Add support for Linux kernel up to 6.5

Signed-off-by: Tamar Levovitz <tamar.levovitz@huawei.com>
Signed-off-by: Robert Baldyga <robert.baldyga@huawei.com>
This commit is contained in:
Tamar Levovitz
2024-04-23 15:12:12 +00:00
committed by Robert Baldyga
parent 9fc5e39349
commit a202d8c9f5
8 changed files with 240 additions and 23 deletions

View File

@@ -1,5 +1,6 @@
/*
* Copyright(c) 2012-2022 Intel Corporation
* Copyright(c) 2024 Huawei Technologies
* SPDX-License-Identifier: BSD-3-Clause
*/
#include <linux/module.h>
@@ -11,18 +12,19 @@
#include "exp_obj.h"
#include "debug.h"
#define CAS_DISK_OPEN_FMODE (FMODE_READ | FMODE_WRITE)
#define CAS_DISK_OPEN_MODE (CAS_BLK_MODE_READ | CAS_BLK_MODE_WRITE)
static inline struct block_device *open_bdev_exclusive(const char *path,
fmode_t mode,
void *holder)
CAS_BLK_MODE mode, void *holder)
{
return blkdev_get_by_path(path, mode | FMODE_EXCL, holder);
return cas_blkdev_get_by_path(path, mode | CAS_BLK_MODE_EXCL,
holder);
}
static inline void close_bdev_exclusive(struct block_device *bdev, fmode_t mode)
static inline void close_bdev_exclusive(struct block_device *bdev,
CAS_BLK_MODE mode)
{
blkdev_put(bdev, mode | FMODE_EXCL);
cas_blkdev_put(bdev, mode | CAS_BLK_MODE_EXCL, NULL);
}
int __init cas_init_disks(void)
@@ -67,7 +69,7 @@ struct cas_disk *cas_disk_open(const char *path)
goto error_kstrdup;
}
dsk->bd = open_bdev_exclusive(path, CAS_DISK_OPEN_FMODE, dsk);
dsk->bd = open_bdev_exclusive(path, CAS_DISK_OPEN_MODE, dsk);
if (IS_ERR(dsk->bd)) {
CAS_DEBUG_ERROR("Cannot open exclusive");
result = PTR_ERR(dsk->bd);
@@ -93,7 +95,7 @@ void cas_disk_close(struct cas_disk *dsk)
CAS_DEBUG_DISK(dsk, "Destroying (%p)", dsk);
close_bdev_exclusive(dsk->bd, CAS_DISK_OPEN_FMODE);
close_bdev_exclusive(dsk->bd, CAS_DISK_OPEN_MODE);
kfree(dsk->path);
kmem_cache_free(cas_module.disk_cache, dsk);

View File

@@ -256,9 +256,9 @@ static void _cas_exp_obj_clear_dev_t(struct cas_disk *dsk)
}
}
static int _cas_exp_obj_open(struct block_device *bdev, fmode_t mode)
CAS_BDEV_OPEN(_cas_exp_obj_open, struct gendisk *gd)
{
struct cas_disk *dsk = bdev->bd_disk->private_data;
struct cas_disk *dsk = gd->private_data;
struct cas_exp_obj *exp_obj = dsk->exp_obj;
int result = -ENAVAIL;
@@ -277,7 +277,7 @@ static int _cas_exp_obj_open(struct block_device *bdev, fmode_t mode)
return result;
}
static void _cas_exp_obj_close(struct gendisk *gd, fmode_t mode)
CAS_BDEV_CLOSE(_cas_exp_obj_close, struct gendisk *gd)
{
struct cas_disk *dsk = gd->private_data;
struct cas_exp_obj *exp_obj = dsk->exp_obj;
@@ -292,8 +292,8 @@ static void _cas_exp_obj_close(struct gendisk *gd, fmode_t mode)
static const struct block_device_operations _cas_exp_obj_ops = {
.owner = THIS_MODULE,
.open = _cas_exp_obj_open,
.release = _cas_exp_obj_close,
.open = CAS_REFER_BDEV_OPEN_CALLBACK(_cas_exp_obj_open),
.release = CAS_REFER_BDEV_CLOSE_CALLBACK(_cas_exp_obj_close),
CAS_SET_SUBMIT_BIO(_cas_exp_obj_submit_bio)
};

View File

@@ -1143,8 +1143,8 @@ int cache_mngt_cache_check_device(struct kcas_cache_check_device *cmd_info)
char holder[] = "CAS CHECK CACHE DEVICE\n";
int result;
bdev = blkdev_get_by_path(cmd_info->path_name, (FMODE_EXCL|FMODE_READ),
holder);
bdev = cas_blkdev_get_by_path(cmd_info->path_name,
(CAS_BLK_MODE_EXCL | CAS_BLK_MODE_READ), holder);
if (IS_ERR(bdev)) {
return (PTR_ERR(bdev) == -EBUSY) ?
-OCF_ERR_NOT_OPEN_EXC :
@@ -1165,7 +1165,7 @@ int cache_mngt_cache_check_device(struct kcas_cache_check_device *cmd_info)
cas_blk_close_volume(volume);
out_bdev:
blkdev_put(bdev, (FMODE_EXCL|FMODE_READ));
cas_blkdev_put(bdev, (CAS_BLK_MODE_EXCL | CAS_BLK_MODE_READ), holder);
return result;
}
@@ -2140,8 +2140,8 @@ static int _cache_mngt_probe_metadata(char *cache_path_name,
char holder[] = "CAS CHECK METADATA\n";
int result;
bdev = blkdev_get_by_path(cache_path_name, (FMODE_EXCL|FMODE_READ),
holder);
bdev = cas_blkdev_get_by_path(cache_path_name,
(CAS_BLK_MODE_EXCL | CAS_BLK_MODE_READ), holder);
if (IS_ERR(bdev)) {
return (PTR_ERR(bdev) == -EBUSY) ?
-OCF_ERR_NOT_OPEN_EXC :
@@ -2164,7 +2164,7 @@ static int _cache_mngt_probe_metadata(char *cache_path_name,
cas_blk_close_volume(volume);
out_bdev:
blkdev_put(bdev, (FMODE_EXCL|FMODE_READ));
cas_blkdev_put(bdev, (CAS_BLK_MODE_EXCL | CAS_BLK_MODE_READ), holder);
return result;
}
@@ -2230,10 +2230,10 @@ static int cache_mngt_check_bdev(struct ocf_mngt_cache_device_config *cfg,
struct block_device *bdev;
int part_count;
bool is_part;
const struct ocf_volume_uuid *uuid = ocf_volume_get_uuid(device_cfg->volume);
const struct ocf_volume_uuid *uuid = ocf_volume_get_uuid(cfg->volume);
bdev = blkdev_get_by_path(uuid->data,
(FMODE_EXCL|FMODE_READ), holder);
bdev = cas_blkdev_get_by_path(uuid->data,
(CAS_BLK_MODE_EXCL | CAS_BLK_MODE_READ), holder);
if (IS_ERR(bdev)) {
return (PTR_ERR(bdev) == -EBUSY) ?
-OCF_ERR_NOT_OPEN_EXC :
@@ -2242,7 +2242,7 @@ static int cache_mngt_check_bdev(struct ocf_mngt_cache_device_config *cfg,
is_part = (cas_bdev_whole(bdev) != bdev);
part_count = cas_blk_get_part_count(bdev);
blkdev_put(bdev, (FMODE_EXCL|FMODE_READ));
cas_blkdev_put(bdev, (CAS_BLK_MODE_EXCL | CAS_BLK_MODE_READ), holder);
if (!is_part && part_count > 1 && !force)
return -KCAS_ERR_CONTAINS_PART;