2 * Copyright (C) 2004-2005 Red Hat, Inc. All rights reserved.
4 * This file is released under the GPL.
7 #ifndef DM_BIO_RECORD_H
8 #define DM_BIO_RECORD_H
10 #include <linux/bio.h>
13 * There are lots of mutable fields in the bio struct that get
14 * changed by the lower levels of the block layer. Some targets,
15 * such as multipath, may wish to resubmit a bio on error. The
16 * functions in this file help the target record and restore the
20 struct dm_bio_vec_details
{
30 struct dm_bio_details
{
32 struct block_device
*bi_bdev
;
34 unsigned short bi_idx
;
35 unsigned long bi_flags
;
36 struct dm_bio_vec_details bi_io_vec
[BIO_MAX_PAGES
];
39 static inline void dm_bio_record(struct dm_bio_details
*bd
, struct bio
*bio
)
43 bd
->bi_sector
= bio
->bi_sector
;
44 bd
->bi_bdev
= bio
->bi_bdev
;
45 bd
->bi_size
= bio
->bi_size
;
46 bd
->bi_idx
= bio
->bi_idx
;
47 bd
->bi_flags
= bio
->bi_flags
;
49 for (i
= 0; i
< bio
->bi_vcnt
; i
++) {
50 bd
->bi_io_vec
[i
].bv_len
= bio
->bi_io_vec
[i
].bv_len
;
51 bd
->bi_io_vec
[i
].bv_offset
= bio
->bi_io_vec
[i
].bv_offset
;
55 static inline void dm_bio_restore(struct dm_bio_details
*bd
, struct bio
*bio
)
59 bio
->bi_sector
= bd
->bi_sector
;
60 bio
->bi_bdev
= bd
->bi_bdev
;
61 bio
->bi_size
= bd
->bi_size
;
62 bio
->bi_idx
= bd
->bi_idx
;
63 bio
->bi_flags
= bd
->bi_flags
;
65 for (i
= 0; i
< bio
->bi_vcnt
; i
++) {
66 bio
->bi_io_vec
[i
].bv_len
= bd
->bi_io_vec
[i
].bv_len
;
67 bio
->bi_io_vec
[i
].bv_offset
= bd
->bi_io_vec
[i
].bv_offset
;