/* wrapper.c */
 int hfsplus_submit_bio(struct super_block *sb, sector_t sector, void *buf,
-                      void **data, int op, int op_flags);
+                      void **data, blk_opf_t opf);
 int hfsplus_read_wrapper(struct super_block *sb);
 
 /*
 
                if ((u8 *)pm - (u8 *)buf >= buf_size) {
                        res = hfsplus_submit_bio(sb,
                                                 *part_start + HFS_PMAP_BLK + i,
-                                                buf, (void **)&pm, REQ_OP_READ,
-                                                0);
+                                                buf, (void **)&pm, REQ_OP_READ);
                        if (res)
                                return res;
                }
                return -ENOMEM;
 
        res = hfsplus_submit_bio(sb, *part_start + HFS_PMAP_BLK,
-                                buf, &data, REQ_OP_READ, 0);
+                                buf, &data, REQ_OP_READ);
        if (res)
                goto out;
 
 
 
        error2 = hfsplus_submit_bio(sb,
                                   sbi->part_start + HFSPLUS_VOLHEAD_SECTOR,
-                                  sbi->s_vhdr_buf, NULL, REQ_OP_WRITE,
+                                  sbi->s_vhdr_buf, NULL, REQ_OP_WRITE |
                                   REQ_SYNC);
        if (!error)
                error = error2;
 
        error2 = hfsplus_submit_bio(sb,
                                  sbi->part_start + sbi->sect_count - 2,
-                                 sbi->s_backup_vhdr_buf, NULL, REQ_OP_WRITE,
+                                 sbi->s_backup_vhdr_buf, NULL, REQ_OP_WRITE |
                                  REQ_SYNC);
        if (!error)
                error2 = error;
 
  * will work correctly.
  */
 int hfsplus_submit_bio(struct super_block *sb, sector_t sector,
-                      void *buf, void **data, int op, int op_flags)
+                      void *buf, void **data, blk_opf_t opf)
 {
+       const enum req_op op = opf & REQ_OP_MASK;
        struct bio *bio;
        int ret = 0;
        u64 io_size;
        offset = start & (io_size - 1);
        sector &= ~((io_size >> HFSPLUS_SECTOR_SHIFT) - 1);
 
-       bio = bio_alloc(sb->s_bdev, 1, op | op_flags, GFP_NOIO);
+       bio = bio_alloc(sb->s_bdev, 1, opf, GFP_NOIO);
        bio->bi_iter.bi_sector = sector;
 
-       if (op != WRITE && data)
+       if (op != REQ_OP_WRITE && data)
                *data = (u8 *)buf + offset;
 
        while (io_size > 0) {
 reread:
        error = hfsplus_submit_bio(sb, part_start + HFSPLUS_VOLHEAD_SECTOR,
                                   sbi->s_vhdr_buf, (void **)&sbi->s_vhdr,
-                                  REQ_OP_READ, 0);
+                                  REQ_OP_READ);
        if (error)
                goto out_free_backup_vhdr;
 
 
        error = hfsplus_submit_bio(sb, part_start + part_size - 2,
                                   sbi->s_backup_vhdr_buf,
-                                  (void **)&sbi->s_backup_vhdr, REQ_OP_READ,
-                                  0);
+                                  (void **)&sbi->s_backup_vhdr, REQ_OP_READ);
        if (error)
                goto out_free_backup_vhdr;