[RFC v2 1/3] drm/ttm: Introduce KUnit tests

Christian König christian.koenig at amd.com
Thu Jun 29 07:50:47 UTC 2023


Am 27.06.23 um 10:32 schrieb Karolina Stolarek:
> Add the initial version of unit tests for ttm_device struct, together
> with helper functions.
>
> Signed-off-by: Karolina Stolarek <karolina.stolarek at intel.com>
> ---
>   drivers/gpu/drm/Kconfig                       | 15 +++++
>   drivers/gpu/drm/ttm/Makefile                  |  1 +
>   drivers/gpu/drm/ttm/tests/.kunitconfig        |  4 ++
>   drivers/gpu/drm/ttm/tests/Makefile            |  5 ++
>   drivers/gpu/drm/ttm/tests/ttm_device_test.c   | 54 +++++++++++++++++
>   drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.c | 59 +++++++++++++++++++
>   drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.h | 29 +++++++++
>   7 files changed, 167 insertions(+)
>   create mode 100644 drivers/gpu/drm/ttm/tests/.kunitconfig
>   create mode 100644 drivers/gpu/drm/ttm/tests/Makefile
>   create mode 100644 drivers/gpu/drm/ttm/tests/ttm_device_test.c
>   create mode 100644 drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.c
>   create mode 100644 drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.h
>
> diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
> index afb3b2f5f425..53024e44a2d5 100644
> --- a/drivers/gpu/drm/Kconfig
> +++ b/drivers/gpu/drm/Kconfig
> @@ -194,6 +194,21 @@ config DRM_TTM
>   	  GPU memory types. Will be enabled automatically if a device driver
>   	  uses it.
>   
> +config DRM_TTM_KUNIT_TEST
> +        tristate "KUnit tests for TTM" if !KUNIT_ALL_TESTS
> +        default n
> +        depends on DRM && KUNIT
> +        select DRM_TTM
> +        select DRM_EXPORT_FOR_TESTS if m
> +        select DRM_KUNIT_TEST_HELPERS
> +        default KUNIT_ALL_TESTS
> +        help
> +          Enables unit tests for TTM, a GPU memory manager subsystem used
> +          to manage memory buffers. This option is mostly useful for kernel
> +          developers.
> +
> +          If in doubt, say "N".
> +
>   config DRM_BUDDY
>   	tristate
>   	depends on DRM
> diff --git a/drivers/gpu/drm/ttm/Makefile b/drivers/gpu/drm/ttm/Makefile
> index f906b22959cf..dad298127226 100644
> --- a/drivers/gpu/drm/ttm/Makefile
> +++ b/drivers/gpu/drm/ttm/Makefile
> @@ -8,3 +8,4 @@ ttm-y := ttm_tt.o ttm_bo.o ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
>   ttm-$(CONFIG_AGP) += ttm_agp_backend.o
>   
>   obj-$(CONFIG_DRM_TTM) += ttm.o
> +obj-$(CONFIG_DRM_TTM_KUNIT_TEST) += tests/
> diff --git a/drivers/gpu/drm/ttm/tests/.kunitconfig b/drivers/gpu/drm/ttm/tests/.kunitconfig
> new file mode 100644
> index 000000000000..75fdce0cd98e
> --- /dev/null
> +++ b/drivers/gpu/drm/ttm/tests/.kunitconfig
> @@ -0,0 +1,4 @@
> +CONFIG_KUNIT=y
> +CONFIG_DRM=y
> +CONFIG_DRM_KUNIT_TEST_HELPERS=y
> +CONFIG_DRM_TTM_KUNIT_TEST=y
> diff --git a/drivers/gpu/drm/ttm/tests/Makefile b/drivers/gpu/drm/ttm/tests/Makefile
> new file mode 100644
> index 000000000000..7917805f37af
> --- /dev/null
> +++ b/drivers/gpu/drm/ttm/tests/Makefile
> @@ -0,0 +1,5 @@
> +# SPDX-License-Identifier: GPL-2.0 AND MIT
> +
> +obj-$(CONFIG_DRM_TTM_KUNIT_TEST) += \
> +        ttm_device_test.o \
> +        ttm_kunit_helpers.o
> diff --git a/drivers/gpu/drm/ttm/tests/ttm_device_test.c b/drivers/gpu/drm/ttm/tests/ttm_device_test.c
> new file mode 100644
> index 000000000000..08d7314b1e35
> --- /dev/null
> +++ b/drivers/gpu/drm/ttm/tests/ttm_device_test.c
> @@ -0,0 +1,54 @@
> +// SPDX-License-Identifier: GPL-2.0 AND MIT
> +/*
> + * Copyright © 2023 Intel Corporation
> + */
> +#include <drm/ttm/ttm_resource.h>
> +#include <drm/ttm/ttm_device.h>
> +#include <drm/ttm/ttm_placement.h>
> +
> +#include "ttm_kunit_helpers.h"
> +
> +static void ttm_device_init_basic(struct kunit *test)
> +{
> +	struct ttm_test_devices_priv *priv = test->priv;
> +	struct ttm_device *ttm_dev;
> +	struct ttm_resource_manager *ttm_sys_man;
> +	int err;
> +
> +	ttm_dev = kunit_kzalloc(test, sizeof(*ttm_dev), GFP_KERNEL);
> +	KUNIT_ASSERT_NOT_NULL(test, ttm_dev);
> +
> +	err = ttm_kunit_helper_alloc_device(test, ttm_dev, false, false);
> +	KUNIT_ASSERT_EQ(test, err, 0);
> +
> +	KUNIT_EXPECT_PTR_EQ(test, ttm_dev->funcs, &ttm_dev_funcs);
> +	KUNIT_ASSERT_NOT_NULL(test, ttm_dev->wq);
> +	KUNIT_ASSERT_NOT_NULL(test, ttm_dev->man_drv[TTM_PL_SYSTEM]);
> +
> +	ttm_sys_man = &ttm_dev->sysman;
> +	KUNIT_ASSERT_NOT_NULL(test, ttm_sys_man);
> +	KUNIT_EXPECT_TRUE(test, ttm_sys_man->use_tt);
> +	KUNIT_EXPECT_TRUE(test, ttm_sys_man->use_type);
> +	KUNIT_ASSERT_NOT_NULL(test, ttm_sys_man->func);
> +
> +	KUNIT_EXPECT_PTR_EQ(test, ttm_dev->dev_mapping,
> +			    priv->drm->anon_inode->i_mapping);
> +
> +	ttm_device_fini(ttm_dev);
> +}
> +
> +static struct kunit_case ttm_device_test_cases[] = {
> +	KUNIT_CASE(ttm_device_init_basic),
> +	{}
> +};
> +
> +static struct kunit_suite ttm_device_test_suite = {
> +	.name = "ttm_device",
> +	.init = ttm_test_devices_init,
> +	.exit = ttm_test_devices_fini,
> +	.test_cases = ttm_device_test_cases,
> +};
> +
> +kunit_test_suites(&ttm_device_test_suite);
> +
> +MODULE_LICENSE("GPL");
> diff --git a/drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.c b/drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.c
> new file mode 100644
> index 000000000000..d03db0405484
> --- /dev/null
> +++ b/drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.c
> @@ -0,0 +1,59 @@
> +// SPDX-License-Identifier: GPL-2.0 AND MIT
> +/*
> + * Copyright © 2023 Intel Corporation
> + */
> +#include "ttm_kunit_helpers.h"
> +
> +struct ttm_device_funcs ttm_dev_funcs = {
> +};
> +EXPORT_SYMBOL_GPL(ttm_dev_funcs);
> +
> +int ttm_kunit_helper_alloc_device(struct kunit *test,

Since this function is only initializing the ttm device I think we 
should name it ttm_kunit_helper_init_device().

On the other hand I don't see a good reason why it can't also allocate 
the device.

Apart from that looks like a good start,
Christian.

> +				  struct ttm_device *ttm,
> +				  bool use_dma_alloc,
> +				  bool use_dma32)
> +{
> +	struct ttm_test_devices_priv *priv = test->priv;
> +	struct drm_device *drm = priv->drm;
> +	int err;
> +
> +	err = ttm_device_init(ttm, &ttm_dev_funcs, drm->dev,
> +			      drm->anon_inode->i_mapping,
> +			      drm->vma_offset_manager,
> +			      use_dma_alloc, use_dma32);
> +
> +	return err;
> +}
> +EXPORT_SYMBOL_GPL(ttm_kunit_helper_alloc_device);
> +
> +int ttm_test_devices_init(struct kunit *test)
> +{
> +	struct ttm_test_devices_priv *priv;
> +
> +	priv = kunit_kzalloc(test, sizeof(*priv), GFP_KERNEL);
> +	KUNIT_ASSERT_NOT_NULL(test, priv);
> +
> +	test->priv = priv;
> +
> +	priv->dev = drm_kunit_helper_alloc_device(test);
> +	KUNIT_ASSERT_NOT_ERR_OR_NULL(test, priv->dev);
> +
> +	priv->drm = __drm_kunit_helper_alloc_drm_device(test, priv->dev,
> +							sizeof(*priv->drm), 0,
> +							DRIVER_GEM);
> +	KUNIT_ASSERT_NOT_ERR_OR_NULL(test, priv->drm);
> +
> +	return 0;
> +}
> +EXPORT_SYMBOL_GPL(ttm_test_devices_init);
> +
> +void ttm_test_devices_fini(struct kunit *test)
> +{
> +	struct ttm_test_devices_priv *priv = test->priv;
> +
> +	drm_kunit_helper_free_device(test, priv->dev);
> +	drm_dev_put(priv->drm);
> +}
> +EXPORT_SYMBOL_GPL(ttm_test_devices_fini);
> +
> +MODULE_LICENSE("GPL");
> diff --git a/drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.h b/drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.h
> new file mode 100644
> index 000000000000..69fb03b9c4d2
> --- /dev/null
> +++ b/drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.h
> @@ -0,0 +1,29 @@
> +/* SPDX-License-Identifier: GPL-2.0 AND MIT */
> +/*
> + * Copyright © 2023 Intel Corporation
> + */
> +#ifndef TTM_KUNIT_HELPERS_H
> +#define TTM_KUNIT_HELPERS_H
> +
> +#include <drm/drm_drv.h>
> +#include <drm/ttm/ttm_device.h>
> +
> +#include <drm/drm_kunit_helpers.h>
> +#include <kunit/test.h>
> +
> +extern struct ttm_device_funcs ttm_dev_funcs;
> +
> +struct ttm_test_devices_priv {
> +	struct drm_device *drm;
> +	struct device *dev;
> +};
> +
> +int ttm_kunit_helper_alloc_device(struct kunit *test,
> +				  struct ttm_device *ttm,
> +				  bool use_dma_alloc,
> +				  bool use_dma32);
> +
> +int ttm_test_devices_init(struct kunit *test);
> +void ttm_test_devices_fini(struct kunit *test);
> +
> +#endif // TTM_KUNIT_HELPERS_H



More information about the dri-devel mailing list