mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/herbert/cryptodev-2.6.git
synced 2026-04-21 04:53:46 -04:00
block: replace fmode_t with a block-specific type for block open flags
The only overlap between the block open flags mapped into the fmode_t and
other uses of fmode_t are FMODE_READ and FMODE_WRITE. Define a new
blk_mode_t instead for use in blkdev_get_by_{dev,path}, ->open and
->ioctl and stop abusing fmode_t.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Acked-by: Jack Wang <jinpu.wang@ionos.com> [rnbd]
Reviewed-by: Hannes Reinecke <hare@suse.de>
Reviewed-by: Christian Brauner <brauner@kernel.org>
Link: https://lore.kernel.org/r/20230608110258.189493-28-hch@lst.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
committed by
Jens Axboe
parent
5e4ea83467
commit
05bdb99653
@@ -3234,7 +3234,7 @@ struct blk_mq_ops dasd_mq_ops = {
|
||||
.exit_hctx = dasd_exit_hctx,
|
||||
};
|
||||
|
||||
static int dasd_open(struct gendisk *disk, fmode_t mode)
|
||||
static int dasd_open(struct gendisk *disk, blk_mode_t mode)
|
||||
{
|
||||
struct dasd_device *base;
|
||||
int rc;
|
||||
@@ -3268,14 +3268,12 @@ static int dasd_open(struct gendisk *disk, fmode_t mode)
|
||||
rc = -ENODEV;
|
||||
goto out;
|
||||
}
|
||||
|
||||
if ((mode & FMODE_WRITE) &&
|
||||
if ((mode & BLK_OPEN_WRITE) &&
|
||||
(test_bit(DASD_FLAG_DEVICE_RO, &base->flags) ||
|
||||
(base->features & DASD_FEATURE_READONLY))) {
|
||||
rc = -EROFS;
|
||||
goto out;
|
||||
}
|
||||
|
||||
dasd_put_device(base);
|
||||
return 0;
|
||||
|
||||
|
||||
@@ -130,7 +130,8 @@ int dasd_scan_partitions(struct dasd_block *block)
|
||||
struct block_device *bdev;
|
||||
int rc;
|
||||
|
||||
bdev = blkdev_get_by_dev(disk_devt(block->gdp), FMODE_READ, NULL, NULL);
|
||||
bdev = blkdev_get_by_dev(disk_devt(block->gdp), BLK_OPEN_READ, NULL,
|
||||
NULL);
|
||||
if (IS_ERR(bdev)) {
|
||||
DBF_DEV_EVENT(DBF_ERR, block->base,
|
||||
"scan partitions error, blkdev_get returned %ld",
|
||||
|
||||
@@ -965,7 +965,8 @@ int dasd_scan_partitions(struct dasd_block *);
|
||||
void dasd_destroy_partitions(struct dasd_block *);
|
||||
|
||||
/* externals in dasd_ioctl.c */
|
||||
int dasd_ioctl(struct block_device *, fmode_t, unsigned int, unsigned long);
|
||||
int dasd_ioctl(struct block_device *bdev, blk_mode_t mode, unsigned int cmd,
|
||||
unsigned long arg);
|
||||
int dasd_set_read_only(struct block_device *bdev, bool ro);
|
||||
|
||||
/* externals in dasd_proc.c */
|
||||
|
||||
@@ -612,7 +612,7 @@ static int dasd_ioctl_readall_cmb(struct dasd_block *block, unsigned int cmd,
|
||||
return ret;
|
||||
}
|
||||
|
||||
int dasd_ioctl(struct block_device *bdev, fmode_t mode,
|
||||
int dasd_ioctl(struct block_device *bdev, blk_mode_t mode,
|
||||
unsigned int cmd, unsigned long arg)
|
||||
{
|
||||
struct dasd_block *block;
|
||||
|
||||
@@ -28,7 +28,7 @@
|
||||
#define DCSSBLK_PARM_LEN 400
|
||||
#define DCSS_BUS_ID_SIZE 20
|
||||
|
||||
static int dcssblk_open(struct gendisk *disk, fmode_t mode);
|
||||
static int dcssblk_open(struct gendisk *disk, blk_mode_t mode);
|
||||
static void dcssblk_release(struct gendisk *disk);
|
||||
static void dcssblk_submit_bio(struct bio *bio);
|
||||
static long dcssblk_dax_direct_access(struct dax_device *dax_dev, pgoff_t pgoff,
|
||||
@@ -809,7 +809,7 @@ out_buf:
|
||||
}
|
||||
|
||||
static int
|
||||
dcssblk_open(struct gendisk *disk, fmode_t mode)
|
||||
dcssblk_open(struct gendisk *disk, blk_mode_t mode)
|
||||
{
|
||||
struct dcssblk_dev_info *dev_info = disk->private_data;
|
||||
int rc;
|
||||
|
||||
Reference in New Issue
Block a user