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;