1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright 2024 Google LLC.
5 #include <kunit/test.h>
6 #include <linux/io-pgtable.h>
8 #include "arm-smmu-v3.h"
10 struct arm_smmu_test_writer
{
11 struct arm_smmu_entry_writer writer
;
13 const __le64
*init_entry
;
14 const __le64
*target_entry
;
17 bool invalid_entry_written
;
18 unsigned int num_syncs
;
21 #define NUM_ENTRY_QWORDS 8
22 #define NUM_EXPECTED_SYNCS(x) x
24 static struct arm_smmu_ste bypass_ste
;
25 static struct arm_smmu_ste abort_ste
;
26 static struct arm_smmu_device smmu
= {
27 .features
= ARM_SMMU_FEAT_STALLS
| ARM_SMMU_FEAT_ATTR_TYPES_OVR
29 static struct mm_struct sva_mm
= {
30 .pgd
= (void *)0xdaedbeefdeadbeefULL
,
33 enum arm_smmu_test_master_feat
{
34 ARM_SMMU_MASTER_TEST_ATS
= BIT(0),
35 ARM_SMMU_MASTER_TEST_STALL
= BIT(1),
38 static bool arm_smmu_entry_differs_in_used_bits(const __le64
*entry
,
39 const __le64
*used_bits
,
46 for (i
= 0; i
< length
; i
++) {
47 if ((entry
[i
] & used_bits
[i
]) != target
[i
])
54 arm_smmu_test_writer_record_syncs(struct arm_smmu_entry_writer
*writer
)
56 struct arm_smmu_test_writer
*test_writer
=
57 container_of(writer
, struct arm_smmu_test_writer
, writer
);
58 __le64
*entry_used_bits
;
60 entry_used_bits
= kunit_kzalloc(
61 test_writer
->test
, sizeof(*entry_used_bits
) * NUM_ENTRY_QWORDS
,
63 KUNIT_ASSERT_NOT_NULL(test_writer
->test
, entry_used_bits
);
65 pr_debug("STE value is now set to: ");
66 print_hex_dump_debug(" ", DUMP_PREFIX_NONE
, 16, 8,
68 NUM_ENTRY_QWORDS
* sizeof(*test_writer
->entry
),
71 test_writer
->num_syncs
+= 1;
72 if (!test_writer
->entry
[0]) {
73 test_writer
->invalid_entry_written
= true;
76 * At any stage in a hitless transition, the entry must be
77 * equivalent to either the initial entry or the target entry
78 * when only considering the bits used by the current
81 writer
->ops
->get_used(test_writer
->entry
, entry_used_bits
);
84 arm_smmu_entry_differs_in_used_bits(
85 test_writer
->entry
, entry_used_bits
,
86 test_writer
->init_entry
, NUM_ENTRY_QWORDS
) &&
87 arm_smmu_entry_differs_in_used_bits(
88 test_writer
->entry
, entry_used_bits
,
89 test_writer
->target_entry
,
95 arm_smmu_v3_test_debug_print_used_bits(struct arm_smmu_entry_writer
*writer
,
98 __le64 used_bits
[NUM_ENTRY_QWORDS
] = {};
100 arm_smmu_get_ste_used(ste
, used_bits
);
101 pr_debug("STE used bits: ");
102 print_hex_dump_debug(" ", DUMP_PREFIX_NONE
, 16, 8, used_bits
,
103 sizeof(used_bits
), false);
106 static const struct arm_smmu_entry_writer_ops test_ste_ops
= {
107 .sync
= arm_smmu_test_writer_record_syncs
,
108 .get_used
= arm_smmu_get_ste_used
,
111 static const struct arm_smmu_entry_writer_ops test_cd_ops
= {
112 .sync
= arm_smmu_test_writer_record_syncs
,
113 .get_used
= arm_smmu_get_cd_used
,
116 static void arm_smmu_v3_test_ste_expect_transition(
117 struct kunit
*test
, const struct arm_smmu_ste
*cur
,
118 const struct arm_smmu_ste
*target
, unsigned int num_syncs_expected
,
121 struct arm_smmu_ste cur_copy
= *cur
;
122 struct arm_smmu_test_writer test_writer
= {
124 .ops
= &test_ste_ops
,
127 .init_entry
= cur
->data
,
128 .target_entry
= target
->data
,
129 .entry
= cur_copy
.data
,
131 .invalid_entry_written
= false,
135 pr_debug("STE initial value: ");
136 print_hex_dump_debug(" ", DUMP_PREFIX_NONE
, 16, 8, cur_copy
.data
,
137 sizeof(cur_copy
), false);
138 arm_smmu_v3_test_debug_print_used_bits(&test_writer
.writer
, cur
->data
);
139 pr_debug("STE target value: ");
140 print_hex_dump_debug(" ", DUMP_PREFIX_NONE
, 16, 8, target
->data
,
141 sizeof(cur_copy
), false);
142 arm_smmu_v3_test_debug_print_used_bits(&test_writer
.writer
,
145 arm_smmu_write_entry(&test_writer
.writer
, cur_copy
.data
, target
->data
);
147 KUNIT_EXPECT_EQ(test
, test_writer
.invalid_entry_written
, !hitless
);
148 KUNIT_EXPECT_EQ(test
, test_writer
.num_syncs
, num_syncs_expected
);
149 KUNIT_EXPECT_MEMEQ(test
, target
->data
, cur_copy
.data
, sizeof(cur_copy
));
152 static void arm_smmu_v3_test_ste_expect_non_hitless_transition(
153 struct kunit
*test
, const struct arm_smmu_ste
*cur
,
154 const struct arm_smmu_ste
*target
, unsigned int num_syncs_expected
)
156 arm_smmu_v3_test_ste_expect_transition(test
, cur
, target
,
157 num_syncs_expected
, false);
160 static void arm_smmu_v3_test_ste_expect_hitless_transition(
161 struct kunit
*test
, const struct arm_smmu_ste
*cur
,
162 const struct arm_smmu_ste
*target
, unsigned int num_syncs_expected
)
164 arm_smmu_v3_test_ste_expect_transition(test
, cur
, target
,
165 num_syncs_expected
, true);
168 static const dma_addr_t fake_cdtab_dma_addr
= 0xF0F0F0F0F0F0;
170 static void arm_smmu_test_make_cdtable_ste(struct arm_smmu_ste
*ste
,
172 const dma_addr_t dma_addr
,
173 enum arm_smmu_test_master_feat feat
)
175 bool ats_enabled
= feat
& ARM_SMMU_MASTER_TEST_ATS
;
176 bool stall_enabled
= feat
& ARM_SMMU_MASTER_TEST_STALL
;
178 struct arm_smmu_master master
= {
179 .ats_enabled
= ats_enabled
,
180 .cd_table
.cdtab_dma
= dma_addr
,
181 .cd_table
.s1cdmax
= 0xFF,
182 .cd_table
.s1fmt
= STRTAB_STE_0_S1FMT_64K_L2
,
184 .stall_enabled
= stall_enabled
,
187 arm_smmu_make_cdtable_ste(ste
, &master
, ats_enabled
, s1dss
);
190 static void arm_smmu_v3_write_ste_test_bypass_to_abort(struct kunit
*test
)
193 * Bypass STEs has used bits in the first two Qwords, while abort STEs
194 * only have used bits in the first QWord. Transitioning from bypass to
195 * abort requires two syncs: the first to set the first qword and make
196 * the STE into an abort, the second to clean up the second qword.
198 arm_smmu_v3_test_ste_expect_hitless_transition(
199 test
, &bypass_ste
, &abort_ste
, NUM_EXPECTED_SYNCS(2));
202 static void arm_smmu_v3_write_ste_test_abort_to_bypass(struct kunit
*test
)
205 * Transitioning from abort to bypass also requires two syncs: the first
206 * to set the second qword data required by the bypass STE, and the
207 * second to set the first qword and switch to bypass.
209 arm_smmu_v3_test_ste_expect_hitless_transition(
210 test
, &abort_ste
, &bypass_ste
, NUM_EXPECTED_SYNCS(2));
213 static void arm_smmu_v3_write_ste_test_cdtable_to_abort(struct kunit
*test
)
215 struct arm_smmu_ste ste
;
217 arm_smmu_test_make_cdtable_ste(&ste
, STRTAB_STE_1_S1DSS_SSID0
,
218 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
219 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &ste
, &abort_ste
,
220 NUM_EXPECTED_SYNCS(2));
223 static void arm_smmu_v3_write_ste_test_abort_to_cdtable(struct kunit
*test
)
225 struct arm_smmu_ste ste
;
227 arm_smmu_test_make_cdtable_ste(&ste
, STRTAB_STE_1_S1DSS_SSID0
,
228 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
229 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &abort_ste
, &ste
,
230 NUM_EXPECTED_SYNCS(2));
233 static void arm_smmu_v3_write_ste_test_cdtable_to_bypass(struct kunit
*test
)
235 struct arm_smmu_ste ste
;
237 arm_smmu_test_make_cdtable_ste(&ste
, STRTAB_STE_1_S1DSS_SSID0
,
238 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
239 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &ste
, &bypass_ste
,
240 NUM_EXPECTED_SYNCS(3));
243 static void arm_smmu_v3_write_ste_test_bypass_to_cdtable(struct kunit
*test
)
245 struct arm_smmu_ste ste
;
247 arm_smmu_test_make_cdtable_ste(&ste
, STRTAB_STE_1_S1DSS_SSID0
,
248 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
249 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &bypass_ste
, &ste
,
250 NUM_EXPECTED_SYNCS(3));
253 static void arm_smmu_v3_write_ste_test_cdtable_s1dss_change(struct kunit
*test
)
255 struct arm_smmu_ste ste
;
256 struct arm_smmu_ste s1dss_bypass
;
258 arm_smmu_test_make_cdtable_ste(&ste
, STRTAB_STE_1_S1DSS_SSID0
,
259 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
260 arm_smmu_test_make_cdtable_ste(&s1dss_bypass
, STRTAB_STE_1_S1DSS_BYPASS
,
261 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
264 * Flipping s1dss on a CD table STE only involves changes to the second
265 * qword of an STE and can be done in a single write.
267 arm_smmu_v3_test_ste_expect_hitless_transition(
268 test
, &ste
, &s1dss_bypass
, NUM_EXPECTED_SYNCS(1));
269 arm_smmu_v3_test_ste_expect_hitless_transition(
270 test
, &s1dss_bypass
, &ste
, NUM_EXPECTED_SYNCS(1));
274 arm_smmu_v3_write_ste_test_s1dssbypass_to_stebypass(struct kunit
*test
)
276 struct arm_smmu_ste s1dss_bypass
;
278 arm_smmu_test_make_cdtable_ste(&s1dss_bypass
, STRTAB_STE_1_S1DSS_BYPASS
,
279 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
280 arm_smmu_v3_test_ste_expect_hitless_transition(
281 test
, &s1dss_bypass
, &bypass_ste
, NUM_EXPECTED_SYNCS(2));
285 arm_smmu_v3_write_ste_test_stebypass_to_s1dssbypass(struct kunit
*test
)
287 struct arm_smmu_ste s1dss_bypass
;
289 arm_smmu_test_make_cdtable_ste(&s1dss_bypass
, STRTAB_STE_1_S1DSS_BYPASS
,
290 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
291 arm_smmu_v3_test_ste_expect_hitless_transition(
292 test
, &bypass_ste
, &s1dss_bypass
, NUM_EXPECTED_SYNCS(2));
295 static void arm_smmu_test_make_s2_ste(struct arm_smmu_ste
*ste
,
296 enum arm_smmu_test_master_feat feat
)
298 bool ats_enabled
= feat
& ARM_SMMU_MASTER_TEST_ATS
;
299 bool stall_enabled
= feat
& ARM_SMMU_MASTER_TEST_STALL
;
300 struct arm_smmu_master master
= {
301 .ats_enabled
= ats_enabled
,
303 .stall_enabled
= stall_enabled
,
305 struct io_pgtable io_pgtable
= {};
306 struct arm_smmu_domain smmu_domain
= {
307 .pgtbl_ops
= &io_pgtable
.ops
,
310 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vttbr
= 0xdaedbeefdeadbeefULL
;
311 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vtcr
.ps
= 1;
312 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vtcr
.tg
= 2;
313 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vtcr
.sh
= 3;
314 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vtcr
.orgn
= 1;
315 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vtcr
.irgn
= 2;
316 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vtcr
.sl
= 3;
317 io_pgtable
.cfg
.arm_lpae_s2_cfg
.vtcr
.tsz
= 4;
319 arm_smmu_make_s2_domain_ste(ste
, &master
, &smmu_domain
, ats_enabled
);
322 static void arm_smmu_v3_write_ste_test_s2_to_abort(struct kunit
*test
)
324 struct arm_smmu_ste ste
;
326 arm_smmu_test_make_s2_ste(&ste
, ARM_SMMU_MASTER_TEST_ATS
);
327 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &ste
, &abort_ste
,
328 NUM_EXPECTED_SYNCS(2));
331 static void arm_smmu_v3_write_ste_test_abort_to_s2(struct kunit
*test
)
333 struct arm_smmu_ste ste
;
335 arm_smmu_test_make_s2_ste(&ste
, ARM_SMMU_MASTER_TEST_ATS
);
336 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &abort_ste
, &ste
,
337 NUM_EXPECTED_SYNCS(2));
340 static void arm_smmu_v3_write_ste_test_s2_to_bypass(struct kunit
*test
)
342 struct arm_smmu_ste ste
;
344 arm_smmu_test_make_s2_ste(&ste
, ARM_SMMU_MASTER_TEST_ATS
);
345 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &ste
, &bypass_ste
,
346 NUM_EXPECTED_SYNCS(2));
349 static void arm_smmu_v3_write_ste_test_bypass_to_s2(struct kunit
*test
)
351 struct arm_smmu_ste ste
;
353 arm_smmu_test_make_s2_ste(&ste
, ARM_SMMU_MASTER_TEST_ATS
);
354 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &bypass_ste
, &ste
,
355 NUM_EXPECTED_SYNCS(2));
358 static void arm_smmu_v3_write_ste_test_s1_to_s2(struct kunit
*test
)
360 struct arm_smmu_ste s1_ste
;
361 struct arm_smmu_ste s2_ste
;
363 arm_smmu_test_make_cdtable_ste(&s1_ste
, STRTAB_STE_1_S1DSS_SSID0
,
364 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
365 arm_smmu_test_make_s2_ste(&s2_ste
, ARM_SMMU_MASTER_TEST_ATS
);
366 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &s1_ste
, &s2_ste
,
367 NUM_EXPECTED_SYNCS(3));
370 static void arm_smmu_v3_write_ste_test_s2_to_s1(struct kunit
*test
)
372 struct arm_smmu_ste s1_ste
;
373 struct arm_smmu_ste s2_ste
;
375 arm_smmu_test_make_cdtable_ste(&s1_ste
, STRTAB_STE_1_S1DSS_SSID0
,
376 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
377 arm_smmu_test_make_s2_ste(&s2_ste
, ARM_SMMU_MASTER_TEST_ATS
);
378 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &s2_ste
, &s1_ste
,
379 NUM_EXPECTED_SYNCS(3));
382 static void arm_smmu_v3_write_ste_test_non_hitless(struct kunit
*test
)
384 struct arm_smmu_ste ste
;
385 struct arm_smmu_ste ste_2
;
388 * Although no flow resembles this in practice, one way to force an STE
389 * update to be non-hitless is to change its CD table pointer as well as
390 * s1 dss field in the same update.
392 arm_smmu_test_make_cdtable_ste(&ste
, STRTAB_STE_1_S1DSS_SSID0
,
393 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_ATS
);
394 arm_smmu_test_make_cdtable_ste(&ste_2
, STRTAB_STE_1_S1DSS_BYPASS
,
395 0x4B4B4b4B4B, ARM_SMMU_MASTER_TEST_ATS
);
396 arm_smmu_v3_test_ste_expect_non_hitless_transition(
397 test
, &ste
, &ste_2
, NUM_EXPECTED_SYNCS(3));
400 static void arm_smmu_v3_test_cd_expect_transition(
401 struct kunit
*test
, const struct arm_smmu_cd
*cur
,
402 const struct arm_smmu_cd
*target
, unsigned int num_syncs_expected
,
405 struct arm_smmu_cd cur_copy
= *cur
;
406 struct arm_smmu_test_writer test_writer
= {
411 .init_entry
= cur
->data
,
412 .target_entry
= target
->data
,
413 .entry
= cur_copy
.data
,
415 .invalid_entry_written
= false,
419 pr_debug("CD initial value: ");
420 print_hex_dump_debug(" ", DUMP_PREFIX_NONE
, 16, 8, cur_copy
.data
,
421 sizeof(cur_copy
), false);
422 arm_smmu_v3_test_debug_print_used_bits(&test_writer
.writer
, cur
->data
);
423 pr_debug("CD target value: ");
424 print_hex_dump_debug(" ", DUMP_PREFIX_NONE
, 16, 8, target
->data
,
425 sizeof(cur_copy
), false);
426 arm_smmu_v3_test_debug_print_used_bits(&test_writer
.writer
,
429 arm_smmu_write_entry(&test_writer
.writer
, cur_copy
.data
, target
->data
);
431 KUNIT_EXPECT_EQ(test
, test_writer
.invalid_entry_written
, !hitless
);
432 KUNIT_EXPECT_EQ(test
, test_writer
.num_syncs
, num_syncs_expected
);
433 KUNIT_EXPECT_MEMEQ(test
, target
->data
, cur_copy
.data
, sizeof(cur_copy
));
436 static void arm_smmu_v3_test_cd_expect_non_hitless_transition(
437 struct kunit
*test
, const struct arm_smmu_cd
*cur
,
438 const struct arm_smmu_cd
*target
, unsigned int num_syncs_expected
)
440 arm_smmu_v3_test_cd_expect_transition(test
, cur
, target
,
441 num_syncs_expected
, false);
444 static void arm_smmu_v3_test_cd_expect_hitless_transition(
445 struct kunit
*test
, const struct arm_smmu_cd
*cur
,
446 const struct arm_smmu_cd
*target
, unsigned int num_syncs_expected
)
448 arm_smmu_v3_test_cd_expect_transition(test
, cur
, target
,
449 num_syncs_expected
, true);
452 static void arm_smmu_test_make_s1_cd(struct arm_smmu_cd
*cd
, unsigned int asid
)
454 struct arm_smmu_master master
= {
457 struct io_pgtable io_pgtable
= {};
458 struct arm_smmu_domain smmu_domain
= {
459 .pgtbl_ops
= &io_pgtable
.ops
,
465 io_pgtable
.cfg
.arm_lpae_s1_cfg
.ttbr
= 0xdaedbeefdeadbeefULL
;
466 io_pgtable
.cfg
.arm_lpae_s1_cfg
.tcr
.ips
= 1;
467 io_pgtable
.cfg
.arm_lpae_s1_cfg
.tcr
.tg
= 2;
468 io_pgtable
.cfg
.arm_lpae_s1_cfg
.tcr
.sh
= 3;
469 io_pgtable
.cfg
.arm_lpae_s1_cfg
.tcr
.orgn
= 1;
470 io_pgtable
.cfg
.arm_lpae_s1_cfg
.tcr
.irgn
= 2;
471 io_pgtable
.cfg
.arm_lpae_s1_cfg
.tcr
.tsz
= 4;
472 io_pgtable
.cfg
.arm_lpae_s1_cfg
.mair
= 0xabcdef012345678ULL
;
474 arm_smmu_make_s1_cd(cd
, &master
, &smmu_domain
);
477 static void arm_smmu_v3_write_cd_test_s1_clear(struct kunit
*test
)
479 struct arm_smmu_cd cd
= {};
480 struct arm_smmu_cd cd_2
;
482 arm_smmu_test_make_s1_cd(&cd_2
, 1997);
483 arm_smmu_v3_test_cd_expect_non_hitless_transition(
484 test
, &cd
, &cd_2
, NUM_EXPECTED_SYNCS(2));
485 arm_smmu_v3_test_cd_expect_non_hitless_transition(
486 test
, &cd_2
, &cd
, NUM_EXPECTED_SYNCS(2));
489 static void arm_smmu_v3_write_cd_test_s1_change_asid(struct kunit
*test
)
491 struct arm_smmu_cd cd
= {};
492 struct arm_smmu_cd cd_2
;
494 arm_smmu_test_make_s1_cd(&cd
, 778);
495 arm_smmu_test_make_s1_cd(&cd_2
, 1997);
496 arm_smmu_v3_test_cd_expect_hitless_transition(test
, &cd
, &cd_2
,
497 NUM_EXPECTED_SYNCS(1));
498 arm_smmu_v3_test_cd_expect_hitless_transition(test
, &cd_2
, &cd
,
499 NUM_EXPECTED_SYNCS(1));
502 static void arm_smmu_test_make_sva_cd(struct arm_smmu_cd
*cd
, unsigned int asid
)
504 struct arm_smmu_master master
= {
508 arm_smmu_make_sva_cd(cd
, &master
, &sva_mm
, asid
);
511 static void arm_smmu_test_make_sva_release_cd(struct arm_smmu_cd
*cd
,
514 struct arm_smmu_master master
= {
518 arm_smmu_make_sva_cd(cd
, &master
, NULL
, asid
);
521 static void arm_smmu_v3_write_ste_test_s1_to_s2_stall(struct kunit
*test
)
523 struct arm_smmu_ste s1_ste
;
524 struct arm_smmu_ste s2_ste
;
526 arm_smmu_test_make_cdtable_ste(&s1_ste
, STRTAB_STE_1_S1DSS_SSID0
,
527 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_STALL
);
528 arm_smmu_test_make_s2_ste(&s2_ste
, ARM_SMMU_MASTER_TEST_STALL
);
529 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &s1_ste
, &s2_ste
,
530 NUM_EXPECTED_SYNCS(3));
533 static void arm_smmu_v3_write_ste_test_s2_to_s1_stall(struct kunit
*test
)
535 struct arm_smmu_ste s1_ste
;
536 struct arm_smmu_ste s2_ste
;
538 arm_smmu_test_make_cdtable_ste(&s1_ste
, STRTAB_STE_1_S1DSS_SSID0
,
539 fake_cdtab_dma_addr
, ARM_SMMU_MASTER_TEST_STALL
);
540 arm_smmu_test_make_s2_ste(&s2_ste
, ARM_SMMU_MASTER_TEST_STALL
);
541 arm_smmu_v3_test_ste_expect_hitless_transition(test
, &s2_ste
, &s1_ste
,
542 NUM_EXPECTED_SYNCS(3));
545 static void arm_smmu_v3_write_cd_test_sva_clear(struct kunit
*test
)
547 struct arm_smmu_cd cd
= {};
548 struct arm_smmu_cd cd_2
;
550 arm_smmu_test_make_sva_cd(&cd_2
, 1997);
551 arm_smmu_v3_test_cd_expect_non_hitless_transition(
552 test
, &cd
, &cd_2
, NUM_EXPECTED_SYNCS(2));
553 arm_smmu_v3_test_cd_expect_non_hitless_transition(
554 test
, &cd_2
, &cd
, NUM_EXPECTED_SYNCS(2));
557 static void arm_smmu_v3_write_cd_test_sva_release(struct kunit
*test
)
559 struct arm_smmu_cd cd
;
560 struct arm_smmu_cd cd_2
;
562 arm_smmu_test_make_sva_cd(&cd
, 1997);
563 arm_smmu_test_make_sva_release_cd(&cd_2
, 1997);
564 arm_smmu_v3_test_cd_expect_hitless_transition(test
, &cd
, &cd_2
,
565 NUM_EXPECTED_SYNCS(2));
566 arm_smmu_v3_test_cd_expect_hitless_transition(test
, &cd_2
, &cd
,
567 NUM_EXPECTED_SYNCS(2));
570 static struct kunit_case arm_smmu_v3_test_cases
[] = {
571 KUNIT_CASE(arm_smmu_v3_write_ste_test_bypass_to_abort
),
572 KUNIT_CASE(arm_smmu_v3_write_ste_test_abort_to_bypass
),
573 KUNIT_CASE(arm_smmu_v3_write_ste_test_cdtable_to_abort
),
574 KUNIT_CASE(arm_smmu_v3_write_ste_test_abort_to_cdtable
),
575 KUNIT_CASE(arm_smmu_v3_write_ste_test_cdtable_to_bypass
),
576 KUNIT_CASE(arm_smmu_v3_write_ste_test_bypass_to_cdtable
),
577 KUNIT_CASE(arm_smmu_v3_write_ste_test_cdtable_s1dss_change
),
578 KUNIT_CASE(arm_smmu_v3_write_ste_test_s1dssbypass_to_stebypass
),
579 KUNIT_CASE(arm_smmu_v3_write_ste_test_stebypass_to_s1dssbypass
),
580 KUNIT_CASE(arm_smmu_v3_write_ste_test_s2_to_abort
),
581 KUNIT_CASE(arm_smmu_v3_write_ste_test_abort_to_s2
),
582 KUNIT_CASE(arm_smmu_v3_write_ste_test_s2_to_bypass
),
583 KUNIT_CASE(arm_smmu_v3_write_ste_test_bypass_to_s2
),
584 KUNIT_CASE(arm_smmu_v3_write_ste_test_s1_to_s2
),
585 KUNIT_CASE(arm_smmu_v3_write_ste_test_s2_to_s1
),
586 KUNIT_CASE(arm_smmu_v3_write_ste_test_non_hitless
),
587 KUNIT_CASE(arm_smmu_v3_write_cd_test_s1_clear
),
588 KUNIT_CASE(arm_smmu_v3_write_cd_test_s1_change_asid
),
589 KUNIT_CASE(arm_smmu_v3_write_ste_test_s1_to_s2_stall
),
590 KUNIT_CASE(arm_smmu_v3_write_ste_test_s2_to_s1_stall
),
591 KUNIT_CASE(arm_smmu_v3_write_cd_test_sva_clear
),
592 KUNIT_CASE(arm_smmu_v3_write_cd_test_sva_release
),
596 static int arm_smmu_v3_test_suite_init(struct kunit_suite
*test
)
598 arm_smmu_make_bypass_ste(&smmu
, &bypass_ste
);
599 arm_smmu_make_abort_ste(&abort_ste
);
603 static struct kunit_suite arm_smmu_v3_test_module
= {
604 .name
= "arm-smmu-v3-kunit-test",
605 .suite_init
= arm_smmu_v3_test_suite_init
,
606 .test_cases
= arm_smmu_v3_test_cases
,
608 kunit_test_suites(&arm_smmu_v3_test_module
);
610 MODULE_IMPORT_NS(EXPORTED_FOR_KUNIT_TESTING
);
611 MODULE_DESCRIPTION("KUnit tests for arm-smmu-v3 driver");
612 MODULE_LICENSE("GPL v2");