[PATCH v6 0/8] Improve test coverage of TTM
Christian König
christian.koenig at amd.com
Wed Nov 8 15:01:28 UTC 2023
Am 08.11.23 um 14:56 schrieb Karolina Stolarek:
> Add tests for building blocks of the TTM subsystem, such as ttm_resource,
> ttm_resource_manager, ttm_tt and ttm_buffer_object. This series covers
> basic functions such as initialization, allocation and clean-up of each
> struct. Testing of ttm_buffer_object also includes locking and unlocking
> the object for validation, with special scenarios such as an interrupted
> wait or deadlock.
>
> Some of the test cases check the bulk move mechanism and how it interacts
> with pinned buffers. This is to be seen if we want to add dedicated testing
> for bulk move or not. The resource allocation subtests use ttm_sys_manager
> for now. Resources that don't use system memory will be indirectly tested
> via tests for ttm_bo_validate()/ttm_bo_init_validate(), using a mock
> resource manager.
>
> Use kunit_tool script to manually run all the tests:
>
> $ ./tools/testing/kunit/kunit.py run --kunitconfig=drivers/gpu/drm/ttm/tests
>
> To build a kernel with TTM KUnit tests, first enable CONFIG_KUNIT, and
> then CONFIG_DRM_TTM_KUNIT_TEST.
Well, you have a tendency to keep us busy :)
Please keep Amar looped in those patches. I will try to review them when
I have time, but he can give you at least some tested-by tags on AMD hw.
Thanks,
Christian.
>
> Many thanks,
> Karolina
>
> v6:
> - Include tests for ttm_bo_init_reserved() and ttm_bo_validate(), with
> a mock resource manager (patches 6-8; no eviction testing)
> - Add ttm_test_devices_all_init() helper to also init ttm_device instance
> - Remove fpfn and lpfn from ttm_place_kunit_init() helper -- these fields
> are neither used nor tested
>
> v5:
> - Actually use the page_flags parameter in ttm_tt_simple_create()
>
> v4:
> - First unreserve the object before calling ww_acquire_fini() in
> ttm_bo_reserve_double_resv subtest
> - Silence lockdep in ttm_bo_reserve_deadlock subtest (open to suggestions
> how to fix it in a different way)
> - Use a genuine GEM object in ttm_buffer_object instead of an empty one
>
> v3:
> - Instead of modifying the main TTM Makefile, use
> EXPORT_SYMBOL_FOR_TESTS_ONLY() macro for symbols that are tested but
> not widely exported. Thanks to this change, TTM tests can be built
> as modules, even when non-exported functions are used
> - Change the description of a patch that fixes ttm_pool_pre_populated()
>
> v2:
> - Remove Makefile for KUnit tests and move the definitions to the
> TTM's one
> - Switch on CONFIG_DRM_TTM_KUNIT_TEST=m so the tests and TTM module
> are built as one. This allows building the tests as a module, even
> if it uses functions that are not exported
> - Fix ttm_pool_pre_populated(); a wrong flag was passed to
> ttm_tt_kunit_init() function
>
> Karolina Stolarek (8):
> drm/ttm/tests: Add tests for ttm_resource and ttm_sys_man
> drm/ttm/tests: Add tests for ttm_tt
> drm/ttm/tests: Add tests for ttm_bo functions
> drm/ttm/tests: Fix argument in ttm_tt_kunit_init()
> drm/ttm/tests: Use an init function from the helpers lib
> drm/ttm/tests: Test simple BO creation and validation
> drm/ttm/tests: Add tests with mock resource managers
> drm/ttm/tests: Add test cases dependent on fence signaling
>
> drivers/gpu/drm/Kconfig | 1 +
> drivers/gpu/drm/ttm/tests/.kunitconfig | 1 +
> drivers/gpu/drm/ttm/tests/Makefile | 5 +
> drivers/gpu/drm/ttm/tests/ttm_bo_test.c | 619 ++++++++++++++
> .../gpu/drm/ttm/tests/ttm_bo_validate_test.c | 792 ++++++++++++++++++
> drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.c | 110 ++-
> drivers/gpu/drm/ttm/tests/ttm_kunit_helpers.h | 8 +
> drivers/gpu/drm/ttm/tests/ttm_mock_manager.c | 194 +++++
> drivers/gpu/drm/ttm/tests/ttm_mock_manager.h | 30 +
> drivers/gpu/drm/ttm/tests/ttm_pool_test.c | 3 +-
> drivers/gpu/drm/ttm/tests/ttm_resource_test.c | 335 ++++++++
> drivers/gpu/drm/ttm/tests/ttm_tt_test.c | 282 +++++++
> drivers/gpu/drm/ttm/ttm_resource.c | 3 +
> drivers/gpu/drm/ttm/ttm_tt.c | 3 +
> 14 files changed, 2383 insertions(+), 3 deletions(-)
> create mode 100644 drivers/gpu/drm/ttm/tests/ttm_bo_test.c
> create mode 100644 drivers/gpu/drm/ttm/tests/ttm_bo_validate_test.c
> create mode 100644 drivers/gpu/drm/ttm/tests/ttm_mock_manager.c
> create mode 100644 drivers/gpu/drm/ttm/tests/ttm_mock_manager.h
> create mode 100644 drivers/gpu/drm/ttm/tests/ttm_resource_test.c
> create mode 100644 drivers/gpu/drm/ttm/tests/ttm_tt_test.c
>
More information about the dri-devel
mailing list