raid1: module implementation

* added raid1 module functions
* raid1 logical volume can be created using standard SPDK RPC
* strip size parameter not supported by raid1

Signed-off-by: Krzysztof Smolinski <krzysztof.smolinski@intel.com>
Change-Id: Id3ee1ba0ec28540ca8eb67b04c3ff655a16b1f19
Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/13444
Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
Community-CI: Mellanox Build Bot
Reviewed-by: Jim Harris <james.r.harris@intel.com>
Reviewed-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com>
Reviewed-by: Krzysztof Karas <krzysztof.karas@intel.com>
Reviewed-by: Shuhei Matsumoto <smatsumoto@nvidia.com>
Reviewed-by: Konrad Sztyber <konrad.sztyber@intel.com>
This commit is contained in:
Krzysztof Smolinski 2022-11-28 15:35:25 +01:00 committed by Tomasz Zawadzki
parent ad94094fc5
commit 208f21cdce
6 changed files with 76 additions and 8 deletions

View File

@ -10,7 +10,7 @@ SO_VER := 4
SO_MINOR := 0
CFLAGS += -I$(SPDK_ROOT_DIR)/lib/bdev/
C_SRCS = bdev_raid.c bdev_raid_rpc.c raid0.c concat.c
C_SRCS = bdev_raid.c bdev_raid_rpc.c raid0.c raid1.c concat.c
ifeq ($(CONFIG_RAID5F),y)
C_SRCS += raid5f.c

View File

@ -738,6 +738,8 @@ static struct {
} g_raid_level_names[] = {
{ "raid0", RAID0 },
{ "0", RAID0 },
{ "raid1", RAID1 },
{ "1", RAID1 },
{ "raid5f", RAID5F },
{ "5f", RAID5F },
{ "concat", CONCAT },
@ -925,7 +927,12 @@ raid_bdev_create(const char *name, uint32_t strip_size, uint8_t num_base_bdevs,
return -EEXIST;
}
if (strip_size && spdk_u32_is_pow2(strip_size) == false) {
if (level == RAID1) {
if (strip_size != 0) {
SPDK_ERRLOG("Strip size is not supported by raid1\n");
return -EINVAL;
}
} else if (spdk_u32_is_pow2(strip_size) == false) {
SPDK_ERRLOG("Invalid strip size %" PRIu32 "\n", strip_size);
return -EINVAL;
}

View File

@ -11,6 +11,7 @@
enum raid_level {
INVALID_RAID_LEVEL = -1,
RAID0 = 0,
RAID1 = 1,
RAID5F = 95, /* 0x5f */
CONCAT = 99,
};

View File

@ -220,11 +220,6 @@ rpc_bdev_raid_create(struct spdk_jsonrpc_request *request,
goto cleanup;
}
if (req.strip_size_kb == 0) {
spdk_jsonrpc_send_error_response(request, -EINVAL, "strip size not specified");
goto cleanup;
}
rc = raid_bdev_create(req.name, req.strip_size_kb, req.base_bdevs.num_base_bdevs,
req.level, &raid_bdev);
if (rc != 0) {

65
module/bdev/raid/raid1.c Normal file
View File

@ -0,0 +1,65 @@
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright (C) 2022 Intel Corporation.
* All rights reserved.
*/
#include "bdev_raid.h"
#include "spdk/log.h"
struct raid1_info {
/* The parent raid bdev */
struct raid_bdev *raid_bdev;
};
static void
raid1_submit_rw_request(struct raid_bdev_io *raid_io)
{
raid_bdev_io_complete(raid_io, SPDK_BDEV_IO_STATUS_FAILED);
}
static int
raid1_start(struct raid_bdev *raid_bdev)
{
uint64_t min_blockcnt = UINT64_MAX;
struct raid_base_bdev_info *base_info;
struct raid1_info *r1info;
r1info = calloc(1, sizeof(*r1info));
if (!r1info) {
SPDK_ERRLOG("Failed to allocate RAID1 info device structure\n");
return -ENOMEM;
}
r1info->raid_bdev = raid_bdev;
RAID_FOR_EACH_BASE_BDEV(raid_bdev, base_info) {
min_blockcnt = spdk_min(min_blockcnt, base_info->bdev->blockcnt);
}
raid_bdev->bdev.blockcnt = min_blockcnt;
raid_bdev->module_private = r1info;
return 0;
}
static bool
raid1_stop(struct raid_bdev *raid_bdev)
{
struct raid1_info *r1info = raid_bdev->module_private;
free(r1info);
return true;
}
static struct raid_bdev_module g_raid1_module = {
.level = RAID1,
.base_bdevs_min = 2,
.base_bdevs_constraint = {CONSTRAINT_MIN_BASE_BDEVS_OPERATIONAL, 1},
.start = raid1_start,
.stop = raid1_stop,
.submit_rw_request = raid1_submit_rw_request,
};
RAID_MODULE_REGISTER(&g_raid1_module)
SPDK_LOG_REGISTER_COMPONENT(bdev_raid1)

View File

@ -2049,7 +2049,7 @@ Format: 'user:u1 secret:s1 muser:mu1 msecret:ms1,user:u2 secret:s2 muser:mu2 mse
p = subparsers.add_parser('bdev_raid_create', help='Create new raid bdev')
p.add_argument('-n', '--name', help='raid bdev name', required=True)
p.add_argument('-z', '--strip-size-kb', help='strip size in KB', type=int)
p.add_argument('-r', '--raid-level', help='raid level, raid0 and a special level concat are supported', required=True)
p.add_argument('-r', '--raid-level', help='raid level, raid0, raid1 and a special level concat are supported', required=True)
p.add_argument('-b', '--base-bdevs', help='base bdevs name, whitespace separated list in quotes', required=True)
p.set_defaults(func=bdev_raid_create)