Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
0420c5dd
Commit
0420c5dd
authored
Feb 06, 2018
by
Ilya Dryomov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
rbd: remove rbd_img_request_fill() and helpers
Signed-off-by:
Ilya Dryomov
<
idryomov@gmail.com
>
parent
5a237819
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
0 additions
and
98 deletions
+0
-98
drivers/block/rbd.c
drivers/block/rbd.c
+0
-98
No files found.
drivers/block/rbd.c
View file @
0420c5dd
...
@@ -1207,27 +1207,6 @@ static void rbd_dev_mapping_clear(struct rbd_device *rbd_dev)
...
@@ -1207,27 +1207,6 @@ static void rbd_dev_mapping_clear(struct rbd_device *rbd_dev)
rbd_dev
->
mapping
.
features
=
0
;
rbd_dev
->
mapping
.
features
=
0
;
}
}
static
u64
rbd_segment_offset
(
struct
rbd_device
*
rbd_dev
,
u64
offset
)
{
u64
segment_size
=
rbd_obj_bytes
(
&
rbd_dev
->
header
);
return
offset
&
(
segment_size
-
1
);
}
static
u64
rbd_segment_length
(
struct
rbd_device
*
rbd_dev
,
u64
offset
,
u64
length
)
{
u64
segment_size
=
rbd_obj_bytes
(
&
rbd_dev
->
header
);
offset
&=
segment_size
-
1
;
rbd_assert
(
length
<=
U64_MAX
-
offset
);
if
(
offset
+
length
>
segment_size
)
length
=
segment_size
-
offset
;
return
length
;
}
static
void
zero_bvec
(
struct
bio_vec
*
bv
)
static
void
zero_bvec
(
struct
bio_vec
*
bv
)
{
{
void
*
buf
;
void
*
buf
;
...
@@ -1977,83 +1956,6 @@ static int __rbd_img_fill_request(struct rbd_img_request *img_req)
...
@@ -1977,83 +1956,6 @@ static int __rbd_img_fill_request(struct rbd_img_request *img_req)
return
0
;
return
0
;
}
}
/*
* Split up an image request into one or more object requests, each
* to a different object. The "type" parameter indicates whether
* "data_desc" is the pointer to the head of a list of bio
* structures, or the base of a page array. In either case this
* function assumes data_desc describes memory sufficient to hold
* all data described by the image request.
*/
static
int
rbd_img_request_fill
(
struct
rbd_img_request
*
img_request
,
enum
obj_request_type
type
,
void
*
data_desc
)
{
struct
rbd_device
*
rbd_dev
=
img_request
->
rbd_dev
;
struct
rbd_obj_request
*
obj_request
=
NULL
;
struct
rbd_obj_request
*
next_obj_request
;
struct
ceph_bio_iter
bio_it
;
struct
ceph_bvec_iter
bvec_it
;
u64
img_offset
;
u64
resid
;
dout
(
"%s: img %p type %d data_desc %p
\n
"
,
__func__
,
img_request
,
(
int
)
type
,
data_desc
);
img_offset
=
img_request
->
offset
;
resid
=
img_request
->
length
;
rbd_assert
(
resid
>
0
);
if
(
type
==
OBJ_REQUEST_BIO
)
{
bio_it
=
*
(
struct
ceph_bio_iter
*
)
data_desc
;
rbd_assert
(
img_offset
==
bio_it
.
iter
.
bi_sector
<<
SECTOR_SHIFT
);
}
else
if
(
type
==
OBJ_REQUEST_BVECS
)
{
bvec_it
=
*
(
struct
ceph_bvec_iter
*
)
data_desc
;
}
while
(
resid
)
{
u64
object_no
=
img_offset
>>
rbd_dev
->
header
.
obj_order
;
u64
offset
=
rbd_segment_offset
(
rbd_dev
,
img_offset
);
u64
length
=
rbd_segment_length
(
rbd_dev
,
img_offset
,
resid
);
obj_request
=
rbd_obj_request_create
();
if
(
!
obj_request
)
goto
out_unwind
;
obj_request
->
ex
.
oe_objno
=
object_no
;
obj_request
->
ex
.
oe_off
=
offset
;
obj_request
->
ex
.
oe_len
=
length
;
/*
* set obj_request->img_request before creating the
* osd_request so that it gets the right snapc
*/
rbd_img_obj_request_add
(
img_request
,
obj_request
);
if
(
type
==
OBJ_REQUEST_BIO
)
{
obj_request
->
bio_pos
=
bio_it
;
ceph_bio_iter_advance
(
&
bio_it
,
length
);
}
else
if
(
type
==
OBJ_REQUEST_BVECS
)
{
obj_request
->
bvec_pos
=
bvec_it
;
ceph_bvec_iter_shorten
(
&
obj_request
->
bvec_pos
,
length
);
ceph_bvec_iter_advance
(
&
bvec_it
,
length
);
}
img_offset
+=
length
;
resid
-=
length
;
}
img_request
->
data_type
=
type
;
return
__rbd_img_fill_request
(
img_request
);
out_unwind:
for_each_obj_request_safe
(
img_request
,
obj_request
,
next_obj_request
)
rbd_img_obj_request_del
(
img_request
,
obj_request
);
return
-
ENOMEM
;
}
union
rbd_img_fill_iter
{
union
rbd_img_fill_iter
{
struct
ceph_bio_iter
bio_iter
;
struct
ceph_bio_iter
bio_iter
;
struct
ceph_bvec_iter
bvec_iter
;
struct
ceph_bvec_iter
bvec_iter
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment