summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2016-11-21 18:18:18 +0300
committerJens Axboe <axboe@fb.com>2016-11-21 19:35:05 +0300
commit93c5bdf7ab71bbdae27f8f51fa175e06f000d69d (patch)
tree1a71e55964b3063436a362eba6bbf75e3e52217f
parent5a8b187c61e9cb1aa1e960fcbadb13beb9401e5e (diff)
downloadlinux-93c5bdf7ab71bbdae27f8f51fa175e06f000d69d.tar.xz
block: clear all of bi_opf in bio_set_op_attrs
Since commit 87374179 ("block: add a proper block layer data direction encoding") we only or the new op and flags into bi_opf in bio_set_op_attrs instead of clearing the old value. I've not seen any breakage with the new behavior, but it seems dangerous. Also convert it to an inline function to make the argument passing safer. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Jens Axboe <axboe@fb.com>
-rw-r--r--include/linux/blk_types.h7
1 files changed, 5 insertions, 2 deletions
diff --git a/include/linux/blk_types.h b/include/linux/blk_types.h
index 4d0044d09984..f57458a6a93b 100644
--- a/include/linux/blk_types.h
+++ b/include/linux/blk_types.h
@@ -207,8 +207,11 @@ enum req_flag_bits {
((req)->cmd_flags & REQ_OP_MASK)
/* obsolete, don't use in new code */
-#define bio_set_op_attrs(bio, op, op_flags) \
- ((bio)->bi_opf |= (op | op_flags))
+static inline void bio_set_op_attrs(struct bio *bio, unsigned op,
+ unsigned op_flags)
+{
+ bio->bi_opf = op | op_flags;
+}
static inline bool op_is_write(unsigned int op)
{