mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 85f3b79fb5
			
		
	
	
		85f3b79fb5
		
	
	
	
	
		
			
			Creating one module for each compilation unit to be tested seems excessive as the number of tests increase. Group them all in a single kunit test module called xe_test.ko. The tests requiring the physical device, aka "live" tests, are still kept in separate modules since they are normally triggered via igt, and not via kunit.py. After igt is converted, those can be merged in a single module as well. Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com> Acked-by: Michal Wajdeczko <michal.wajdeczko@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20231122203147.988021-2-lucas.demarchi@intel.com
		
			
				
	
	
		
			67 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| /*
 | |
|  * Copyright © 2023 Intel Corporation
 | |
|  */
 | |
| 
 | |
| #include <drm/drm_drv.h>
 | |
| #include <drm/drm_kunit_helpers.h>
 | |
| 
 | |
| #include <kunit/test.h>
 | |
| 
 | |
| #include "tests/xe_test.h"
 | |
| 
 | |
| #include "xe_device.h"
 | |
| #include "xe_pci_test.h"
 | |
| #include "xe_pci_types.h"
 | |
| 
 | |
| static void check_graphics_ip(const struct xe_graphics_desc *graphics)
 | |
| {
 | |
| 	struct kunit *test = xe_cur_kunit();
 | |
| 	u64 mask = graphics->hw_engine_mask;
 | |
| 
 | |
| 	/* RCS, CCS, and BCS engines are allowed on the graphics IP */
 | |
| 	mask &= ~(XE_HW_ENGINE_RCS_MASK |
 | |
| 		  XE_HW_ENGINE_CCS_MASK |
 | |
| 		  XE_HW_ENGINE_BCS_MASK);
 | |
| 
 | |
| 	/* Any remaining engines are an error */
 | |
| 	KUNIT_ASSERT_EQ(test, mask, 0);
 | |
| }
 | |
| 
 | |
| static void check_media_ip(const struct xe_media_desc *media)
 | |
| {
 | |
| 	struct kunit *test = xe_cur_kunit();
 | |
| 	u64 mask = media->hw_engine_mask;
 | |
| 
 | |
| 	/* VCS, VECS and GSCCS engines are allowed on the media IP */
 | |
| 	mask &= ~(XE_HW_ENGINE_VCS_MASK |
 | |
| 		  XE_HW_ENGINE_VECS_MASK |
 | |
| 		  XE_HW_ENGINE_GSCCS_MASK);
 | |
| 
 | |
| 	/* Any remaining engines are an error */
 | |
| 	KUNIT_ASSERT_EQ(test, mask, 0);
 | |
| }
 | |
| 
 | |
| static void xe_gmdid_graphics_ip(struct kunit *test)
 | |
| {
 | |
| 	xe_call_for_each_graphics_ip(check_graphics_ip);
 | |
| }
 | |
| 
 | |
| static void xe_gmdid_media_ip(struct kunit *test)
 | |
| {
 | |
| 	xe_call_for_each_media_ip(check_media_ip);
 | |
| }
 | |
| 
 | |
| static struct kunit_case xe_pci_tests[] = {
 | |
| 	KUNIT_CASE(xe_gmdid_graphics_ip),
 | |
| 	KUNIT_CASE(xe_gmdid_media_ip),
 | |
| 	{}
 | |
| };
 | |
| 
 | |
| static struct kunit_suite xe_pci_test_suite = {
 | |
| 	.name = "xe_pci",
 | |
| 	.test_cases = xe_pci_tests,
 | |
| };
 | |
| 
 | |
| kunit_test_suite(xe_pci_test_suite);
 |