1 /* SPDX-License-Identifier: GPL-2.0 AND MIT */ 2 /* 3 * Copyright © 2022 Intel Corporation 4 */ 5 6 #ifndef _XE_TEST_H_ 7 #define _XE_TEST_H_ 8 9 #include <linux/types.h> 10 11 #if IS_ENABLED(CONFIG_DRM_XE_KUNIT_TEST) 12 #include <kunit/test.h> 13 #include <kunit/test-bug.h> 14 15 /* 16 * Each test that provides a kunit private test structure, place a test id 17 * here and point the kunit->priv to an embedded struct xe_test_priv. 18 */ 19 enum xe_test_priv_id { 20 XE_TEST_LIVE_DMA_BUF, 21 XE_TEST_LIVE_MIGRATE, 22 }; 23 24 /** 25 * struct xe_test_priv - Base class for test private info 26 * @id: enum xe_test_priv_id to identify the subclass. 27 */ 28 struct xe_test_priv { 29 enum xe_test_priv_id id; 30 }; 31 32 #define XE_TEST_DECLARE(x) x 33 #define XE_TEST_ONLY(x) unlikely(x) 34 35 /** 36 * xe_cur_kunit_priv - Obtain the struct xe_test_priv pointed to by 37 * current->kunit->priv if it exists and is embedded in the expected subclass. 38 * @id: Id of the expected subclass. 39 * 40 * Return: NULL if the process is not a kunit test, and NULL if the 41 * current kunit->priv pointer is not pointing to an object of the expected 42 * subclass. A pointer to the embedded struct xe_test_priv otherwise. 43 */ 44 static inline struct xe_test_priv * xe_cur_kunit_priv(enum xe_test_priv_id id)45xe_cur_kunit_priv(enum xe_test_priv_id id) 46 { 47 struct xe_test_priv *priv; 48 49 if (!kunit_get_current_test()) 50 return NULL; 51 52 priv = kunit_get_current_test()->priv; 53 return priv->id == id ? priv : NULL; 54 } 55 56 #else /* if IS_ENABLED(CONFIG_DRM_XE_KUNIT_TEST) */ 57 58 #define XE_TEST_DECLARE(x) 59 #define XE_TEST_ONLY(x) 0 60 #define xe_cur_kunit_priv(_id) NULL 61 62 #endif 63 #endif 64