1488570ebSJim Harris /* SPDX-License-Identifier: BSD-3-Clause 2a6dbe372Spaul luse * Copyright (C) 2018 Intel Corporation. 33559bec4SDaniel Verkamp * All rights reserved. 454db60cdSMike Gerdts * Copyright (c) 2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved. 53559bec4SDaniel Verkamp */ 63559bec4SDaniel Verkamp 7ae431e31SKonrad Sztyber #include "spdk_internal/cunit.h" 83559bec4SDaniel Verkamp 9999d6df4SBen Walker #include "common/lib/ut_multithread.c" 105ffa5c00SPawel Wodkowski #include "unit/lib/json_mock.c" 113559bec4SDaniel Verkamp 12c4fee1e9SPawel Wodkowski #include "spdk/config.h" 13736f6937SChangpeng Liu /* HACK: disable VTune integration so the unit test doesn't need VTune headers and libs to build */ 14736f6937SChangpeng Liu #undef SPDK_CONFIG_VTUNE 15736f6937SChangpeng Liu 163559bec4SDaniel Verkamp #include "bdev/bdev.c" 173559bec4SDaniel Verkamp #include "bdev/part.c" 183559bec4SDaniel Verkamp 19*ff173863SShuhei Matsumoto #include "common/lib/bdev/common_stubs.h" 20*ff173863SShuhei Matsumoto 212b5f264eSKanKuo struct ut_expected_io { 222b5f264eSKanKuo }; 232b5f264eSKanKuo 242b5f264eSKanKuo struct bdev_ut_channel { 252b5f264eSKanKuo TAILQ_HEAD(, spdk_bdev_io) outstanding_io; 262b5f264eSKanKuo uint32_t outstanding_io_count; 272b5f264eSKanKuo TAILQ_HEAD(, ut_expected_io) expected_io; 282b5f264eSKanKuo }; 292b5f264eSKanKuo 302b5f264eSKanKuo static uint32_t g_part_ut_io_device; 312b5f264eSKanKuo static struct bdev_ut_channel *g_bdev_ut_channel; 3280b22cf3SKonrad Sztyber static int g_accel_io_device; 332b5f264eSKanKuo 341299439fSAlexey Marchuk DEFINE_RETURN_MOCK(spdk_memory_domain_pull_data, int); 351299439fSAlexey Marchuk int 361299439fSAlexey Marchuk spdk_memory_domain_pull_data(struct spdk_memory_domain *src_domain, void *src_domain_ctx, 371299439fSAlexey Marchuk struct iovec *src_iov, uint32_t src_iov_cnt, struct iovec *dst_iov, uint32_t dst_iov_cnt, 381299439fSAlexey Marchuk spdk_memory_domain_data_cpl_cb cpl_cb, void *cpl_cb_arg) 391299439fSAlexey Marchuk { 401299439fSAlexey Marchuk HANDLE_RETURN_MOCK(spdk_memory_domain_pull_data); 411299439fSAlexey Marchuk 421299439fSAlexey Marchuk cpl_cb(cpl_cb_arg, 0); 431299439fSAlexey Marchuk return 0; 441299439fSAlexey Marchuk } 451299439fSAlexey Marchuk 461299439fSAlexey Marchuk DEFINE_RETURN_MOCK(spdk_memory_domain_push_data, int); 471299439fSAlexey Marchuk int 481299439fSAlexey Marchuk spdk_memory_domain_push_data(struct spdk_memory_domain *dst_domain, void *dst_domain_ctx, 491299439fSAlexey Marchuk struct iovec *dst_iov, uint32_t dst_iovcnt, struct iovec *src_iov, uint32_t src_iovcnt, 501299439fSAlexey Marchuk spdk_memory_domain_data_cpl_cb cpl_cb, void *cpl_cb_arg) 511299439fSAlexey Marchuk { 521299439fSAlexey Marchuk HANDLE_RETURN_MOCK(spdk_memory_domain_push_data); 531299439fSAlexey Marchuk 541299439fSAlexey Marchuk cpl_cb(cpl_cb_arg, 0); 551299439fSAlexey Marchuk return 0; 561299439fSAlexey Marchuk } 57afaabcceSJim Harris 5880b22cf3SKonrad Sztyber struct spdk_io_channel * 5980b22cf3SKonrad Sztyber spdk_accel_get_io_channel(void) 6080b22cf3SKonrad Sztyber { 6180b22cf3SKonrad Sztyber return spdk_get_io_channel(&g_accel_io_device); 6280b22cf3SKonrad Sztyber } 6380b22cf3SKonrad Sztyber 6480b22cf3SKonrad Sztyber static int 6580b22cf3SKonrad Sztyber ut_accel_ch_create_cb(void *io_device, void *ctx) 6680b22cf3SKonrad Sztyber { 6780b22cf3SKonrad Sztyber return 0; 6880b22cf3SKonrad Sztyber } 6980b22cf3SKonrad Sztyber 7080b22cf3SKonrad Sztyber static void 7180b22cf3SKonrad Sztyber ut_accel_ch_destroy_cb(void *io_device, void *ctx) 7280b22cf3SKonrad Sztyber { 7380b22cf3SKonrad Sztyber } 7480b22cf3SKonrad Sztyber 7580b22cf3SKonrad Sztyber static int 7680b22cf3SKonrad Sztyber ut_part_setup(void) 7780b22cf3SKonrad Sztyber { 7880b22cf3SKonrad Sztyber spdk_io_device_register(&g_accel_io_device, ut_accel_ch_create_cb, 7980b22cf3SKonrad Sztyber ut_accel_ch_destroy_cb, 0, NULL); 8080b22cf3SKonrad Sztyber return 0; 8180b22cf3SKonrad Sztyber } 8280b22cf3SKonrad Sztyber 8380b22cf3SKonrad Sztyber static int 8480b22cf3SKonrad Sztyber ut_part_teardown(void) 8580b22cf3SKonrad Sztyber { 8680b22cf3SKonrad Sztyber spdk_io_device_unregister(&g_accel_io_device, NULL); 8780b22cf3SKonrad Sztyber 8880b22cf3SKonrad Sztyber return 0; 8980b22cf3SKonrad Sztyber } 9080b22cf3SKonrad Sztyber 91ecd5f651SSeth Howell static void 92c8341f12SSeth Howell _part_cleanup(struct spdk_bdev_part *part) 93c8341f12SSeth Howell { 9440d89d60SGangCao spdk_io_device_unregister(part, NULL); 95c8341f12SSeth Howell free(part->internal.bdev.name); 96c8341f12SSeth Howell free(part->internal.bdev.product_name); 97c8341f12SSeth Howell } 98c8341f12SSeth Howell 992b5f264eSKanKuo static struct spdk_io_channel * 1002b5f264eSKanKuo part_ut_get_io_channel(void *ctx) 1012b5f264eSKanKuo { 1022b5f264eSKanKuo return spdk_get_io_channel(&g_part_ut_io_device); 1032b5f264eSKanKuo } 1042b5f264eSKanKuo 1053559bec4SDaniel Verkamp void 1063559bec4SDaniel Verkamp spdk_scsi_nvme_translate(const struct spdk_bdev_io *bdev_io, 1073559bec4SDaniel Verkamp int *sc, int *sk, int *asc, int *ascq) 1083559bec4SDaniel Verkamp { 1093559bec4SDaniel Verkamp } 1103559bec4SDaniel Verkamp 1112b5f264eSKanKuo static int 1122b5f264eSKanKuo bdev_ut_create_ch(void *io_device, void *ctx_buf) 1132b5f264eSKanKuo { 1142b5f264eSKanKuo struct bdev_ut_channel *ch = ctx_buf; 1152b5f264eSKanKuo 1162b5f264eSKanKuo CU_ASSERT(g_bdev_ut_channel == NULL); 1172b5f264eSKanKuo g_bdev_ut_channel = ch; 1182b5f264eSKanKuo g_part_ut_io_device++; 1192b5f264eSKanKuo 1202b5f264eSKanKuo TAILQ_INIT(&ch->outstanding_io); 1212b5f264eSKanKuo ch->outstanding_io_count = 0; 1222b5f264eSKanKuo TAILQ_INIT(&ch->expected_io); 1232b5f264eSKanKuo return 0; 1242b5f264eSKanKuo } 1252b5f264eSKanKuo 1262b5f264eSKanKuo static void 1272b5f264eSKanKuo bdev_ut_destroy_ch(void *io_device, void *ctx_buf) 1282b5f264eSKanKuo { 1292b5f264eSKanKuo CU_ASSERT(g_bdev_ut_channel != NULL); 1302b5f264eSKanKuo g_bdev_ut_channel = NULL; 1312b5f264eSKanKuo g_part_ut_io_device--; 1322b5f264eSKanKuo } 1332b5f264eSKanKuo 1342b5f264eSKanKuo struct spdk_bdev_module bdev_ut_if; 1352b5f264eSKanKuo 1362b5f264eSKanKuo static int 1372b5f264eSKanKuo bdev_ut_module_init(void) 1382b5f264eSKanKuo { 1392b5f264eSKanKuo spdk_io_device_register(&g_part_ut_io_device, bdev_ut_create_ch, bdev_ut_destroy_ch, 1402b5f264eSKanKuo sizeof(struct bdev_ut_channel), NULL); 1412b5f264eSKanKuo spdk_bdev_module_init_done(&bdev_ut_if); 1422b5f264eSKanKuo return 0; 1432b5f264eSKanKuo } 1442b5f264eSKanKuo 1452b5f264eSKanKuo static void 1462b5f264eSKanKuo bdev_ut_module_fini(void) 1472b5f264eSKanKuo { 1482b5f264eSKanKuo spdk_io_device_unregister(&g_part_ut_io_device, NULL); 1492b5f264eSKanKuo } 1502b5f264eSKanKuo 15119100ed5SDaniel Verkamp struct spdk_bdev_module bdev_ut_if = { 1524d367354SPawel Wodkowski .name = "bdev_ut", 1532b5f264eSKanKuo .module_init = bdev_ut_module_init, 1542b5f264eSKanKuo .module_fini = bdev_ut_module_fini, 1552b5f264eSKanKuo .async_init = true, 1564d367354SPawel Wodkowski }; 1574d367354SPawel Wodkowski 1584d367354SPawel Wodkowski static void vbdev_ut_examine(struct spdk_bdev *bdev); 1594d367354SPawel Wodkowski 1602b5f264eSKanKuo static int 1612b5f264eSKanKuo vbdev_ut_module_init(void) 1622b5f264eSKanKuo { 1632b5f264eSKanKuo return 0; 1642b5f264eSKanKuo } 1652b5f264eSKanKuo 1662b5f264eSKanKuo static void 1672b5f264eSKanKuo vbdev_ut_module_fini(void) 1682b5f264eSKanKuo { 1692b5f264eSKanKuo } 1702b5f264eSKanKuo 17119100ed5SDaniel Verkamp struct spdk_bdev_module vbdev_ut_if = { 1724d367354SPawel Wodkowski .name = "vbdev_ut", 1732b5f264eSKanKuo .module_init = vbdev_ut_module_init, 1742b5f264eSKanKuo .module_fini = vbdev_ut_module_fini, 1759d258c75SPiotr Pelplinski .examine_config = vbdev_ut_examine, 1764d367354SPawel Wodkowski }; 1774d367354SPawel Wodkowski 178df6b55fdSgila SPDK_BDEV_MODULE_REGISTER(bdev_ut, &bdev_ut_if) 179df6b55fdSgila SPDK_BDEV_MODULE_REGISTER(vbdev_ut, &vbdev_ut_if) 1803559bec4SDaniel Verkamp 1813559bec4SDaniel Verkamp static void 1823559bec4SDaniel Verkamp vbdev_ut_examine(struct spdk_bdev *bdev) 1833559bec4SDaniel Verkamp { 1844d367354SPawel Wodkowski spdk_bdev_module_examine_done(&vbdev_ut_if); 1853559bec4SDaniel Verkamp } 1863559bec4SDaniel Verkamp 1873559bec4SDaniel Verkamp static int 1883559bec4SDaniel Verkamp __destruct(void *ctx) 1893559bec4SDaniel Verkamp { 1903559bec4SDaniel Verkamp return 0; 1913559bec4SDaniel Verkamp } 1923559bec4SDaniel Verkamp 1931ce7786fSShuhei Matsumoto static bool 1941ce7786fSShuhei Matsumoto __io_type_supported(void *ctx, enum spdk_bdev_io_type type) 1951ce7786fSShuhei Matsumoto { 1961ce7786fSShuhei Matsumoto return true; 1971ce7786fSShuhei Matsumoto } 1981ce7786fSShuhei Matsumoto 1993559bec4SDaniel Verkamp static struct spdk_bdev_fn_table base_fn_table = { 2003559bec4SDaniel Verkamp .destruct = __destruct, 2012b5f264eSKanKuo .get_io_channel = part_ut_get_io_channel, 2021ce7786fSShuhei Matsumoto .io_type_supported = __io_type_supported, 2033559bec4SDaniel Verkamp }; 2043559bec4SDaniel Verkamp static struct spdk_bdev_fn_table part_fn_table = { 2053559bec4SDaniel Verkamp .destruct = __destruct, 2061ce7786fSShuhei Matsumoto .io_type_supported = __io_type_supported, 2073559bec4SDaniel Verkamp }; 2083559bec4SDaniel Verkamp 2093559bec4SDaniel Verkamp static void 2102b5f264eSKanKuo bdev_init_cb(void *arg, int rc) 2112b5f264eSKanKuo { 2122b5f264eSKanKuo CU_ASSERT(rc == 0); 2132b5f264eSKanKuo } 2142b5f264eSKanKuo 2152b5f264eSKanKuo static void 2162b5f264eSKanKuo bdev_fini_cb(void *arg) 2172b5f264eSKanKuo { 2182b5f264eSKanKuo } 2192b5f264eSKanKuo 2202b5f264eSKanKuo static void 221107741fcSKonrad Sztyber ut_init_bdev(void) 222107741fcSKonrad Sztyber { 2235a3e64efSKonrad Sztyber int rc; 2245a3e64efSKonrad Sztyber 2255a3e64efSKonrad Sztyber rc = spdk_iobuf_initialize(); 2265a3e64efSKonrad Sztyber CU_ASSERT(rc == 0); 2275a3e64efSKonrad Sztyber 228107741fcSKonrad Sztyber spdk_bdev_initialize(bdev_init_cb, NULL); 229107741fcSKonrad Sztyber poll_threads(); 230107741fcSKonrad Sztyber } 231107741fcSKonrad Sztyber 232107741fcSKonrad Sztyber static void 233107741fcSKonrad Sztyber ut_fini_bdev(void) 234107741fcSKonrad Sztyber { 235107741fcSKonrad Sztyber spdk_bdev_finish(bdev_fini_cb, NULL); 2365a3e64efSKonrad Sztyber spdk_iobuf_finish(bdev_fini_cb, NULL); 237107741fcSKonrad Sztyber poll_threads(); 238107741fcSKonrad Sztyber } 239107741fcSKonrad Sztyber 240107741fcSKonrad Sztyber static void 2412b5f264eSKanKuo bdev_ut_event_cb(enum spdk_bdev_event_type type, struct spdk_bdev *bdev, void *event_ctx) 2422b5f264eSKanKuo { 2432b5f264eSKanKuo } 2442b5f264eSKanKuo 2452b5f264eSKanKuo static void 2463559bec4SDaniel Verkamp part_test(void) 2473559bec4SDaniel Verkamp { 2483559bec4SDaniel Verkamp struct spdk_bdev_part_base *base; 2494473942fSPawel Wodkowski struct spdk_bdev_part part1 = {}; 2504473942fSPawel Wodkowski struct spdk_bdev_part part2 = {}; 251687d5a87SGangCao struct spdk_bdev_part part3 = {}; 2523559bec4SDaniel Verkamp struct spdk_bdev bdev_base = {}; 2533559bec4SDaniel Verkamp SPDK_BDEV_PART_TAILQ tailq = TAILQ_HEAD_INITIALIZER(tailq); 2543559bec4SDaniel Verkamp int rc; 2553559bec4SDaniel Verkamp 2563559bec4SDaniel Verkamp bdev_base.name = "base"; 2573559bec4SDaniel Verkamp bdev_base.fn_table = &base_fn_table; 2584d367354SPawel Wodkowski bdev_base.module = &bdev_ut_if; 2593559bec4SDaniel Verkamp rc = spdk_bdev_register(&bdev_base); 2603559bec4SDaniel Verkamp CU_ASSERT(rc == 0); 26199935996STomasz Zawadzki rc = spdk_bdev_part_base_construct_ext("base", NULL, &vbdev_ut_if, 2625d5243e0SSeth Howell &part_fn_table, &tailq, NULL, 26399935996STomasz Zawadzki NULL, 0, NULL, NULL, &base); 2645d5243e0SSeth Howell 26599935996STomasz Zawadzki CU_ASSERT(rc == 0); 2665d5243e0SSeth Howell SPDK_CU_ASSERT_FATAL(base != NULL); 2673559bec4SDaniel Verkamp 26811ccf3beSSeth Howell rc = spdk_bdev_part_construct(&part1, base, "test1", 0, 100, "test"); 26911ccf3beSSeth Howell SPDK_CU_ASSERT_FATAL(rc == 0); 270687d5a87SGangCao SPDK_CU_ASSERT_FATAL(base->ref == 1); 271687d5a87SGangCao SPDK_CU_ASSERT_FATAL(base->claimed == true); 27211ccf3beSSeth Howell rc = spdk_bdev_part_construct(&part2, base, "test2", 100, 100, "test"); 27311ccf3beSSeth Howell SPDK_CU_ASSERT_FATAL(rc == 0); 274687d5a87SGangCao SPDK_CU_ASSERT_FATAL(base->ref == 2); 275687d5a87SGangCao SPDK_CU_ASSERT_FATAL(base->claimed == true); 276687d5a87SGangCao rc = spdk_bdev_part_construct(&part3, base, "test1", 0, 100, "test"); 277687d5a87SGangCao SPDK_CU_ASSERT_FATAL(rc != 0); 278687d5a87SGangCao SPDK_CU_ASSERT_FATAL(base->ref == 2); 279687d5a87SGangCao SPDK_CU_ASSERT_FATAL(base->claimed == true); 2803559bec4SDaniel Verkamp 281eb20b890SDarek Stojaczyk spdk_bdev_part_base_hotremove(base, &tailq); 2823559bec4SDaniel Verkamp 2833559bec4SDaniel Verkamp spdk_bdev_part_base_free(base); 284c8341f12SSeth Howell _part_cleanup(&part1); 285c8341f12SSeth Howell _part_cleanup(&part2); 2863559bec4SDaniel Verkamp spdk_bdev_unregister(&bdev_base, NULL, NULL); 287999d6df4SBen Walker 288999d6df4SBen Walker poll_threads(); 2893559bec4SDaniel Verkamp } 2903559bec4SDaniel Verkamp 291b4f9bb44SKanKuo static void 292b4f9bb44SKanKuo part_free_test(void) 293b4f9bb44SKanKuo { 294b4f9bb44SKanKuo struct spdk_bdev_part_base *base = NULL; 295b4f9bb44SKanKuo struct spdk_bdev_part *part; 296b4f9bb44SKanKuo struct spdk_bdev bdev_base = {}; 297b4f9bb44SKanKuo SPDK_BDEV_PART_TAILQ tailq = TAILQ_HEAD_INITIALIZER(tailq); 298b4f9bb44SKanKuo int rc; 299b4f9bb44SKanKuo 300b4f9bb44SKanKuo bdev_base.name = "base"; 301b4f9bb44SKanKuo bdev_base.fn_table = &base_fn_table; 302b4f9bb44SKanKuo bdev_base.module = &bdev_ut_if; 303b4f9bb44SKanKuo rc = spdk_bdev_register(&bdev_base); 304b4f9bb44SKanKuo CU_ASSERT(rc == 0); 305b4f9bb44SKanKuo poll_threads(); 306b4f9bb44SKanKuo 307b4f9bb44SKanKuo rc = spdk_bdev_part_base_construct_ext("base", NULL, &vbdev_ut_if, 308b4f9bb44SKanKuo &part_fn_table, &tailq, NULL, 309b4f9bb44SKanKuo NULL, 0, NULL, NULL, &base); 310b4f9bb44SKanKuo CU_ASSERT(rc == 0); 311b4f9bb44SKanKuo CU_ASSERT(TAILQ_EMPTY(&tailq)); 312b4f9bb44SKanKuo SPDK_CU_ASSERT_FATAL(base != NULL); 313b4f9bb44SKanKuo 314b4f9bb44SKanKuo part = calloc(1, sizeof(*part)); 315b4f9bb44SKanKuo SPDK_CU_ASSERT_FATAL(part != NULL); 316b4f9bb44SKanKuo rc = spdk_bdev_part_construct(part, base, "test", 0, 100, "test"); 317b4f9bb44SKanKuo SPDK_CU_ASSERT_FATAL(rc == 0); 318b4f9bb44SKanKuo poll_threads(); 319b4f9bb44SKanKuo CU_ASSERT(!TAILQ_EMPTY(&tailq)); 320b4f9bb44SKanKuo 321b4f9bb44SKanKuo spdk_bdev_unregister(&part->internal.bdev, NULL, NULL); 322b4f9bb44SKanKuo poll_threads(); 323b4f9bb44SKanKuo 324b4f9bb44SKanKuo rc = spdk_bdev_part_free(part); 325b4f9bb44SKanKuo CU_ASSERT(rc == 1); 326b4f9bb44SKanKuo poll_threads(); 327b4f9bb44SKanKuo CU_ASSERT(TAILQ_EMPTY(&tailq)); 328b4f9bb44SKanKuo 329b4f9bb44SKanKuo spdk_bdev_unregister(&bdev_base, NULL, NULL); 330b4f9bb44SKanKuo poll_threads(); 331b4f9bb44SKanKuo } 332b4f9bb44SKanKuo 3332b5f264eSKanKuo static void 3342b5f264eSKanKuo part_get_io_channel_test(void) 3352b5f264eSKanKuo { 3362b5f264eSKanKuo struct spdk_bdev_part_base *base = NULL; 3372b5f264eSKanKuo struct spdk_bdev_desc *desc = NULL; 3382b5f264eSKanKuo struct spdk_io_channel *io_ch; 3392b5f264eSKanKuo struct spdk_bdev_part *part; 3402b5f264eSKanKuo struct spdk_bdev bdev_base = {}; 3412b5f264eSKanKuo SPDK_BDEV_PART_TAILQ tailq = TAILQ_HEAD_INITIALIZER(tailq); 3422b5f264eSKanKuo int rc; 3432b5f264eSKanKuo 344107741fcSKonrad Sztyber ut_init_bdev(); 3452b5f264eSKanKuo bdev_base.name = "base"; 3462b5f264eSKanKuo bdev_base.blocklen = 512; 3472b5f264eSKanKuo bdev_base.blockcnt = 1024; 3482b5f264eSKanKuo bdev_base.fn_table = &base_fn_table; 3492b5f264eSKanKuo bdev_base.module = &bdev_ut_if; 3502b5f264eSKanKuo rc = spdk_bdev_register(&bdev_base); 3512b5f264eSKanKuo CU_ASSERT(rc == 0); 3522b5f264eSKanKuo 3532b5f264eSKanKuo rc = spdk_bdev_part_base_construct_ext("base", NULL, &vbdev_ut_if, 3542b5f264eSKanKuo &part_fn_table, &tailq, NULL, 3552b5f264eSKanKuo NULL, 100, NULL, NULL, &base); 3562b5f264eSKanKuo CU_ASSERT(rc == 0); 3572b5f264eSKanKuo CU_ASSERT(TAILQ_EMPTY(&tailq)); 3582b5f264eSKanKuo SPDK_CU_ASSERT_FATAL(base != NULL); 3592b5f264eSKanKuo 3602b5f264eSKanKuo part = calloc(1, sizeof(*part)); 3612b5f264eSKanKuo SPDK_CU_ASSERT_FATAL(part != NULL); 3622b5f264eSKanKuo rc = spdk_bdev_part_construct(part, base, "test", 0, 100, "test"); 3632b5f264eSKanKuo SPDK_CU_ASSERT_FATAL(rc == 0); 3642b5f264eSKanKuo CU_ASSERT(!TAILQ_EMPTY(&tailq)); 3652b5f264eSKanKuo 3662b5f264eSKanKuo rc = spdk_bdev_open_ext("test", true, bdev_ut_event_cb, NULL, &desc); 3672b5f264eSKanKuo CU_ASSERT(rc == 0); 3682b5f264eSKanKuo SPDK_CU_ASSERT_FATAL(desc != NULL); 3692b5f264eSKanKuo CU_ASSERT(&part->internal.bdev == spdk_bdev_desc_get_bdev(desc)); 3702b5f264eSKanKuo 3712b5f264eSKanKuo io_ch = spdk_bdev_get_io_channel(desc); 3722b5f264eSKanKuo CU_ASSERT(io_ch != NULL); 3732b5f264eSKanKuo CU_ASSERT(g_part_ut_io_device == 1); 3742b5f264eSKanKuo 3752b5f264eSKanKuo spdk_put_io_channel(io_ch); 3762b5f264eSKanKuo spdk_bdev_close(desc); 3772b5f264eSKanKuo spdk_bdev_unregister(&part->internal.bdev, NULL, NULL); 3782b5f264eSKanKuo poll_threads(); 3792b5f264eSKanKuo CU_ASSERT(g_part_ut_io_device == 0); 3802b5f264eSKanKuo 3812b5f264eSKanKuo rc = spdk_bdev_part_free(part); 3822b5f264eSKanKuo CU_ASSERT(rc == 1); 3832b5f264eSKanKuo poll_threads(); 3842b5f264eSKanKuo CU_ASSERT(TAILQ_EMPTY(&tailq)); 3852b5f264eSKanKuo 3862b5f264eSKanKuo spdk_bdev_unregister(&bdev_base, NULL, NULL); 387107741fcSKonrad Sztyber ut_fini_bdev(); 3882b5f264eSKanKuo } 3892b5f264eSKanKuo 39054db60cdSMike Gerdts static void 39154db60cdSMike Gerdts part_construct_ext(void) 39254db60cdSMike Gerdts { 39354db60cdSMike Gerdts struct spdk_bdev_part_base *base; 39454db60cdSMike Gerdts struct spdk_bdev_part part1 = {}; 39554db60cdSMike Gerdts struct spdk_bdev bdev_base = {}; 39654db60cdSMike Gerdts SPDK_BDEV_PART_TAILQ tailq = TAILQ_HEAD_INITIALIZER(tailq); 39754db60cdSMike Gerdts const char *uuid = "7ed764b7-a841-41b1-ba93-6548d9335a44"; 39854db60cdSMike Gerdts struct spdk_bdev_part_construct_opts opts; 39954db60cdSMike Gerdts int rc; 40054db60cdSMike Gerdts 40154db60cdSMike Gerdts bdev_base.name = "base"; 40254db60cdSMike Gerdts bdev_base.fn_table = &base_fn_table; 40354db60cdSMike Gerdts bdev_base.module = &bdev_ut_if; 40454db60cdSMike Gerdts rc = spdk_bdev_register(&bdev_base); 40554db60cdSMike Gerdts CU_ASSERT(rc == 0); 40654db60cdSMike Gerdts rc = spdk_bdev_part_base_construct_ext("base", NULL, &vbdev_ut_if, 40754db60cdSMike Gerdts &part_fn_table, &tailq, NULL, 40854db60cdSMike Gerdts NULL, 0, NULL, NULL, &base); 40954db60cdSMike Gerdts 41054db60cdSMike Gerdts CU_ASSERT(rc == 0); 41154db60cdSMike Gerdts SPDK_CU_ASSERT_FATAL(base != NULL); 41254db60cdSMike Gerdts 41354db60cdSMike Gerdts /* Verify opts.uuid is used as bdev UUID */ 41454db60cdSMike Gerdts spdk_bdev_part_construct_opts_init(&opts, sizeof(opts)); 41554db60cdSMike Gerdts spdk_uuid_parse(&opts.uuid, uuid); 41654db60cdSMike Gerdts rc = spdk_bdev_part_construct_ext(&part1, base, "test1", 0, 100, "test", &opts); 41754db60cdSMike Gerdts SPDK_CU_ASSERT_FATAL(rc == 0); 41854db60cdSMike Gerdts SPDK_CU_ASSERT_FATAL(base->ref == 1); 41954db60cdSMike Gerdts SPDK_CU_ASSERT_FATAL(base->claimed == true); 42054db60cdSMike Gerdts CU_ASSERT(spdk_bdev_get_by_name(uuid) != NULL); 42154db60cdSMike Gerdts CU_ASSERT(spdk_bdev_get_by_name("test1") != NULL); 42254db60cdSMike Gerdts 42354db60cdSMike Gerdts /* Clean up */ 42454db60cdSMike Gerdts spdk_bdev_part_base_hotremove(base, &tailq); 42554db60cdSMike Gerdts spdk_bdev_part_base_free(base); 42654db60cdSMike Gerdts _part_cleanup(&part1); 42754db60cdSMike Gerdts spdk_bdev_unregister(&bdev_base, NULL, NULL); 42854db60cdSMike Gerdts 42954db60cdSMike Gerdts poll_threads(); 43054db60cdSMike Gerdts } 43154db60cdSMike Gerdts 4323559bec4SDaniel Verkamp int 4333559bec4SDaniel Verkamp main(int argc, char **argv) 4343559bec4SDaniel Verkamp { 4353559bec4SDaniel Verkamp CU_pSuite suite = NULL; 4363559bec4SDaniel Verkamp unsigned int num_failures; 4373559bec4SDaniel Verkamp 43878b696bcSVitaliy Mysak CU_initialize_registry(); 4393559bec4SDaniel Verkamp 44080b22cf3SKonrad Sztyber suite = CU_add_suite("bdev_part", ut_part_setup, ut_part_teardown); 4413559bec4SDaniel Verkamp 442dcf0ca15SVitaliy Mysak CU_ADD_TEST(suite, part_test); 443b4f9bb44SKanKuo CU_ADD_TEST(suite, part_free_test); 4442b5f264eSKanKuo CU_ADD_TEST(suite, part_get_io_channel_test); 44554db60cdSMike Gerdts CU_ADD_TEST(suite, part_construct_ext); 4463559bec4SDaniel Verkamp 4472b5f264eSKanKuo allocate_cores(1); 448999d6df4SBen Walker allocate_threads(1); 449999d6df4SBen Walker set_thread(0); 450999d6df4SBen Walker 451ea941caeSKonrad Sztyber num_failures = spdk_ut_run_tests(argc, argv, NULL); 4523559bec4SDaniel Verkamp CU_cleanup_registry(); 453999d6df4SBen Walker 454999d6df4SBen Walker free_threads(); 4552b5f264eSKanKuo free_cores(); 456999d6df4SBen Walker 4573559bec4SDaniel Verkamp return num_failures; 4583559bec4SDaniel Verkamp } 459