xref: /spdk/test/unit/lib/bdev/part.c/part_ut.c (revision ff173863b114ffb0d2b86e2825badcc504fc5fa1)
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