xref: /aosp_15_r20/external/XNNPACK/test/f32-igemm-2.cc (revision 4bdc94577ba0e567308109d787f7fec7b531ce36)
1*4bdc9457SAndroid Build Coastguard Worker // Copyright (c) Facebook, Inc. and its affiliates.
2*4bdc9457SAndroid Build Coastguard Worker // All rights reserved.
3*4bdc9457SAndroid Build Coastguard Worker //
4*4bdc9457SAndroid Build Coastguard Worker // Copyright 2019 Google LLC
5*4bdc9457SAndroid Build Coastguard Worker //
6*4bdc9457SAndroid Build Coastguard Worker // This source code is licensed under the BSD-style license found in the
7*4bdc9457SAndroid Build Coastguard Worker // LICENSE file in the root directory of this source tree.
8*4bdc9457SAndroid Build Coastguard Worker //
9*4bdc9457SAndroid Build Coastguard Worker // Auto-generated file. Do not edit!
10*4bdc9457SAndroid Build Coastguard Worker //   Specification: test/f32-igemm.yaml
11*4bdc9457SAndroid Build Coastguard Worker //   Generator: tools/generate-gemm-test.py
12*4bdc9457SAndroid Build Coastguard Worker 
13*4bdc9457SAndroid Build Coastguard Worker 
14*4bdc9457SAndroid Build Coastguard Worker #include <gtest/gtest.h>
15*4bdc9457SAndroid Build Coastguard Worker 
16*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/allocator.h>
17*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/common.h>
18*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/isa-checks.h>
19*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/microparams-init.h>
20*4bdc9457SAndroid Build Coastguard Worker 
21*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/gemm.h>
22*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/igemm.h>
23*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/ppmm.h>
24*4bdc9457SAndroid Build Coastguard Worker #include "gemm-microkernel-tester.h"
25*4bdc9457SAndroid Build Coastguard Worker 
26*4bdc9457SAndroid Build Coastguard Worker 
27*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,k_eq_1)28*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, k_eq_1) {
29*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
30*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
31*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
32*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
33*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
34*4bdc9457SAndroid Build Coastguard Worker       .m(1)
35*4bdc9457SAndroid Build Coastguard Worker       .n(8)
36*4bdc9457SAndroid Build Coastguard Worker       .k(1)
37*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
38*4bdc9457SAndroid Build Coastguard Worker   }
39*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,strided_cn)40*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, strided_cn) {
41*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
42*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
43*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
44*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
45*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
46*4bdc9457SAndroid Build Coastguard Worker       .m(1)
47*4bdc9457SAndroid Build Coastguard Worker       .n(8)
48*4bdc9457SAndroid Build Coastguard Worker       .k(1)
49*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
50*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
51*4bdc9457SAndroid Build Coastguard Worker   }
52*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,k_eq_1_subtile)53*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, k_eq_1_subtile) {
54*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
55*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 1; m++) {
56*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
57*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
58*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
59*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
60*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
61*4bdc9457SAndroid Build Coastguard Worker           .m(m)
62*4bdc9457SAndroid Build Coastguard Worker           .n(n)
63*4bdc9457SAndroid Build Coastguard Worker           .k(1)
64*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
65*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
66*4bdc9457SAndroid Build Coastguard Worker       }
67*4bdc9457SAndroid Build Coastguard Worker     }
68*4bdc9457SAndroid Build Coastguard Worker   }
69*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,k_eq_1_subtile_m)70*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, k_eq_1_subtile_m) {
71*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 1; m++) {
72*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
73*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
74*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
75*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
76*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
77*4bdc9457SAndroid Build Coastguard Worker         .m(m)
78*4bdc9457SAndroid Build Coastguard Worker         .n(8)
79*4bdc9457SAndroid Build Coastguard Worker         .k(1)
80*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
81*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
82*4bdc9457SAndroid Build Coastguard Worker     }
83*4bdc9457SAndroid Build Coastguard Worker   }
84*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,k_eq_1_subtile_n)85*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, k_eq_1_subtile_n) {
86*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
87*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
88*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
89*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
90*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
91*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
92*4bdc9457SAndroid Build Coastguard Worker         .m(1)
93*4bdc9457SAndroid Build Coastguard Worker         .n(n)
94*4bdc9457SAndroid Build Coastguard Worker         .k(1)
95*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
96*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
97*4bdc9457SAndroid Build Coastguard Worker     }
98*4bdc9457SAndroid Build Coastguard Worker   }
99*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,k_gt_1)100*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, k_gt_1) {
101*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
102*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
103*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
104*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
105*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
106*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
107*4bdc9457SAndroid Build Coastguard Worker         .m(1)
108*4bdc9457SAndroid Build Coastguard Worker         .n(8)
109*4bdc9457SAndroid Build Coastguard Worker         .k(k)
110*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
111*4bdc9457SAndroid Build Coastguard Worker     }
112*4bdc9457SAndroid Build Coastguard Worker   }
113*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,k_gt_1_subtile)114*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, k_gt_1_subtile) {
115*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
116*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
117*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
118*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
119*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
120*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
121*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
122*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
123*4bdc9457SAndroid Build Coastguard Worker             .m(m)
124*4bdc9457SAndroid Build Coastguard Worker             .n(n)
125*4bdc9457SAndroid Build Coastguard Worker             .k(k)
126*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
127*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
128*4bdc9457SAndroid Build Coastguard Worker         }
129*4bdc9457SAndroid Build Coastguard Worker       }
130*4bdc9457SAndroid Build Coastguard Worker     }
131*4bdc9457SAndroid Build Coastguard Worker   }
132*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_gt_8)133*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_gt_8) {
134*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
135*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
136*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
137*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
138*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
139*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
140*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
141*4bdc9457SAndroid Build Coastguard Worker           .m(1)
142*4bdc9457SAndroid Build Coastguard Worker           .n(n)
143*4bdc9457SAndroid Build Coastguard Worker           .k(k)
144*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
145*4bdc9457SAndroid Build Coastguard Worker       }
146*4bdc9457SAndroid Build Coastguard Worker     }
147*4bdc9457SAndroid Build Coastguard Worker   }
148*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_gt_8_strided_cn)149*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_gt_8_strided_cn) {
150*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
151*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
152*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
153*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
154*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
155*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
156*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
157*4bdc9457SAndroid Build Coastguard Worker           .m(1)
158*4bdc9457SAndroid Build Coastguard Worker           .n(n)
159*4bdc9457SAndroid Build Coastguard Worker           .k(k)
160*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
161*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
162*4bdc9457SAndroid Build Coastguard Worker       }
163*4bdc9457SAndroid Build Coastguard Worker     }
164*4bdc9457SAndroid Build Coastguard Worker   }
165*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_gt_8_subtile)166*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_gt_8_subtile) {
167*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
168*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
169*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
170*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
171*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
172*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
173*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
174*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
175*4bdc9457SAndroid Build Coastguard Worker             .m(m)
176*4bdc9457SAndroid Build Coastguard Worker             .n(n)
177*4bdc9457SAndroid Build Coastguard Worker             .k(k)
178*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
179*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
180*4bdc9457SAndroid Build Coastguard Worker         }
181*4bdc9457SAndroid Build Coastguard Worker       }
182*4bdc9457SAndroid Build Coastguard Worker     }
183*4bdc9457SAndroid Build Coastguard Worker   }
184*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_div_8)185*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_div_8) {
186*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
187*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
188*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
189*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
190*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
191*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
192*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
193*4bdc9457SAndroid Build Coastguard Worker           .m(1)
194*4bdc9457SAndroid Build Coastguard Worker           .n(n)
195*4bdc9457SAndroid Build Coastguard Worker           .k(k)
196*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
197*4bdc9457SAndroid Build Coastguard Worker       }
198*4bdc9457SAndroid Build Coastguard Worker     }
199*4bdc9457SAndroid Build Coastguard Worker   }
200*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_div_8_strided_cn)201*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_div_8_strided_cn) {
202*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
203*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
204*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
205*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
206*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
207*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
208*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
209*4bdc9457SAndroid Build Coastguard Worker           .m(1)
210*4bdc9457SAndroid Build Coastguard Worker           .n(n)
211*4bdc9457SAndroid Build Coastguard Worker           .k(k)
212*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
213*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
214*4bdc9457SAndroid Build Coastguard Worker       }
215*4bdc9457SAndroid Build Coastguard Worker     }
216*4bdc9457SAndroid Build Coastguard Worker   }
217*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_div_8_subtile)218*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_div_8_subtile) {
219*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
220*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
221*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
222*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
223*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
224*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
225*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
226*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
227*4bdc9457SAndroid Build Coastguard Worker             .m(m)
228*4bdc9457SAndroid Build Coastguard Worker             .n(n)
229*4bdc9457SAndroid Build Coastguard Worker             .k(k)
230*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
231*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
232*4bdc9457SAndroid Build Coastguard Worker         }
233*4bdc9457SAndroid Build Coastguard Worker       }
234*4bdc9457SAndroid Build Coastguard Worker     }
235*4bdc9457SAndroid Build Coastguard Worker   }
236*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,small_kernel)237*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, small_kernel) {
238*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
239*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
240*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
241*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
242*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
243*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
244*4bdc9457SAndroid Build Coastguard Worker         .m(1)
245*4bdc9457SAndroid Build Coastguard Worker         .n(8)
246*4bdc9457SAndroid Build Coastguard Worker         .k(k)
247*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
248*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
249*4bdc9457SAndroid Build Coastguard Worker     }
250*4bdc9457SAndroid Build Coastguard Worker   }
251*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,small_kernel_subtile)252*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, small_kernel_subtile) {
253*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
254*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
255*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
256*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
257*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
258*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
259*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
260*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
261*4bdc9457SAndroid Build Coastguard Worker             .m(m)
262*4bdc9457SAndroid Build Coastguard Worker             .n(n)
263*4bdc9457SAndroid Build Coastguard Worker             .k(k)
264*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
265*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
266*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
267*4bdc9457SAndroid Build Coastguard Worker         }
268*4bdc9457SAndroid Build Coastguard Worker       }
269*4bdc9457SAndroid Build Coastguard Worker     }
270*4bdc9457SAndroid Build Coastguard Worker   }
271*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_gt_8_small_kernel)272*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_gt_8_small_kernel) {
273*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
274*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
275*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
276*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
277*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
278*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
279*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
280*4bdc9457SAndroid Build Coastguard Worker           .m(1)
281*4bdc9457SAndroid Build Coastguard Worker           .n(n)
282*4bdc9457SAndroid Build Coastguard Worker           .k(k)
283*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
284*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
285*4bdc9457SAndroid Build Coastguard Worker       }
286*4bdc9457SAndroid Build Coastguard Worker     }
287*4bdc9457SAndroid Build Coastguard Worker   }
288*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,n_div_8_small_kernel)289*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, n_div_8_small_kernel) {
290*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
291*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
292*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
293*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
294*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
295*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
296*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
297*4bdc9457SAndroid Build Coastguard Worker           .m(1)
298*4bdc9457SAndroid Build Coastguard Worker           .n(n)
299*4bdc9457SAndroid Build Coastguard Worker           .k(k)
300*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
301*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
302*4bdc9457SAndroid Build Coastguard Worker       }
303*4bdc9457SAndroid Build Coastguard Worker     }
304*4bdc9457SAndroid Build Coastguard Worker   }
305*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,strided_cm_subtile)306*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, strided_cm_subtile) {
307*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
308*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
309*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
310*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
311*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
312*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
313*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
314*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
315*4bdc9457SAndroid Build Coastguard Worker             .m(m)
316*4bdc9457SAndroid Build Coastguard Worker             .n(n)
317*4bdc9457SAndroid Build Coastguard Worker             .k(k)
318*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
319*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
320*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
321*4bdc9457SAndroid Build Coastguard Worker         }
322*4bdc9457SAndroid Build Coastguard Worker       }
323*4bdc9457SAndroid Build Coastguard Worker     }
324*4bdc9457SAndroid Build Coastguard Worker   }
325*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,a_offset)326*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, a_offset) {
327*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
328*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
329*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
330*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
331*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
332*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
333*4bdc9457SAndroid Build Coastguard Worker         .m(1)
334*4bdc9457SAndroid Build Coastguard Worker         .n(8)
335*4bdc9457SAndroid Build Coastguard Worker         .k(k)
336*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
337*4bdc9457SAndroid Build Coastguard Worker         .a_offset(7)
338*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
339*4bdc9457SAndroid Build Coastguard Worker     }
340*4bdc9457SAndroid Build Coastguard Worker   }
341*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,zero)342*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, zero) {
343*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
344*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 1; mz++) {
345*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
346*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
347*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
348*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
349*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
350*4bdc9457SAndroid Build Coastguard Worker           .m(1)
351*4bdc9457SAndroid Build Coastguard Worker           .n(8)
352*4bdc9457SAndroid Build Coastguard Worker           .k(k)
353*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
354*4bdc9457SAndroid Build Coastguard Worker           .a_offset(7)
355*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
356*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
357*4bdc9457SAndroid Build Coastguard Worker       }
358*4bdc9457SAndroid Build Coastguard Worker     }
359*4bdc9457SAndroid Build Coastguard Worker   }
360*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT,strided_cm)361*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_LOADSPLAT, strided_cm) {
362*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
363*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
364*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
365*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
366*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
367*4bdc9457SAndroid Build Coastguard Worker       .m(1)
368*4bdc9457SAndroid Build Coastguard Worker       .n(8)
369*4bdc9457SAndroid Build Coastguard Worker       .k(1)
370*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
371*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_loadsplat);
372*4bdc9457SAndroid Build Coastguard Worker   }
373*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
374*4bdc9457SAndroid Build Coastguard Worker 
375*4bdc9457SAndroid Build Coastguard Worker 
376*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_eq_4)377*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_eq_4) {
378*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
379*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
380*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
381*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
382*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
383*4bdc9457SAndroid Build Coastguard Worker       .m(1)
384*4bdc9457SAndroid Build Coastguard Worker       .n(8)
385*4bdc9457SAndroid Build Coastguard Worker       .k(4)
386*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
387*4bdc9457SAndroid Build Coastguard Worker   }
388*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,strided_cn)389*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, strided_cn) {
390*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
391*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
392*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
393*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
394*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
395*4bdc9457SAndroid Build Coastguard Worker       .m(1)
396*4bdc9457SAndroid Build Coastguard Worker       .n(8)
397*4bdc9457SAndroid Build Coastguard Worker       .k(4)
398*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
399*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
400*4bdc9457SAndroid Build Coastguard Worker   }
401*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_eq_4_subtile)402*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_eq_4_subtile) {
403*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
404*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 1; m++) {
405*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
406*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
407*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
408*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
409*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
410*4bdc9457SAndroid Build Coastguard Worker           .m(m)
411*4bdc9457SAndroid Build Coastguard Worker           .n(n)
412*4bdc9457SAndroid Build Coastguard Worker           .k(4)
413*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
414*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
415*4bdc9457SAndroid Build Coastguard Worker       }
416*4bdc9457SAndroid Build Coastguard Worker     }
417*4bdc9457SAndroid Build Coastguard Worker   }
418*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_eq_4_subtile_m)419*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_eq_4_subtile_m) {
420*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 1; m++) {
421*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
422*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
423*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
424*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
425*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
426*4bdc9457SAndroid Build Coastguard Worker         .m(m)
427*4bdc9457SAndroid Build Coastguard Worker         .n(8)
428*4bdc9457SAndroid Build Coastguard Worker         .k(4)
429*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
430*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
431*4bdc9457SAndroid Build Coastguard Worker     }
432*4bdc9457SAndroid Build Coastguard Worker   }
433*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_eq_4_subtile_n)434*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_eq_4_subtile_n) {
435*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
436*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
437*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
438*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
439*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
440*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
441*4bdc9457SAndroid Build Coastguard Worker         .m(1)
442*4bdc9457SAndroid Build Coastguard Worker         .n(n)
443*4bdc9457SAndroid Build Coastguard Worker         .k(4)
444*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
445*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
446*4bdc9457SAndroid Build Coastguard Worker     }
447*4bdc9457SAndroid Build Coastguard Worker   }
448*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_lt_4)449*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_lt_4) {
450*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
451*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
452*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
453*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
454*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
455*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
456*4bdc9457SAndroid Build Coastguard Worker         .m(1)
457*4bdc9457SAndroid Build Coastguard Worker         .n(8)
458*4bdc9457SAndroid Build Coastguard Worker         .k(k)
459*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
460*4bdc9457SAndroid Build Coastguard Worker     }
461*4bdc9457SAndroid Build Coastguard Worker   }
462*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_lt_4_subtile)463*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_lt_4_subtile) {
464*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
465*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
466*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
467*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
468*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
469*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
470*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
471*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
472*4bdc9457SAndroid Build Coastguard Worker             .m(m)
473*4bdc9457SAndroid Build Coastguard Worker             .n(n)
474*4bdc9457SAndroid Build Coastguard Worker             .k(k)
475*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
476*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
477*4bdc9457SAndroid Build Coastguard Worker         }
478*4bdc9457SAndroid Build Coastguard Worker       }
479*4bdc9457SAndroid Build Coastguard Worker     }
480*4bdc9457SAndroid Build Coastguard Worker   }
481*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_gt_4)482*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_gt_4) {
483*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
484*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
485*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
486*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
487*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
488*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
489*4bdc9457SAndroid Build Coastguard Worker         .m(1)
490*4bdc9457SAndroid Build Coastguard Worker         .n(8)
491*4bdc9457SAndroid Build Coastguard Worker         .k(k)
492*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
493*4bdc9457SAndroid Build Coastguard Worker     }
494*4bdc9457SAndroid Build Coastguard Worker   }
495*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_gt_4_subtile)496*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_gt_4_subtile) {
497*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
498*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
499*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
500*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
501*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
502*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
503*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
504*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
505*4bdc9457SAndroid Build Coastguard Worker             .m(m)
506*4bdc9457SAndroid Build Coastguard Worker             .n(n)
507*4bdc9457SAndroid Build Coastguard Worker             .k(k)
508*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
509*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
510*4bdc9457SAndroid Build Coastguard Worker         }
511*4bdc9457SAndroid Build Coastguard Worker       }
512*4bdc9457SAndroid Build Coastguard Worker     }
513*4bdc9457SAndroid Build Coastguard Worker   }
514*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_div_4)515*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_div_4) {
516*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
517*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
518*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
519*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
520*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
521*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
522*4bdc9457SAndroid Build Coastguard Worker         .m(1)
523*4bdc9457SAndroid Build Coastguard Worker         .n(8)
524*4bdc9457SAndroid Build Coastguard Worker         .k(k)
525*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
526*4bdc9457SAndroid Build Coastguard Worker     }
527*4bdc9457SAndroid Build Coastguard Worker   }
528*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,k_div_4_subtile)529*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, k_div_4_subtile) {
530*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
531*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
532*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
533*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
534*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
535*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
536*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
537*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
538*4bdc9457SAndroid Build Coastguard Worker             .m(m)
539*4bdc9457SAndroid Build Coastguard Worker             .n(n)
540*4bdc9457SAndroid Build Coastguard Worker             .k(k)
541*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
542*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
543*4bdc9457SAndroid Build Coastguard Worker         }
544*4bdc9457SAndroid Build Coastguard Worker       }
545*4bdc9457SAndroid Build Coastguard Worker     }
546*4bdc9457SAndroid Build Coastguard Worker   }
547*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_gt_8)548*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_gt_8) {
549*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
550*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
551*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
552*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
553*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
554*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
555*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
556*4bdc9457SAndroid Build Coastguard Worker           .m(1)
557*4bdc9457SAndroid Build Coastguard Worker           .n(n)
558*4bdc9457SAndroid Build Coastguard Worker           .k(k)
559*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
560*4bdc9457SAndroid Build Coastguard Worker       }
561*4bdc9457SAndroid Build Coastguard Worker     }
562*4bdc9457SAndroid Build Coastguard Worker   }
563*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_gt_8_strided_cn)564*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_gt_8_strided_cn) {
565*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
566*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
567*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
568*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
569*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
570*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
571*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
572*4bdc9457SAndroid Build Coastguard Worker           .m(1)
573*4bdc9457SAndroid Build Coastguard Worker           .n(n)
574*4bdc9457SAndroid Build Coastguard Worker           .k(k)
575*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
576*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
577*4bdc9457SAndroid Build Coastguard Worker       }
578*4bdc9457SAndroid Build Coastguard Worker     }
579*4bdc9457SAndroid Build Coastguard Worker   }
580*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_gt_8_subtile)581*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_gt_8_subtile) {
582*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
583*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
584*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
585*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
586*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
587*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
588*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
589*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
590*4bdc9457SAndroid Build Coastguard Worker             .m(m)
591*4bdc9457SAndroid Build Coastguard Worker             .n(n)
592*4bdc9457SAndroid Build Coastguard Worker             .k(k)
593*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
594*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
595*4bdc9457SAndroid Build Coastguard Worker         }
596*4bdc9457SAndroid Build Coastguard Worker       }
597*4bdc9457SAndroid Build Coastguard Worker     }
598*4bdc9457SAndroid Build Coastguard Worker   }
599*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_div_8)600*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_div_8) {
601*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
602*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
603*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
604*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
605*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
606*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
607*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
608*4bdc9457SAndroid Build Coastguard Worker           .m(1)
609*4bdc9457SAndroid Build Coastguard Worker           .n(n)
610*4bdc9457SAndroid Build Coastguard Worker           .k(k)
611*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
612*4bdc9457SAndroid Build Coastguard Worker       }
613*4bdc9457SAndroid Build Coastguard Worker     }
614*4bdc9457SAndroid Build Coastguard Worker   }
615*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_div_8_strided_cn)616*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_div_8_strided_cn) {
617*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
618*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
619*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
620*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
621*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
622*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
623*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
624*4bdc9457SAndroid Build Coastguard Worker           .m(1)
625*4bdc9457SAndroid Build Coastguard Worker           .n(n)
626*4bdc9457SAndroid Build Coastguard Worker           .k(k)
627*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
628*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
629*4bdc9457SAndroid Build Coastguard Worker       }
630*4bdc9457SAndroid Build Coastguard Worker     }
631*4bdc9457SAndroid Build Coastguard Worker   }
632*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_div_8_subtile)633*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_div_8_subtile) {
634*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
635*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
636*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
637*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
638*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
639*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
640*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
641*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
642*4bdc9457SAndroid Build Coastguard Worker             .m(m)
643*4bdc9457SAndroid Build Coastguard Worker             .n(n)
644*4bdc9457SAndroid Build Coastguard Worker             .k(k)
645*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
646*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
647*4bdc9457SAndroid Build Coastguard Worker         }
648*4bdc9457SAndroid Build Coastguard Worker       }
649*4bdc9457SAndroid Build Coastguard Worker     }
650*4bdc9457SAndroid Build Coastguard Worker   }
651*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,small_kernel)652*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, small_kernel) {
653*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
654*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
655*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
656*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
657*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
658*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
659*4bdc9457SAndroid Build Coastguard Worker         .m(1)
660*4bdc9457SAndroid Build Coastguard Worker         .n(8)
661*4bdc9457SAndroid Build Coastguard Worker         .k(k)
662*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
663*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
664*4bdc9457SAndroid Build Coastguard Worker     }
665*4bdc9457SAndroid Build Coastguard Worker   }
666*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,small_kernel_subtile)667*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, small_kernel_subtile) {
668*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
669*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
670*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
671*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
672*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
673*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
674*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
675*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
676*4bdc9457SAndroid Build Coastguard Worker             .m(m)
677*4bdc9457SAndroid Build Coastguard Worker             .n(n)
678*4bdc9457SAndroid Build Coastguard Worker             .k(k)
679*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
680*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
681*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
682*4bdc9457SAndroid Build Coastguard Worker         }
683*4bdc9457SAndroid Build Coastguard Worker       }
684*4bdc9457SAndroid Build Coastguard Worker     }
685*4bdc9457SAndroid Build Coastguard Worker   }
686*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_gt_8_small_kernel)687*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_gt_8_small_kernel) {
688*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
689*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
690*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
691*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
692*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
693*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
694*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
695*4bdc9457SAndroid Build Coastguard Worker           .m(1)
696*4bdc9457SAndroid Build Coastguard Worker           .n(n)
697*4bdc9457SAndroid Build Coastguard Worker           .k(k)
698*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
699*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
700*4bdc9457SAndroid Build Coastguard Worker       }
701*4bdc9457SAndroid Build Coastguard Worker     }
702*4bdc9457SAndroid Build Coastguard Worker   }
703*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,n_div_8_small_kernel)704*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, n_div_8_small_kernel) {
705*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
706*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
707*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
708*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
709*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
710*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
711*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
712*4bdc9457SAndroid Build Coastguard Worker           .m(1)
713*4bdc9457SAndroid Build Coastguard Worker           .n(n)
714*4bdc9457SAndroid Build Coastguard Worker           .k(k)
715*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
716*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
717*4bdc9457SAndroid Build Coastguard Worker       }
718*4bdc9457SAndroid Build Coastguard Worker     }
719*4bdc9457SAndroid Build Coastguard Worker   }
720*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,strided_cm_subtile)721*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, strided_cm_subtile) {
722*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
723*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
724*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
725*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
726*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
727*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
728*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
729*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
730*4bdc9457SAndroid Build Coastguard Worker             .m(m)
731*4bdc9457SAndroid Build Coastguard Worker             .n(n)
732*4bdc9457SAndroid Build Coastguard Worker             .k(k)
733*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
734*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
735*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
736*4bdc9457SAndroid Build Coastguard Worker         }
737*4bdc9457SAndroid Build Coastguard Worker       }
738*4bdc9457SAndroid Build Coastguard Worker     }
739*4bdc9457SAndroid Build Coastguard Worker   }
740*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,a_offset)741*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, a_offset) {
742*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
743*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
744*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
745*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
746*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
747*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
748*4bdc9457SAndroid Build Coastguard Worker         .m(1)
749*4bdc9457SAndroid Build Coastguard Worker         .n(8)
750*4bdc9457SAndroid Build Coastguard Worker         .k(k)
751*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
752*4bdc9457SAndroid Build Coastguard Worker         .a_offset(23)
753*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
754*4bdc9457SAndroid Build Coastguard Worker     }
755*4bdc9457SAndroid Build Coastguard Worker   }
756*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,zero)757*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, zero) {
758*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
759*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 1; mz++) {
760*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
761*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
762*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
763*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
764*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
765*4bdc9457SAndroid Build Coastguard Worker           .m(1)
766*4bdc9457SAndroid Build Coastguard Worker           .n(8)
767*4bdc9457SAndroid Build Coastguard Worker           .k(k)
768*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
769*4bdc9457SAndroid Build Coastguard Worker           .a_offset(23)
770*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
771*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
772*4bdc9457SAndroid Build Coastguard Worker       }
773*4bdc9457SAndroid Build Coastguard Worker     }
774*4bdc9457SAndroid Build Coastguard Worker   }
775*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT,strided_cm)776*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMSIMD_SPLAT, strided_cm) {
777*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
778*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
779*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
780*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
781*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
782*4bdc9457SAndroid Build Coastguard Worker       .m(1)
783*4bdc9457SAndroid Build Coastguard Worker       .n(8)
784*4bdc9457SAndroid Build Coastguard Worker       .k(4)
785*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
786*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmsimd_splat);
787*4bdc9457SAndroid Build Coastguard Worker   }
788*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
789*4bdc9457SAndroid Build Coastguard Worker 
790*4bdc9457SAndroid Build Coastguard Worker 
791*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_eq_4)792*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_eq_4) {
793*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
794*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
795*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
796*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
797*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
798*4bdc9457SAndroid Build Coastguard Worker       .m(1)
799*4bdc9457SAndroid Build Coastguard Worker       .n(8)
800*4bdc9457SAndroid Build Coastguard Worker       .k(4)
801*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
802*4bdc9457SAndroid Build Coastguard Worker   }
803*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,strided_cn)804*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, strided_cn) {
805*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
806*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
807*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
808*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
809*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
810*4bdc9457SAndroid Build Coastguard Worker       .m(1)
811*4bdc9457SAndroid Build Coastguard Worker       .n(8)
812*4bdc9457SAndroid Build Coastguard Worker       .k(4)
813*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
814*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
815*4bdc9457SAndroid Build Coastguard Worker   }
816*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_eq_4_subtile)817*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_eq_4_subtile) {
818*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
819*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 1; m++) {
820*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
821*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
822*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
823*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
824*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
825*4bdc9457SAndroid Build Coastguard Worker           .m(m)
826*4bdc9457SAndroid Build Coastguard Worker           .n(n)
827*4bdc9457SAndroid Build Coastguard Worker           .k(4)
828*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
829*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
830*4bdc9457SAndroid Build Coastguard Worker       }
831*4bdc9457SAndroid Build Coastguard Worker     }
832*4bdc9457SAndroid Build Coastguard Worker   }
833*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_eq_4_subtile_m)834*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_eq_4_subtile_m) {
835*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 1; m++) {
836*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
837*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
838*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
839*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
840*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
841*4bdc9457SAndroid Build Coastguard Worker         .m(m)
842*4bdc9457SAndroid Build Coastguard Worker         .n(8)
843*4bdc9457SAndroid Build Coastguard Worker         .k(4)
844*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
845*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
846*4bdc9457SAndroid Build Coastguard Worker     }
847*4bdc9457SAndroid Build Coastguard Worker   }
848*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_eq_4_subtile_n)849*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_eq_4_subtile_n) {
850*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
851*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
852*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
853*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
854*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
855*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
856*4bdc9457SAndroid Build Coastguard Worker         .m(1)
857*4bdc9457SAndroid Build Coastguard Worker         .n(n)
858*4bdc9457SAndroid Build Coastguard Worker         .k(4)
859*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
860*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
861*4bdc9457SAndroid Build Coastguard Worker     }
862*4bdc9457SAndroid Build Coastguard Worker   }
863*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_lt_4)864*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_lt_4) {
865*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
866*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
867*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
868*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
869*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
870*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
871*4bdc9457SAndroid Build Coastguard Worker         .m(1)
872*4bdc9457SAndroid Build Coastguard Worker         .n(8)
873*4bdc9457SAndroid Build Coastguard Worker         .k(k)
874*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
875*4bdc9457SAndroid Build Coastguard Worker     }
876*4bdc9457SAndroid Build Coastguard Worker   }
877*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_lt_4_subtile)878*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_lt_4_subtile) {
879*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
880*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
881*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
882*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
883*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
884*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
885*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
886*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
887*4bdc9457SAndroid Build Coastguard Worker             .m(m)
888*4bdc9457SAndroid Build Coastguard Worker             .n(n)
889*4bdc9457SAndroid Build Coastguard Worker             .k(k)
890*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
891*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
892*4bdc9457SAndroid Build Coastguard Worker         }
893*4bdc9457SAndroid Build Coastguard Worker       }
894*4bdc9457SAndroid Build Coastguard Worker     }
895*4bdc9457SAndroid Build Coastguard Worker   }
896*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_gt_4)897*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_gt_4) {
898*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
899*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
900*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
901*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
902*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
903*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
904*4bdc9457SAndroid Build Coastguard Worker         .m(1)
905*4bdc9457SAndroid Build Coastguard Worker         .n(8)
906*4bdc9457SAndroid Build Coastguard Worker         .k(k)
907*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
908*4bdc9457SAndroid Build Coastguard Worker     }
909*4bdc9457SAndroid Build Coastguard Worker   }
910*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_gt_4_subtile)911*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_gt_4_subtile) {
912*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
913*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
914*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
915*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
916*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
917*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
918*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
919*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
920*4bdc9457SAndroid Build Coastguard Worker             .m(m)
921*4bdc9457SAndroid Build Coastguard Worker             .n(n)
922*4bdc9457SAndroid Build Coastguard Worker             .k(k)
923*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
924*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
925*4bdc9457SAndroid Build Coastguard Worker         }
926*4bdc9457SAndroid Build Coastguard Worker       }
927*4bdc9457SAndroid Build Coastguard Worker     }
928*4bdc9457SAndroid Build Coastguard Worker   }
929*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_div_4)930*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_div_4) {
931*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
932*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
933*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
934*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
935*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
936*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
937*4bdc9457SAndroid Build Coastguard Worker         .m(1)
938*4bdc9457SAndroid Build Coastguard Worker         .n(8)
939*4bdc9457SAndroid Build Coastguard Worker         .k(k)
940*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
941*4bdc9457SAndroid Build Coastguard Worker     }
942*4bdc9457SAndroid Build Coastguard Worker   }
943*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,k_div_4_subtile)944*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, k_div_4_subtile) {
945*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
946*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
947*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
948*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
949*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
950*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
951*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
952*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
953*4bdc9457SAndroid Build Coastguard Worker             .m(m)
954*4bdc9457SAndroid Build Coastguard Worker             .n(n)
955*4bdc9457SAndroid Build Coastguard Worker             .k(k)
956*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
957*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
958*4bdc9457SAndroid Build Coastguard Worker         }
959*4bdc9457SAndroid Build Coastguard Worker       }
960*4bdc9457SAndroid Build Coastguard Worker     }
961*4bdc9457SAndroid Build Coastguard Worker   }
962*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_gt_8)963*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_gt_8) {
964*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
965*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
966*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
967*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
968*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
969*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
970*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
971*4bdc9457SAndroid Build Coastguard Worker           .m(1)
972*4bdc9457SAndroid Build Coastguard Worker           .n(n)
973*4bdc9457SAndroid Build Coastguard Worker           .k(k)
974*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
975*4bdc9457SAndroid Build Coastguard Worker       }
976*4bdc9457SAndroid Build Coastguard Worker     }
977*4bdc9457SAndroid Build Coastguard Worker   }
978*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_gt_8_strided_cn)979*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_gt_8_strided_cn) {
980*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
981*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
982*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
983*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
984*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
985*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
986*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
987*4bdc9457SAndroid Build Coastguard Worker           .m(1)
988*4bdc9457SAndroid Build Coastguard Worker           .n(n)
989*4bdc9457SAndroid Build Coastguard Worker           .k(k)
990*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
991*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
992*4bdc9457SAndroid Build Coastguard Worker       }
993*4bdc9457SAndroid Build Coastguard Worker     }
994*4bdc9457SAndroid Build Coastguard Worker   }
995*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_gt_8_subtile)996*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_gt_8_subtile) {
997*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
998*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
999*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
1000*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1001*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
1002*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1003*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1004*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
1005*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1006*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1007*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1008*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1009*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1010*4bdc9457SAndroid Build Coastguard Worker         }
1011*4bdc9457SAndroid Build Coastguard Worker       }
1012*4bdc9457SAndroid Build Coastguard Worker     }
1013*4bdc9457SAndroid Build Coastguard Worker   }
1014*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_div_8)1015*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_div_8) {
1016*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1017*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1018*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1019*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
1020*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1021*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1022*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
1023*4bdc9457SAndroid Build Coastguard Worker           .m(1)
1024*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1025*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1026*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1027*4bdc9457SAndroid Build Coastguard Worker       }
1028*4bdc9457SAndroid Build Coastguard Worker     }
1029*4bdc9457SAndroid Build Coastguard Worker   }
1030*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_div_8_strided_cn)1031*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_div_8_strided_cn) {
1032*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1033*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1034*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1035*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
1036*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1037*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1038*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
1039*4bdc9457SAndroid Build Coastguard Worker           .m(1)
1040*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1041*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1042*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
1043*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1044*4bdc9457SAndroid Build Coastguard Worker       }
1045*4bdc9457SAndroid Build Coastguard Worker     }
1046*4bdc9457SAndroid Build Coastguard Worker   }
1047*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_div_8_subtile)1048*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_div_8_subtile) {
1049*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1050*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1051*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
1052*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1053*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
1054*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1055*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1056*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
1057*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1058*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1059*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1060*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1061*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1062*4bdc9457SAndroid Build Coastguard Worker         }
1063*4bdc9457SAndroid Build Coastguard Worker       }
1064*4bdc9457SAndroid Build Coastguard Worker     }
1065*4bdc9457SAndroid Build Coastguard Worker   }
1066*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,small_kernel)1067*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, small_kernel) {
1068*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1069*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1070*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
1071*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1072*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1073*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
1074*4bdc9457SAndroid Build Coastguard Worker         .m(1)
1075*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1076*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1077*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
1078*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1079*4bdc9457SAndroid Build Coastguard Worker     }
1080*4bdc9457SAndroid Build Coastguard Worker   }
1081*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,small_kernel_subtile)1082*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, small_kernel_subtile) {
1083*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1084*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1085*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
1086*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1087*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
1088*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1089*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1090*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
1091*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1092*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1093*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1094*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
1095*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1096*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1097*4bdc9457SAndroid Build Coastguard Worker         }
1098*4bdc9457SAndroid Build Coastguard Worker       }
1099*4bdc9457SAndroid Build Coastguard Worker     }
1100*4bdc9457SAndroid Build Coastguard Worker   }
1101*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_gt_8_small_kernel)1102*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_gt_8_small_kernel) {
1103*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1104*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1105*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1106*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
1107*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1108*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1109*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
1110*4bdc9457SAndroid Build Coastguard Worker           .m(1)
1111*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1112*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1113*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1114*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1115*4bdc9457SAndroid Build Coastguard Worker       }
1116*4bdc9457SAndroid Build Coastguard Worker     }
1117*4bdc9457SAndroid Build Coastguard Worker   }
1118*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,n_div_8_small_kernel)1119*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, n_div_8_small_kernel) {
1120*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1121*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1122*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1123*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
1124*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1125*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1126*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
1127*4bdc9457SAndroid Build Coastguard Worker           .m(1)
1128*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1129*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1130*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1131*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1132*4bdc9457SAndroid Build Coastguard Worker       }
1133*4bdc9457SAndroid Build Coastguard Worker     }
1134*4bdc9457SAndroid Build Coastguard Worker   }
1135*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,strided_cm_subtile)1136*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, strided_cm_subtile) {
1137*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1138*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1139*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
1140*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1141*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
1142*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1143*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1144*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
1145*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1146*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1147*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1148*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
1149*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1150*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1151*4bdc9457SAndroid Build Coastguard Worker         }
1152*4bdc9457SAndroid Build Coastguard Worker       }
1153*4bdc9457SAndroid Build Coastguard Worker     }
1154*4bdc9457SAndroid Build Coastguard Worker   }
1155*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,a_offset)1156*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, a_offset) {
1157*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1158*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1159*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
1160*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1161*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1162*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
1163*4bdc9457SAndroid Build Coastguard Worker         .m(1)
1164*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1165*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1166*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
1167*4bdc9457SAndroid Build Coastguard Worker         .a_offset(23)
1168*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1169*4bdc9457SAndroid Build Coastguard Worker     }
1170*4bdc9457SAndroid Build Coastguard Worker   }
1171*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,zero)1172*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, zero) {
1173*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1174*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 1; mz++) {
1175*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1176*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
1177*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1178*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1179*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
1180*4bdc9457SAndroid Build Coastguard Worker           .m(1)
1181*4bdc9457SAndroid Build Coastguard Worker           .n(8)
1182*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1183*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1184*4bdc9457SAndroid Build Coastguard Worker           .a_offset(23)
1185*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
1186*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1187*4bdc9457SAndroid Build Coastguard Worker       }
1188*4bdc9457SAndroid Build Coastguard Worker     }
1189*4bdc9457SAndroid Build Coastguard Worker   }
1190*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8S4__WASMSIMD,strided_cm)1191*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8S4__WASMSIMD, strided_cm) {
1192*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
1193*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
1194*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
1195*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
1196*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
1197*4bdc9457SAndroid Build Coastguard Worker       .m(1)
1198*4bdc9457SAndroid Build Coastguard Worker       .n(8)
1199*4bdc9457SAndroid Build Coastguard Worker       .k(4)
1200*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
1201*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8s4__wasmsimd);
1202*4bdc9457SAndroid Build Coastguard Worker   }
1203*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
1204*4bdc9457SAndroid Build Coastguard Worker 
1205*4bdc9457SAndroid Build Coastguard Worker 
1206*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_eq_4)1207*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_eq_4) {
1208*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
1209*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
1210*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
1211*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
1212*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
1213*4bdc9457SAndroid Build Coastguard Worker       .m(4)
1214*4bdc9457SAndroid Build Coastguard Worker       .n(8)
1215*4bdc9457SAndroid Build Coastguard Worker       .k(4)
1216*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1217*4bdc9457SAndroid Build Coastguard Worker   }
1218*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,strided_cn)1219*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, strided_cn) {
1220*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
1221*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
1222*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
1223*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
1224*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
1225*4bdc9457SAndroid Build Coastguard Worker       .m(4)
1226*4bdc9457SAndroid Build Coastguard Worker       .n(8)
1227*4bdc9457SAndroid Build Coastguard Worker       .k(4)
1228*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
1229*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1230*4bdc9457SAndroid Build Coastguard Worker   }
1231*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_eq_4_subtile)1232*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_eq_4_subtile) {
1233*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
1234*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 4; m++) {
1235*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1236*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1237*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1238*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1239*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1240*4bdc9457SAndroid Build Coastguard Worker           .m(m)
1241*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1242*4bdc9457SAndroid Build Coastguard Worker           .k(4)
1243*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
1244*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1245*4bdc9457SAndroid Build Coastguard Worker       }
1246*4bdc9457SAndroid Build Coastguard Worker     }
1247*4bdc9457SAndroid Build Coastguard Worker   }
1248*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_eq_4_subtile_m)1249*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_eq_4_subtile_m) {
1250*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 4; m++) {
1251*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1252*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
1253*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1254*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1255*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1256*4bdc9457SAndroid Build Coastguard Worker         .m(m)
1257*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1258*4bdc9457SAndroid Build Coastguard Worker         .k(4)
1259*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
1260*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1261*4bdc9457SAndroid Build Coastguard Worker     }
1262*4bdc9457SAndroid Build Coastguard Worker   }
1263*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_eq_4_subtile_n)1264*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_eq_4_subtile_n) {
1265*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
1266*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1267*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
1268*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1269*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1270*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1271*4bdc9457SAndroid Build Coastguard Worker         .m(4)
1272*4bdc9457SAndroid Build Coastguard Worker         .n(n)
1273*4bdc9457SAndroid Build Coastguard Worker         .k(4)
1274*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
1275*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1276*4bdc9457SAndroid Build Coastguard Worker     }
1277*4bdc9457SAndroid Build Coastguard Worker   }
1278*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_lt_4)1279*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_lt_4) {
1280*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
1281*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1282*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
1283*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1284*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1285*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1286*4bdc9457SAndroid Build Coastguard Worker         .m(4)
1287*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1288*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1289*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1290*4bdc9457SAndroid Build Coastguard Worker     }
1291*4bdc9457SAndroid Build Coastguard Worker   }
1292*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_lt_4_subtile)1293*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_lt_4_subtile) {
1294*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
1295*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1296*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
1297*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1298*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
1299*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1300*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1301*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1302*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1303*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1304*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1305*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1306*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1307*4bdc9457SAndroid Build Coastguard Worker         }
1308*4bdc9457SAndroid Build Coastguard Worker       }
1309*4bdc9457SAndroid Build Coastguard Worker     }
1310*4bdc9457SAndroid Build Coastguard Worker   }
1311*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_gt_4)1312*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_gt_4) {
1313*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
1314*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1315*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
1316*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1317*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1318*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1319*4bdc9457SAndroid Build Coastguard Worker         .m(4)
1320*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1321*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1322*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1323*4bdc9457SAndroid Build Coastguard Worker     }
1324*4bdc9457SAndroid Build Coastguard Worker   }
1325*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_gt_4_subtile)1326*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_gt_4_subtile) {
1327*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
1328*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1329*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
1330*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1331*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
1332*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1333*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1334*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1335*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1336*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1337*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1338*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1339*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1340*4bdc9457SAndroid Build Coastguard Worker         }
1341*4bdc9457SAndroid Build Coastguard Worker       }
1342*4bdc9457SAndroid Build Coastguard Worker     }
1343*4bdc9457SAndroid Build Coastguard Worker   }
1344*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_div_4)1345*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_div_4) {
1346*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
1347*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1348*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
1349*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1350*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1351*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1352*4bdc9457SAndroid Build Coastguard Worker         .m(4)
1353*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1354*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1355*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1356*4bdc9457SAndroid Build Coastguard Worker     }
1357*4bdc9457SAndroid Build Coastguard Worker   }
1358*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,k_div_4_subtile)1359*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, k_div_4_subtile) {
1360*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
1361*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1362*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
1363*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1364*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
1365*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1366*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1367*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1368*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1369*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1370*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1371*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1372*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1373*4bdc9457SAndroid Build Coastguard Worker         }
1374*4bdc9457SAndroid Build Coastguard Worker       }
1375*4bdc9457SAndroid Build Coastguard Worker     }
1376*4bdc9457SAndroid Build Coastguard Worker   }
1377*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_gt_8)1378*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_gt_8) {
1379*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1380*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1381*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1382*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1383*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1384*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1385*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1386*4bdc9457SAndroid Build Coastguard Worker           .m(4)
1387*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1388*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1389*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1390*4bdc9457SAndroid Build Coastguard Worker       }
1391*4bdc9457SAndroid Build Coastguard Worker     }
1392*4bdc9457SAndroid Build Coastguard Worker   }
1393*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_gt_8_strided_cn)1394*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_gt_8_strided_cn) {
1395*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1396*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1397*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1398*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1399*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1400*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1401*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1402*4bdc9457SAndroid Build Coastguard Worker           .m(4)
1403*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1404*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1405*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
1406*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1407*4bdc9457SAndroid Build Coastguard Worker       }
1408*4bdc9457SAndroid Build Coastguard Worker     }
1409*4bdc9457SAndroid Build Coastguard Worker   }
1410*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_gt_8_subtile)1411*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_gt_8_subtile) {
1412*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1413*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1414*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
1415*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1416*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
1417*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1418*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1419*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1420*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1421*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1422*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1423*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1424*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1425*4bdc9457SAndroid Build Coastguard Worker         }
1426*4bdc9457SAndroid Build Coastguard Worker       }
1427*4bdc9457SAndroid Build Coastguard Worker     }
1428*4bdc9457SAndroid Build Coastguard Worker   }
1429*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_div_8)1430*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_div_8) {
1431*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1432*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1433*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1434*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1435*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1436*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1437*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1438*4bdc9457SAndroid Build Coastguard Worker           .m(4)
1439*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1440*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1441*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1442*4bdc9457SAndroid Build Coastguard Worker       }
1443*4bdc9457SAndroid Build Coastguard Worker     }
1444*4bdc9457SAndroid Build Coastguard Worker   }
1445*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_div_8_strided_cn)1446*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_div_8_strided_cn) {
1447*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1448*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1449*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1450*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1451*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1452*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1453*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1454*4bdc9457SAndroid Build Coastguard Worker           .m(4)
1455*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1456*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1457*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
1458*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1459*4bdc9457SAndroid Build Coastguard Worker       }
1460*4bdc9457SAndroid Build Coastguard Worker     }
1461*4bdc9457SAndroid Build Coastguard Worker   }
1462*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_div_8_subtile)1463*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_div_8_subtile) {
1464*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1465*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1466*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
1467*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1468*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
1469*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1470*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1471*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1472*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1473*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1474*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1475*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1476*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1477*4bdc9457SAndroid Build Coastguard Worker         }
1478*4bdc9457SAndroid Build Coastguard Worker       }
1479*4bdc9457SAndroid Build Coastguard Worker     }
1480*4bdc9457SAndroid Build Coastguard Worker   }
1481*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,small_kernel)1482*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, small_kernel) {
1483*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1484*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1485*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
1486*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1487*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1488*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1489*4bdc9457SAndroid Build Coastguard Worker         .m(4)
1490*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1491*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1492*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
1493*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1494*4bdc9457SAndroid Build Coastguard Worker     }
1495*4bdc9457SAndroid Build Coastguard Worker   }
1496*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,small_kernel_subtile)1497*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, small_kernel_subtile) {
1498*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1499*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1500*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
1501*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1502*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
1503*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1504*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1505*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1506*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1507*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1508*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1509*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
1510*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1511*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1512*4bdc9457SAndroid Build Coastguard Worker         }
1513*4bdc9457SAndroid Build Coastguard Worker       }
1514*4bdc9457SAndroid Build Coastguard Worker     }
1515*4bdc9457SAndroid Build Coastguard Worker   }
1516*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_gt_8_small_kernel)1517*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_gt_8_small_kernel) {
1518*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1519*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1520*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1521*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1522*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1523*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1524*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1525*4bdc9457SAndroid Build Coastguard Worker           .m(4)
1526*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1527*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1528*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1529*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1530*4bdc9457SAndroid Build Coastguard Worker       }
1531*4bdc9457SAndroid Build Coastguard Worker     }
1532*4bdc9457SAndroid Build Coastguard Worker   }
1533*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,n_div_8_small_kernel)1534*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, n_div_8_small_kernel) {
1535*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1536*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1537*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1538*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1539*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1540*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1541*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1542*4bdc9457SAndroid Build Coastguard Worker           .m(4)
1543*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1544*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1545*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1546*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1547*4bdc9457SAndroid Build Coastguard Worker       }
1548*4bdc9457SAndroid Build Coastguard Worker     }
1549*4bdc9457SAndroid Build Coastguard Worker   }
1550*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,strided_cm_subtile)1551*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, strided_cm_subtile) {
1552*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1553*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1554*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
1555*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1556*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
1557*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1558*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1559*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1560*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1561*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1562*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1563*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
1564*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1565*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1566*4bdc9457SAndroid Build Coastguard Worker         }
1567*4bdc9457SAndroid Build Coastguard Worker       }
1568*4bdc9457SAndroid Build Coastguard Worker     }
1569*4bdc9457SAndroid Build Coastguard Worker   }
1570*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,a_offset)1571*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, a_offset) {
1572*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1573*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1574*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
1575*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1576*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1577*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1578*4bdc9457SAndroid Build Coastguard Worker         .m(4)
1579*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1580*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1581*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
1582*4bdc9457SAndroid Build Coastguard Worker         .a_offset(83)
1583*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1584*4bdc9457SAndroid Build Coastguard Worker     }
1585*4bdc9457SAndroid Build Coastguard Worker   }
1586*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,zero)1587*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, zero) {
1588*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1589*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 4; mz++) {
1590*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1591*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
1592*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1593*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1594*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1595*4bdc9457SAndroid Build Coastguard Worker           .m(4)
1596*4bdc9457SAndroid Build Coastguard Worker           .n(8)
1597*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1598*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1599*4bdc9457SAndroid Build Coastguard Worker           .a_offset(83)
1600*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
1601*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1602*4bdc9457SAndroid Build Coastguard Worker       }
1603*4bdc9457SAndroid Build Coastguard Worker     }
1604*4bdc9457SAndroid Build Coastguard Worker   }
1605*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT,strided_cm)1606*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMSIMD_SPLAT, strided_cm) {
1607*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
1608*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
1609*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
1610*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
1611*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
1612*4bdc9457SAndroid Build Coastguard Worker       .m(4)
1613*4bdc9457SAndroid Build Coastguard Worker       .n(8)
1614*4bdc9457SAndroid Build Coastguard Worker       .k(4)
1615*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
1616*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8__wasmsimd_splat);
1617*4bdc9457SAndroid Build Coastguard Worker   }
1618*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
1619*4bdc9457SAndroid Build Coastguard Worker 
1620*4bdc9457SAndroid Build Coastguard Worker 
1621*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_eq_4)1622*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_eq_4) {
1623*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
1624*4bdc9457SAndroid Build Coastguard Worker       .mr(5)
1625*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
1626*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
1627*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
1628*4bdc9457SAndroid Build Coastguard Worker       .m(5)
1629*4bdc9457SAndroid Build Coastguard Worker       .n(8)
1630*4bdc9457SAndroid Build Coastguard Worker       .k(4)
1631*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1632*4bdc9457SAndroid Build Coastguard Worker   }
1633*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,strided_cn)1634*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, strided_cn) {
1635*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
1636*4bdc9457SAndroid Build Coastguard Worker       .mr(5)
1637*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
1638*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
1639*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
1640*4bdc9457SAndroid Build Coastguard Worker       .m(5)
1641*4bdc9457SAndroid Build Coastguard Worker       .n(8)
1642*4bdc9457SAndroid Build Coastguard Worker       .k(4)
1643*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
1644*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1645*4bdc9457SAndroid Build Coastguard Worker   }
1646*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_eq_4_subtile)1647*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_eq_4_subtile) {
1648*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
1649*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 5; m++) {
1650*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1651*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
1652*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1653*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1654*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1655*4bdc9457SAndroid Build Coastguard Worker           .m(m)
1656*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1657*4bdc9457SAndroid Build Coastguard Worker           .k(4)
1658*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
1659*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1660*4bdc9457SAndroid Build Coastguard Worker       }
1661*4bdc9457SAndroid Build Coastguard Worker     }
1662*4bdc9457SAndroid Build Coastguard Worker   }
1663*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_eq_4_subtile_m)1664*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_eq_4_subtile_m) {
1665*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 5; m++) {
1666*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1667*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
1668*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1669*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1670*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1671*4bdc9457SAndroid Build Coastguard Worker         .m(m)
1672*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1673*4bdc9457SAndroid Build Coastguard Worker         .k(4)
1674*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
1675*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1676*4bdc9457SAndroid Build Coastguard Worker     }
1677*4bdc9457SAndroid Build Coastguard Worker   }
1678*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_eq_4_subtile_n)1679*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_eq_4_subtile_n) {
1680*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
1681*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1682*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
1683*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1684*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1685*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1686*4bdc9457SAndroid Build Coastguard Worker         .m(5)
1687*4bdc9457SAndroid Build Coastguard Worker         .n(n)
1688*4bdc9457SAndroid Build Coastguard Worker         .k(4)
1689*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
1690*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1691*4bdc9457SAndroid Build Coastguard Worker     }
1692*4bdc9457SAndroid Build Coastguard Worker   }
1693*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_lt_4)1694*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_lt_4) {
1695*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
1696*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1697*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
1698*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1699*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1700*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1701*4bdc9457SAndroid Build Coastguard Worker         .m(5)
1702*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1703*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1704*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1705*4bdc9457SAndroid Build Coastguard Worker     }
1706*4bdc9457SAndroid Build Coastguard Worker   }
1707*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_lt_4_subtile)1708*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_lt_4_subtile) {
1709*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
1710*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1711*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
1712*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1713*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
1714*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1715*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1716*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1717*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1718*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1719*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1720*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1721*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1722*4bdc9457SAndroid Build Coastguard Worker         }
1723*4bdc9457SAndroid Build Coastguard Worker       }
1724*4bdc9457SAndroid Build Coastguard Worker     }
1725*4bdc9457SAndroid Build Coastguard Worker   }
1726*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_gt_4)1727*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_gt_4) {
1728*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
1729*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1730*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
1731*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1732*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1733*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1734*4bdc9457SAndroid Build Coastguard Worker         .m(5)
1735*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1736*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1737*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1738*4bdc9457SAndroid Build Coastguard Worker     }
1739*4bdc9457SAndroid Build Coastguard Worker   }
1740*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_gt_4_subtile)1741*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_gt_4_subtile) {
1742*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
1743*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1744*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
1745*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1746*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
1747*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1748*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1749*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1750*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1751*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1752*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1753*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1754*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1755*4bdc9457SAndroid Build Coastguard Worker         }
1756*4bdc9457SAndroid Build Coastguard Worker       }
1757*4bdc9457SAndroid Build Coastguard Worker     }
1758*4bdc9457SAndroid Build Coastguard Worker   }
1759*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_div_4)1760*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_div_4) {
1761*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
1762*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1763*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
1764*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1765*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1766*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1767*4bdc9457SAndroid Build Coastguard Worker         .m(5)
1768*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1769*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1770*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1771*4bdc9457SAndroid Build Coastguard Worker     }
1772*4bdc9457SAndroid Build Coastguard Worker   }
1773*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,k_div_4_subtile)1774*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, k_div_4_subtile) {
1775*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
1776*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1777*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
1778*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1779*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
1780*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1781*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1782*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1783*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1784*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1785*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1786*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1787*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1788*4bdc9457SAndroid Build Coastguard Worker         }
1789*4bdc9457SAndroid Build Coastguard Worker       }
1790*4bdc9457SAndroid Build Coastguard Worker     }
1791*4bdc9457SAndroid Build Coastguard Worker   }
1792*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_gt_8)1793*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_gt_8) {
1794*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1795*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1796*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1797*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
1798*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1799*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1800*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1801*4bdc9457SAndroid Build Coastguard Worker           .m(5)
1802*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1803*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1804*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1805*4bdc9457SAndroid Build Coastguard Worker       }
1806*4bdc9457SAndroid Build Coastguard Worker     }
1807*4bdc9457SAndroid Build Coastguard Worker   }
1808*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_gt_8_strided_cn)1809*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_gt_8_strided_cn) {
1810*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1811*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1812*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1813*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
1814*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1815*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1816*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1817*4bdc9457SAndroid Build Coastguard Worker           .m(5)
1818*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1819*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1820*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
1821*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1822*4bdc9457SAndroid Build Coastguard Worker       }
1823*4bdc9457SAndroid Build Coastguard Worker     }
1824*4bdc9457SAndroid Build Coastguard Worker   }
1825*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_gt_8_subtile)1826*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_gt_8_subtile) {
1827*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1828*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1829*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
1830*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1831*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
1832*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1833*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1834*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1835*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1836*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1837*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1838*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1839*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1840*4bdc9457SAndroid Build Coastguard Worker         }
1841*4bdc9457SAndroid Build Coastguard Worker       }
1842*4bdc9457SAndroid Build Coastguard Worker     }
1843*4bdc9457SAndroid Build Coastguard Worker   }
1844*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_div_8)1845*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_div_8) {
1846*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1847*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1848*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1849*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
1850*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1851*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1852*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1853*4bdc9457SAndroid Build Coastguard Worker           .m(5)
1854*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1855*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1856*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1857*4bdc9457SAndroid Build Coastguard Worker       }
1858*4bdc9457SAndroid Build Coastguard Worker     }
1859*4bdc9457SAndroid Build Coastguard Worker   }
1860*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_div_8_strided_cn)1861*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_div_8_strided_cn) {
1862*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1863*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1864*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1865*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
1866*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1867*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1868*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1869*4bdc9457SAndroid Build Coastguard Worker           .m(5)
1870*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1871*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1872*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
1873*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1874*4bdc9457SAndroid Build Coastguard Worker       }
1875*4bdc9457SAndroid Build Coastguard Worker     }
1876*4bdc9457SAndroid Build Coastguard Worker   }
1877*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_div_8_subtile)1878*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_div_8_subtile) {
1879*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1880*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1881*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
1882*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1883*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
1884*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1885*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1886*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1887*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1888*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1889*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1890*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1891*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1892*4bdc9457SAndroid Build Coastguard Worker         }
1893*4bdc9457SAndroid Build Coastguard Worker       }
1894*4bdc9457SAndroid Build Coastguard Worker     }
1895*4bdc9457SAndroid Build Coastguard Worker   }
1896*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,small_kernel)1897*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, small_kernel) {
1898*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1899*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1900*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
1901*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1902*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1903*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1904*4bdc9457SAndroid Build Coastguard Worker         .m(5)
1905*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1906*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1907*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
1908*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1909*4bdc9457SAndroid Build Coastguard Worker     }
1910*4bdc9457SAndroid Build Coastguard Worker   }
1911*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,small_kernel_subtile)1912*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, small_kernel_subtile) {
1913*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1914*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1915*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
1916*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1917*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
1918*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1919*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1920*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1921*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1922*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1923*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1924*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
1925*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1926*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1927*4bdc9457SAndroid Build Coastguard Worker         }
1928*4bdc9457SAndroid Build Coastguard Worker       }
1929*4bdc9457SAndroid Build Coastguard Worker     }
1930*4bdc9457SAndroid Build Coastguard Worker   }
1931*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_gt_8_small_kernel)1932*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_gt_8_small_kernel) {
1933*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
1934*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1935*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1936*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
1937*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1938*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1939*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1940*4bdc9457SAndroid Build Coastguard Worker           .m(5)
1941*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1942*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1943*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1944*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1945*4bdc9457SAndroid Build Coastguard Worker       }
1946*4bdc9457SAndroid Build Coastguard Worker     }
1947*4bdc9457SAndroid Build Coastguard Worker   }
1948*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,n_div_8_small_kernel)1949*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, n_div_8_small_kernel) {
1950*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
1951*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
1952*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
1953*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
1954*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
1955*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
1956*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
1957*4bdc9457SAndroid Build Coastguard Worker           .m(5)
1958*4bdc9457SAndroid Build Coastguard Worker           .n(n)
1959*4bdc9457SAndroid Build Coastguard Worker           .k(k)
1960*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
1961*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1962*4bdc9457SAndroid Build Coastguard Worker       }
1963*4bdc9457SAndroid Build Coastguard Worker     }
1964*4bdc9457SAndroid Build Coastguard Worker   }
1965*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,strided_cm_subtile)1966*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, strided_cm_subtile) {
1967*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1968*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
1969*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
1970*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
1971*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
1972*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
1973*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
1974*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
1975*4bdc9457SAndroid Build Coastguard Worker             .m(m)
1976*4bdc9457SAndroid Build Coastguard Worker             .n(n)
1977*4bdc9457SAndroid Build Coastguard Worker             .k(k)
1978*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
1979*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
1980*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1981*4bdc9457SAndroid Build Coastguard Worker         }
1982*4bdc9457SAndroid Build Coastguard Worker       }
1983*4bdc9457SAndroid Build Coastguard Worker     }
1984*4bdc9457SAndroid Build Coastguard Worker   }
1985*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,a_offset)1986*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, a_offset) {
1987*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
1988*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
1989*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
1990*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
1991*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
1992*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
1993*4bdc9457SAndroid Build Coastguard Worker         .m(5)
1994*4bdc9457SAndroid Build Coastguard Worker         .n(8)
1995*4bdc9457SAndroid Build Coastguard Worker         .k(k)
1996*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
1997*4bdc9457SAndroid Build Coastguard Worker         .a_offset(103)
1998*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
1999*4bdc9457SAndroid Build Coastguard Worker     }
2000*4bdc9457SAndroid Build Coastguard Worker   }
2001*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,zero)2002*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, zero) {
2003*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
2004*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 5; mz++) {
2005*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2006*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
2007*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2008*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2009*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2010*4bdc9457SAndroid Build Coastguard Worker           .m(5)
2011*4bdc9457SAndroid Build Coastguard Worker           .n(8)
2012*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2013*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
2014*4bdc9457SAndroid Build Coastguard Worker           .a_offset(103)
2015*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
2016*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
2017*4bdc9457SAndroid Build Coastguard Worker       }
2018*4bdc9457SAndroid Build Coastguard Worker     }
2019*4bdc9457SAndroid Build Coastguard Worker   }
2020*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT,strided_cm)2021*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMSIMD_SPLAT, strided_cm) {
2022*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2023*4bdc9457SAndroid Build Coastguard Worker       .mr(5)
2024*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2025*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2026*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
2027*4bdc9457SAndroid Build Coastguard Worker       .m(5)
2028*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2029*4bdc9457SAndroid Build Coastguard Worker       .k(4)
2030*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
2031*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_5x8__wasmsimd_splat);
2032*4bdc9457SAndroid Build Coastguard Worker   }
2033*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
2034*4bdc9457SAndroid Build Coastguard Worker 
2035*4bdc9457SAndroid Build Coastguard Worker 
2036*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,k_eq_1)2037*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, k_eq_1) {
2038*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2039*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
2040*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2041*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2042*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
2043*4bdc9457SAndroid Build Coastguard Worker       .m(6)
2044*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2045*4bdc9457SAndroid Build Coastguard Worker       .k(1)
2046*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2047*4bdc9457SAndroid Build Coastguard Worker   }
2048*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,strided_cn)2049*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, strided_cn) {
2050*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2051*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
2052*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2053*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2054*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
2055*4bdc9457SAndroid Build Coastguard Worker       .m(6)
2056*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2057*4bdc9457SAndroid Build Coastguard Worker       .k(1)
2058*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
2059*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2060*4bdc9457SAndroid Build Coastguard Worker   }
2061*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,k_eq_1_subtile)2062*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, k_eq_1_subtile) {
2063*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
2064*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 6; m++) {
2065*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2066*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2067*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2068*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2069*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2070*4bdc9457SAndroid Build Coastguard Worker           .m(m)
2071*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2072*4bdc9457SAndroid Build Coastguard Worker           .k(1)
2073*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
2074*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2075*4bdc9457SAndroid Build Coastguard Worker       }
2076*4bdc9457SAndroid Build Coastguard Worker     }
2077*4bdc9457SAndroid Build Coastguard Worker   }
2078*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,k_eq_1_subtile_m)2079*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, k_eq_1_subtile_m) {
2080*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 6; m++) {
2081*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2082*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2083*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2084*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2085*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2086*4bdc9457SAndroid Build Coastguard Worker         .m(m)
2087*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2088*4bdc9457SAndroid Build Coastguard Worker         .k(1)
2089*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
2090*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2091*4bdc9457SAndroid Build Coastguard Worker     }
2092*4bdc9457SAndroid Build Coastguard Worker   }
2093*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,k_eq_1_subtile_n)2094*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, k_eq_1_subtile_n) {
2095*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
2096*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2097*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2098*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2099*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2100*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2101*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2102*4bdc9457SAndroid Build Coastguard Worker         .n(n)
2103*4bdc9457SAndroid Build Coastguard Worker         .k(1)
2104*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
2105*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2106*4bdc9457SAndroid Build Coastguard Worker     }
2107*4bdc9457SAndroid Build Coastguard Worker   }
2108*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,k_gt_1)2109*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, k_gt_1) {
2110*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
2111*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2112*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2113*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2114*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2115*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2116*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2117*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2118*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2119*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2120*4bdc9457SAndroid Build Coastguard Worker     }
2121*4bdc9457SAndroid Build Coastguard Worker   }
2122*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,k_gt_1_subtile)2123*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, k_gt_1_subtile) {
2124*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
2125*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2126*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2127*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2128*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2129*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2130*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2131*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
2132*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2133*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2134*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2135*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2136*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2137*4bdc9457SAndroid Build Coastguard Worker         }
2138*4bdc9457SAndroid Build Coastguard Worker       }
2139*4bdc9457SAndroid Build Coastguard Worker     }
2140*4bdc9457SAndroid Build Coastguard Worker   }
2141*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_gt_8)2142*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_gt_8) {
2143*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2144*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2145*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2146*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2147*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2148*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2149*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2150*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2151*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2152*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2153*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2154*4bdc9457SAndroid Build Coastguard Worker       }
2155*4bdc9457SAndroid Build Coastguard Worker     }
2156*4bdc9457SAndroid Build Coastguard Worker   }
2157*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_gt_8_strided_cn)2158*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_gt_8_strided_cn) {
2159*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2160*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2161*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2162*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2163*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2164*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2165*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2166*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2167*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2168*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2169*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
2170*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2171*4bdc9457SAndroid Build Coastguard Worker       }
2172*4bdc9457SAndroid Build Coastguard Worker     }
2173*4bdc9457SAndroid Build Coastguard Worker   }
2174*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_gt_8_subtile)2175*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_gt_8_subtile) {
2176*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2177*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2178*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2179*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2180*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2181*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2182*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2183*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
2184*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2185*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2186*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2187*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2188*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2189*4bdc9457SAndroid Build Coastguard Worker         }
2190*4bdc9457SAndroid Build Coastguard Worker       }
2191*4bdc9457SAndroid Build Coastguard Worker     }
2192*4bdc9457SAndroid Build Coastguard Worker   }
2193*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_div_8)2194*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_div_8) {
2195*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2196*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2197*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2198*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2199*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2200*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2201*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2202*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2203*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2204*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2205*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2206*4bdc9457SAndroid Build Coastguard Worker       }
2207*4bdc9457SAndroid Build Coastguard Worker     }
2208*4bdc9457SAndroid Build Coastguard Worker   }
2209*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_div_8_strided_cn)2210*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_div_8_strided_cn) {
2211*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2212*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2213*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2214*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2215*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2216*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2217*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2218*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2219*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2220*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2221*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
2222*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2223*4bdc9457SAndroid Build Coastguard Worker       }
2224*4bdc9457SAndroid Build Coastguard Worker     }
2225*4bdc9457SAndroid Build Coastguard Worker   }
2226*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_div_8_subtile)2227*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_div_8_subtile) {
2228*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2229*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2230*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2231*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2232*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2233*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2234*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2235*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
2236*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2237*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2238*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2239*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2240*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2241*4bdc9457SAndroid Build Coastguard Worker         }
2242*4bdc9457SAndroid Build Coastguard Worker       }
2243*4bdc9457SAndroid Build Coastguard Worker     }
2244*4bdc9457SAndroid Build Coastguard Worker   }
2245*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,small_kernel)2246*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, small_kernel) {
2247*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
2248*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2249*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2250*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2251*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2252*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2253*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2254*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2255*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2256*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
2257*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2258*4bdc9457SAndroid Build Coastguard Worker     }
2259*4bdc9457SAndroid Build Coastguard Worker   }
2260*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,small_kernel_subtile)2261*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, small_kernel_subtile) {
2262*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
2263*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2264*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2265*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2266*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2267*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2268*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2269*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
2270*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2271*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2272*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2273*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
2274*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2275*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2276*4bdc9457SAndroid Build Coastguard Worker         }
2277*4bdc9457SAndroid Build Coastguard Worker       }
2278*4bdc9457SAndroid Build Coastguard Worker     }
2279*4bdc9457SAndroid Build Coastguard Worker   }
2280*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_gt_8_small_kernel)2281*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_gt_8_small_kernel) {
2282*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2283*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2284*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2285*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2286*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2287*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2288*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2289*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2290*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2291*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2292*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
2293*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2294*4bdc9457SAndroid Build Coastguard Worker       }
2295*4bdc9457SAndroid Build Coastguard Worker     }
2296*4bdc9457SAndroid Build Coastguard Worker   }
2297*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,n_div_8_small_kernel)2298*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, n_div_8_small_kernel) {
2299*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2300*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2301*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2302*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2303*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2304*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2305*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2306*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2307*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2308*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2309*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
2310*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2311*4bdc9457SAndroid Build Coastguard Worker       }
2312*4bdc9457SAndroid Build Coastguard Worker     }
2313*4bdc9457SAndroid Build Coastguard Worker   }
2314*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,strided_cm_subtile)2315*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, strided_cm_subtile) {
2316*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
2317*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2318*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2319*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2320*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2321*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2322*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2323*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
2324*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2325*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2326*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2327*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
2328*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2329*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2330*4bdc9457SAndroid Build Coastguard Worker         }
2331*4bdc9457SAndroid Build Coastguard Worker       }
2332*4bdc9457SAndroid Build Coastguard Worker     }
2333*4bdc9457SAndroid Build Coastguard Worker   }
2334*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,a_offset)2335*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, a_offset) {
2336*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
2337*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2338*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2339*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2340*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2341*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2342*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2343*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2344*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2345*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
2346*4bdc9457SAndroid Build Coastguard Worker         .a_offset(37)
2347*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2348*4bdc9457SAndroid Build Coastguard Worker     }
2349*4bdc9457SAndroid Build Coastguard Worker   }
2350*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,zero)2351*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, zero) {
2352*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
2353*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 6; mz++) {
2354*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2355*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2356*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2357*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2358*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2359*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2360*4bdc9457SAndroid Build Coastguard Worker           .n(8)
2361*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2362*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
2363*4bdc9457SAndroid Build Coastguard Worker           .a_offset(37)
2364*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
2365*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2366*4bdc9457SAndroid Build Coastguard Worker       }
2367*4bdc9457SAndroid Build Coastguard Worker     }
2368*4bdc9457SAndroid Build Coastguard Worker   }
2369*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT,strided_cm)2370*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMSIMD_LOADSPLAT, strided_cm) {
2371*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2372*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
2373*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2374*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2375*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
2376*4bdc9457SAndroid Build Coastguard Worker       .m(6)
2377*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2378*4bdc9457SAndroid Build Coastguard Worker       .k(1)
2379*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
2380*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8__wasmsimd_loadsplat);
2381*4bdc9457SAndroid Build Coastguard Worker   }
2382*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
2383*4bdc9457SAndroid Build Coastguard Worker 
2384*4bdc9457SAndroid Build Coastguard Worker 
2385*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_eq_4)2386*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_eq_4) {
2387*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2388*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
2389*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2390*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2391*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
2392*4bdc9457SAndroid Build Coastguard Worker       .m(6)
2393*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2394*4bdc9457SAndroid Build Coastguard Worker       .k(4)
2395*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2396*4bdc9457SAndroid Build Coastguard Worker   }
2397*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,strided_cn)2398*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, strided_cn) {
2399*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2400*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
2401*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2402*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2403*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
2404*4bdc9457SAndroid Build Coastguard Worker       .m(6)
2405*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2406*4bdc9457SAndroid Build Coastguard Worker       .k(4)
2407*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
2408*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2409*4bdc9457SAndroid Build Coastguard Worker   }
2410*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_eq_4_subtile)2411*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_eq_4_subtile) {
2412*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
2413*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 6; m++) {
2414*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2415*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2416*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2417*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2418*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2419*4bdc9457SAndroid Build Coastguard Worker           .m(m)
2420*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2421*4bdc9457SAndroid Build Coastguard Worker           .k(4)
2422*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
2423*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2424*4bdc9457SAndroid Build Coastguard Worker       }
2425*4bdc9457SAndroid Build Coastguard Worker     }
2426*4bdc9457SAndroid Build Coastguard Worker   }
2427*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_eq_4_subtile_m)2428*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_eq_4_subtile_m) {
2429*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 6; m++) {
2430*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2431*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2432*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2433*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2434*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
2435*4bdc9457SAndroid Build Coastguard Worker         .m(m)
2436*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2437*4bdc9457SAndroid Build Coastguard Worker         .k(4)
2438*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
2439*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2440*4bdc9457SAndroid Build Coastguard Worker     }
2441*4bdc9457SAndroid Build Coastguard Worker   }
2442*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_eq_4_subtile_n)2443*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_eq_4_subtile_n) {
2444*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
2445*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2446*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2447*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2448*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2449*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
2450*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2451*4bdc9457SAndroid Build Coastguard Worker         .n(n)
2452*4bdc9457SAndroid Build Coastguard Worker         .k(4)
2453*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
2454*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2455*4bdc9457SAndroid Build Coastguard Worker     }
2456*4bdc9457SAndroid Build Coastguard Worker   }
2457*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_lt_4)2458*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_lt_4) {
2459*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
2460*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2461*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2462*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2463*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2464*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
2465*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2466*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2467*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2468*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2469*4bdc9457SAndroid Build Coastguard Worker     }
2470*4bdc9457SAndroid Build Coastguard Worker   }
2471*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_lt_4_subtile)2472*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_lt_4_subtile) {
2473*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
2474*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2475*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2476*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2477*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2478*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2479*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2480*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
2481*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2482*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2483*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2484*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2485*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2486*4bdc9457SAndroid Build Coastguard Worker         }
2487*4bdc9457SAndroid Build Coastguard Worker       }
2488*4bdc9457SAndroid Build Coastguard Worker     }
2489*4bdc9457SAndroid Build Coastguard Worker   }
2490*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_gt_4)2491*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_gt_4) {
2492*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
2493*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2494*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2495*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2496*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2497*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
2498*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2499*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2500*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2501*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2502*4bdc9457SAndroid Build Coastguard Worker     }
2503*4bdc9457SAndroid Build Coastguard Worker   }
2504*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_gt_4_subtile)2505*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_gt_4_subtile) {
2506*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
2507*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2508*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2509*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2510*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2511*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2512*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2513*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
2514*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2515*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2516*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2517*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2518*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2519*4bdc9457SAndroid Build Coastguard Worker         }
2520*4bdc9457SAndroid Build Coastguard Worker       }
2521*4bdc9457SAndroid Build Coastguard Worker     }
2522*4bdc9457SAndroid Build Coastguard Worker   }
2523*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_div_4)2524*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_div_4) {
2525*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
2526*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2527*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2528*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2529*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2530*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
2531*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2532*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2533*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2534*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2535*4bdc9457SAndroid Build Coastguard Worker     }
2536*4bdc9457SAndroid Build Coastguard Worker   }
2537*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,k_div_4_subtile)2538*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, k_div_4_subtile) {
2539*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
2540*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2541*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2542*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2543*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2544*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2545*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2546*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
2547*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2548*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2549*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2550*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2551*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2552*4bdc9457SAndroid Build Coastguard Worker         }
2553*4bdc9457SAndroid Build Coastguard Worker       }
2554*4bdc9457SAndroid Build Coastguard Worker     }
2555*4bdc9457SAndroid Build Coastguard Worker   }
2556*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_gt_8)2557*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_gt_8) {
2558*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2559*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2560*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2561*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2562*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2563*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2564*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2565*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2566*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2567*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2568*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2569*4bdc9457SAndroid Build Coastguard Worker       }
2570*4bdc9457SAndroid Build Coastguard Worker     }
2571*4bdc9457SAndroid Build Coastguard Worker   }
2572*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_gt_8_strided_cn)2573*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_gt_8_strided_cn) {
2574*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2575*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2576*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2577*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2578*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2579*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2580*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2581*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2582*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2583*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2584*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
2585*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2586*4bdc9457SAndroid Build Coastguard Worker       }
2587*4bdc9457SAndroid Build Coastguard Worker     }
2588*4bdc9457SAndroid Build Coastguard Worker   }
2589*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_gt_8_subtile)2590*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_gt_8_subtile) {
2591*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2592*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2593*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2594*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2595*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2596*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2597*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2598*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
2599*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2600*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2601*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2602*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2603*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2604*4bdc9457SAndroid Build Coastguard Worker         }
2605*4bdc9457SAndroid Build Coastguard Worker       }
2606*4bdc9457SAndroid Build Coastguard Worker     }
2607*4bdc9457SAndroid Build Coastguard Worker   }
2608*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_div_8)2609*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_div_8) {
2610*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2611*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2612*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2613*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2614*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2615*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2616*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2617*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2618*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2619*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2620*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2621*4bdc9457SAndroid Build Coastguard Worker       }
2622*4bdc9457SAndroid Build Coastguard Worker     }
2623*4bdc9457SAndroid Build Coastguard Worker   }
2624*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_div_8_strided_cn)2625*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_div_8_strided_cn) {
2626*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2627*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2628*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2629*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2630*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2631*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2632*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2633*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2634*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2635*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2636*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
2637*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2638*4bdc9457SAndroid Build Coastguard Worker       }
2639*4bdc9457SAndroid Build Coastguard Worker     }
2640*4bdc9457SAndroid Build Coastguard Worker   }
2641*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_div_8_subtile)2642*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_div_8_subtile) {
2643*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2644*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2645*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2646*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2647*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2648*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2649*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2650*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
2651*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2652*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2653*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2654*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2655*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2656*4bdc9457SAndroid Build Coastguard Worker         }
2657*4bdc9457SAndroid Build Coastguard Worker       }
2658*4bdc9457SAndroid Build Coastguard Worker     }
2659*4bdc9457SAndroid Build Coastguard Worker   }
2660*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,small_kernel)2661*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, small_kernel) {
2662*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
2663*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2664*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2665*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2666*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2667*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
2668*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2669*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2670*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2671*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
2672*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2673*4bdc9457SAndroid Build Coastguard Worker     }
2674*4bdc9457SAndroid Build Coastguard Worker   }
2675*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,small_kernel_subtile)2676*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, small_kernel_subtile) {
2677*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
2678*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2679*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2680*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2681*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2682*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2683*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2684*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
2685*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2686*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2687*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2688*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
2689*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2690*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2691*4bdc9457SAndroid Build Coastguard Worker         }
2692*4bdc9457SAndroid Build Coastguard Worker       }
2693*4bdc9457SAndroid Build Coastguard Worker     }
2694*4bdc9457SAndroid Build Coastguard Worker   }
2695*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_gt_8_small_kernel)2696*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_gt_8_small_kernel) {
2697*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2698*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2699*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2700*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2701*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2702*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2703*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2704*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2705*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2706*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2707*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
2708*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2709*4bdc9457SAndroid Build Coastguard Worker       }
2710*4bdc9457SAndroid Build Coastguard Worker     }
2711*4bdc9457SAndroid Build Coastguard Worker   }
2712*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,n_div_8_small_kernel)2713*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, n_div_8_small_kernel) {
2714*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2715*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
2716*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2717*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2718*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2719*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2720*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2721*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2722*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2723*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2724*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
2725*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2726*4bdc9457SAndroid Build Coastguard Worker       }
2727*4bdc9457SAndroid Build Coastguard Worker     }
2728*4bdc9457SAndroid Build Coastguard Worker   }
2729*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,strided_cm_subtile)2730*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, strided_cm_subtile) {
2731*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
2732*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2733*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
2734*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2735*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
2736*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2737*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2738*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
2739*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2740*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2741*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2742*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
2743*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2744*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2745*4bdc9457SAndroid Build Coastguard Worker         }
2746*4bdc9457SAndroid Build Coastguard Worker       }
2747*4bdc9457SAndroid Build Coastguard Worker     }
2748*4bdc9457SAndroid Build Coastguard Worker   }
2749*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,a_offset)2750*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, a_offset) {
2751*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
2752*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2753*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
2754*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2755*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2756*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
2757*4bdc9457SAndroid Build Coastguard Worker         .m(6)
2758*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2759*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2760*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
2761*4bdc9457SAndroid Build Coastguard Worker         .a_offset(127)
2762*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2763*4bdc9457SAndroid Build Coastguard Worker     }
2764*4bdc9457SAndroid Build Coastguard Worker   }
2765*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,zero)2766*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, zero) {
2767*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
2768*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 6; mz++) {
2769*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2770*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
2771*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2772*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2773*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
2774*4bdc9457SAndroid Build Coastguard Worker           .m(6)
2775*4bdc9457SAndroid Build Coastguard Worker           .n(8)
2776*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2777*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
2778*4bdc9457SAndroid Build Coastguard Worker           .a_offset(127)
2779*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
2780*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2781*4bdc9457SAndroid Build Coastguard Worker       }
2782*4bdc9457SAndroid Build Coastguard Worker     }
2783*4bdc9457SAndroid Build Coastguard Worker   }
2784*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8S4__WASMSIMD,strided_cm)2785*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8S4__WASMSIMD, strided_cm) {
2786*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2787*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
2788*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2789*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2790*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
2791*4bdc9457SAndroid Build Coastguard Worker       .m(6)
2792*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2793*4bdc9457SAndroid Build Coastguard Worker       .k(4)
2794*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
2795*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8s4__wasmsimd);
2796*4bdc9457SAndroid Build Coastguard Worker   }
2797*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
2798*4bdc9457SAndroid Build Coastguard Worker 
2799*4bdc9457SAndroid Build Coastguard Worker 
2800*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1)2801*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1) {
2802*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2803*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
2804*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2805*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2806*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
2807*4bdc9457SAndroid Build Coastguard Worker       .m(1)
2808*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2809*4bdc9457SAndroid Build Coastguard Worker       .k(1)
2810*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2811*4bdc9457SAndroid Build Coastguard Worker   }
2812*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cn)2813*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cn) {
2814*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
2815*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
2816*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
2817*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
2818*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
2819*4bdc9457SAndroid Build Coastguard Worker       .m(1)
2820*4bdc9457SAndroid Build Coastguard Worker       .n(8)
2821*4bdc9457SAndroid Build Coastguard Worker       .k(1)
2822*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
2823*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2824*4bdc9457SAndroid Build Coastguard Worker   }
2825*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile)2826*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile) {
2827*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
2828*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 1; m++) {
2829*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2830*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
2831*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2832*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2833*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2834*4bdc9457SAndroid Build Coastguard Worker           .m(m)
2835*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2836*4bdc9457SAndroid Build Coastguard Worker           .k(1)
2837*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
2838*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2839*4bdc9457SAndroid Build Coastguard Worker       }
2840*4bdc9457SAndroid Build Coastguard Worker     }
2841*4bdc9457SAndroid Build Coastguard Worker   }
2842*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_m)2843*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_m) {
2844*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 1; m++) {
2845*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2846*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
2847*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2848*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2849*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2850*4bdc9457SAndroid Build Coastguard Worker         .m(m)
2851*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2852*4bdc9457SAndroid Build Coastguard Worker         .k(1)
2853*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
2854*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2855*4bdc9457SAndroid Build Coastguard Worker     }
2856*4bdc9457SAndroid Build Coastguard Worker   }
2857*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_n)2858*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_n) {
2859*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
2860*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2861*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
2862*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2863*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2864*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2865*4bdc9457SAndroid Build Coastguard Worker         .m(1)
2866*4bdc9457SAndroid Build Coastguard Worker         .n(n)
2867*4bdc9457SAndroid Build Coastguard Worker         .k(1)
2868*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
2869*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2870*4bdc9457SAndroid Build Coastguard Worker     }
2871*4bdc9457SAndroid Build Coastguard Worker   }
2872*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1)2873*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1) {
2874*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
2875*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
2876*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
2877*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
2878*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
2879*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
2880*4bdc9457SAndroid Build Coastguard Worker         .m(1)
2881*4bdc9457SAndroid Build Coastguard Worker         .n(8)
2882*4bdc9457SAndroid Build Coastguard Worker         .k(k)
2883*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2884*4bdc9457SAndroid Build Coastguard Worker     }
2885*4bdc9457SAndroid Build Coastguard Worker   }
2886*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1_subtile)2887*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1_subtile) {
2888*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
2889*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
2890*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
2891*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2892*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
2893*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2894*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2895*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
2896*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2897*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2898*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2899*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2900*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2901*4bdc9457SAndroid Build Coastguard Worker         }
2902*4bdc9457SAndroid Build Coastguard Worker       }
2903*4bdc9457SAndroid Build Coastguard Worker     }
2904*4bdc9457SAndroid Build Coastguard Worker   }
2905*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8)2906*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8) {
2907*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2908*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2909*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2910*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
2911*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2912*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2913*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2914*4bdc9457SAndroid Build Coastguard Worker           .m(1)
2915*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2916*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2917*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2918*4bdc9457SAndroid Build Coastguard Worker       }
2919*4bdc9457SAndroid Build Coastguard Worker     }
2920*4bdc9457SAndroid Build Coastguard Worker   }
2921*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_strided_cn)2922*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_strided_cn) {
2923*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2924*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2925*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2926*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
2927*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2928*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2929*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2930*4bdc9457SAndroid Build Coastguard Worker           .m(1)
2931*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2932*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2933*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
2934*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2935*4bdc9457SAndroid Build Coastguard Worker       }
2936*4bdc9457SAndroid Build Coastguard Worker     }
2937*4bdc9457SAndroid Build Coastguard Worker   }
2938*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_subtile)2939*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_subtile) {
2940*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
2941*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2942*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
2943*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2944*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
2945*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2946*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2947*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
2948*4bdc9457SAndroid Build Coastguard Worker             .m(m)
2949*4bdc9457SAndroid Build Coastguard Worker             .n(n)
2950*4bdc9457SAndroid Build Coastguard Worker             .k(k)
2951*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
2952*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2953*4bdc9457SAndroid Build Coastguard Worker         }
2954*4bdc9457SAndroid Build Coastguard Worker       }
2955*4bdc9457SAndroid Build Coastguard Worker     }
2956*4bdc9457SAndroid Build Coastguard Worker   }
2957*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8)2958*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8) {
2959*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2960*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2961*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2962*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
2963*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2964*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2965*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2966*4bdc9457SAndroid Build Coastguard Worker           .m(1)
2967*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2968*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2969*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2970*4bdc9457SAndroid Build Coastguard Worker       }
2971*4bdc9457SAndroid Build Coastguard Worker     }
2972*4bdc9457SAndroid Build Coastguard Worker   }
2973*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_strided_cn)2974*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_strided_cn) {
2975*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2976*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2977*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
2978*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
2979*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
2980*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
2981*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
2982*4bdc9457SAndroid Build Coastguard Worker           .m(1)
2983*4bdc9457SAndroid Build Coastguard Worker           .n(n)
2984*4bdc9457SAndroid Build Coastguard Worker           .k(k)
2985*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
2986*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
2987*4bdc9457SAndroid Build Coastguard Worker       }
2988*4bdc9457SAndroid Build Coastguard Worker     }
2989*4bdc9457SAndroid Build Coastguard Worker   }
2990*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_subtile)2991*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_subtile) {
2992*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
2993*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
2994*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
2995*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
2996*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
2997*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
2998*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
2999*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3000*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3001*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3002*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3003*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3004*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3005*4bdc9457SAndroid Build Coastguard Worker         }
3006*4bdc9457SAndroid Build Coastguard Worker       }
3007*4bdc9457SAndroid Build Coastguard Worker     }
3008*4bdc9457SAndroid Build Coastguard Worker   }
3009*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel)3010*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel) {
3011*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3012*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3013*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
3014*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3015*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3016*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3017*4bdc9457SAndroid Build Coastguard Worker         .m(1)
3018*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3019*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3020*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
3021*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3022*4bdc9457SAndroid Build Coastguard Worker     }
3023*4bdc9457SAndroid Build Coastguard Worker   }
3024*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel_subtile)3025*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel_subtile) {
3026*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3027*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3028*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
3029*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3030*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
3031*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3032*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3033*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3034*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3035*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3036*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3037*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
3038*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3039*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3040*4bdc9457SAndroid Build Coastguard Worker         }
3041*4bdc9457SAndroid Build Coastguard Worker       }
3042*4bdc9457SAndroid Build Coastguard Worker     }
3043*4bdc9457SAndroid Build Coastguard Worker   }
3044*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_small_kernel)3045*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_small_kernel) {
3046*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3047*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3048*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3049*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
3050*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3051*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3052*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3053*4bdc9457SAndroid Build Coastguard Worker           .m(1)
3054*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3055*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3056*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3057*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3058*4bdc9457SAndroid Build Coastguard Worker       }
3059*4bdc9457SAndroid Build Coastguard Worker     }
3060*4bdc9457SAndroid Build Coastguard Worker   }
3061*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_small_kernel)3062*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_small_kernel) {
3063*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3064*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3065*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3066*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
3067*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3068*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3069*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3070*4bdc9457SAndroid Build Coastguard Worker           .m(1)
3071*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3072*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3073*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3074*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3075*4bdc9457SAndroid Build Coastguard Worker       }
3076*4bdc9457SAndroid Build Coastguard Worker     }
3077*4bdc9457SAndroid Build Coastguard Worker   }
3078*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm_subtile)3079*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm_subtile) {
3080*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3081*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3082*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 1; m++) {
3083*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3084*4bdc9457SAndroid Build Coastguard Worker             .mr(1)
3085*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3086*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3087*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3088*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3089*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3090*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3091*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
3092*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3093*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3094*4bdc9457SAndroid Build Coastguard Worker         }
3095*4bdc9457SAndroid Build Coastguard Worker       }
3096*4bdc9457SAndroid Build Coastguard Worker     }
3097*4bdc9457SAndroid Build Coastguard Worker   }
3098*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,a_offset)3099*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, a_offset) {
3100*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3101*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3102*4bdc9457SAndroid Build Coastguard Worker         .mr(1)
3103*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3104*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3105*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3106*4bdc9457SAndroid Build Coastguard Worker         .m(1)
3107*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3108*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3109*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
3110*4bdc9457SAndroid Build Coastguard Worker         .a_offset(7)
3111*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3112*4bdc9457SAndroid Build Coastguard Worker     }
3113*4bdc9457SAndroid Build Coastguard Worker   }
3114*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,zero)3115*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, zero) {
3116*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3117*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 1; mz++) {
3118*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3119*4bdc9457SAndroid Build Coastguard Worker           .mr(1)
3120*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3121*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3122*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3123*4bdc9457SAndroid Build Coastguard Worker           .m(1)
3124*4bdc9457SAndroid Build Coastguard Worker           .n(8)
3125*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3126*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3127*4bdc9457SAndroid Build Coastguard Worker           .a_offset(7)
3128*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
3129*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3130*4bdc9457SAndroid Build Coastguard Worker       }
3131*4bdc9457SAndroid Build Coastguard Worker     }
3132*4bdc9457SAndroid Build Coastguard Worker   }
3133*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm)3134*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_1X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm) {
3135*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3136*4bdc9457SAndroid Build Coastguard Worker       .mr(1)
3137*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3138*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3139*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
3140*4bdc9457SAndroid Build Coastguard Worker       .m(1)
3141*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3142*4bdc9457SAndroid Build Coastguard Worker       .k(1)
3143*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
3144*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_1x8__wasmrelaxedsimd_fma_loadsplat);
3145*4bdc9457SAndroid Build Coastguard Worker   }
3146*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMRELAXEDSIMD
3147*4bdc9457SAndroid Build Coastguard Worker 
3148*4bdc9457SAndroid Build Coastguard Worker 
3149*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1)3150*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1) {
3151*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3152*4bdc9457SAndroid Build Coastguard Worker       .mr(3)
3153*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3154*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3155*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
3156*4bdc9457SAndroid Build Coastguard Worker       .m(3)
3157*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3158*4bdc9457SAndroid Build Coastguard Worker       .k(1)
3159*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3160*4bdc9457SAndroid Build Coastguard Worker   }
3161*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cn)3162*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cn) {
3163*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3164*4bdc9457SAndroid Build Coastguard Worker       .mr(3)
3165*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3166*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3167*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
3168*4bdc9457SAndroid Build Coastguard Worker       .m(3)
3169*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3170*4bdc9457SAndroid Build Coastguard Worker       .k(1)
3171*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
3172*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3173*4bdc9457SAndroid Build Coastguard Worker   }
3174*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile)3175*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile) {
3176*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
3177*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 3; m++) {
3178*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3179*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3180*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3181*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3182*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3183*4bdc9457SAndroid Build Coastguard Worker           .m(m)
3184*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3185*4bdc9457SAndroid Build Coastguard Worker           .k(1)
3186*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
3187*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3188*4bdc9457SAndroid Build Coastguard Worker       }
3189*4bdc9457SAndroid Build Coastguard Worker     }
3190*4bdc9457SAndroid Build Coastguard Worker   }
3191*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_m)3192*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_m) {
3193*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 3; m++) {
3194*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3195*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3196*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3197*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3198*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3199*4bdc9457SAndroid Build Coastguard Worker         .m(m)
3200*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3201*4bdc9457SAndroid Build Coastguard Worker         .k(1)
3202*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
3203*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3204*4bdc9457SAndroid Build Coastguard Worker     }
3205*4bdc9457SAndroid Build Coastguard Worker   }
3206*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_n)3207*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_n) {
3208*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
3209*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3210*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3211*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3212*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3213*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3214*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3215*4bdc9457SAndroid Build Coastguard Worker         .n(n)
3216*4bdc9457SAndroid Build Coastguard Worker         .k(1)
3217*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
3218*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3219*4bdc9457SAndroid Build Coastguard Worker     }
3220*4bdc9457SAndroid Build Coastguard Worker   }
3221*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1)3222*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1) {
3223*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
3224*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3225*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3226*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3227*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3228*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3229*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3230*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3231*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3232*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3233*4bdc9457SAndroid Build Coastguard Worker     }
3234*4bdc9457SAndroid Build Coastguard Worker   }
3235*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1_subtile)3236*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1_subtile) {
3237*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
3238*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3239*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3240*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3241*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3242*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3243*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3244*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3245*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3246*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3247*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3248*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3249*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3250*4bdc9457SAndroid Build Coastguard Worker         }
3251*4bdc9457SAndroid Build Coastguard Worker       }
3252*4bdc9457SAndroid Build Coastguard Worker     }
3253*4bdc9457SAndroid Build Coastguard Worker   }
3254*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8)3255*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8) {
3256*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3257*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3258*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3259*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3260*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3261*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3262*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3263*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3264*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3265*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3266*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3267*4bdc9457SAndroid Build Coastguard Worker       }
3268*4bdc9457SAndroid Build Coastguard Worker     }
3269*4bdc9457SAndroid Build Coastguard Worker   }
3270*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_strided_cn)3271*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_strided_cn) {
3272*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3273*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3274*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3275*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3276*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3277*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3278*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3279*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3280*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3281*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3282*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
3283*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3284*4bdc9457SAndroid Build Coastguard Worker       }
3285*4bdc9457SAndroid Build Coastguard Worker     }
3286*4bdc9457SAndroid Build Coastguard Worker   }
3287*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_subtile)3288*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_subtile) {
3289*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3290*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3291*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3292*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3293*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3294*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3295*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3296*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3297*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3298*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3299*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3300*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3301*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3302*4bdc9457SAndroid Build Coastguard Worker         }
3303*4bdc9457SAndroid Build Coastguard Worker       }
3304*4bdc9457SAndroid Build Coastguard Worker     }
3305*4bdc9457SAndroid Build Coastguard Worker   }
3306*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8)3307*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8) {
3308*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3309*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3310*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3311*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3312*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3313*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3314*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3315*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3316*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3317*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3318*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3319*4bdc9457SAndroid Build Coastguard Worker       }
3320*4bdc9457SAndroid Build Coastguard Worker     }
3321*4bdc9457SAndroid Build Coastguard Worker   }
3322*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_strided_cn)3323*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_strided_cn) {
3324*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3325*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3326*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3327*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3328*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3329*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3330*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3331*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3332*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3333*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3334*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
3335*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3336*4bdc9457SAndroid Build Coastguard Worker       }
3337*4bdc9457SAndroid Build Coastguard Worker     }
3338*4bdc9457SAndroid Build Coastguard Worker   }
3339*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_subtile)3340*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_subtile) {
3341*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3342*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3343*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3344*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3345*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3346*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3347*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3348*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3349*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3350*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3351*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3352*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3353*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3354*4bdc9457SAndroid Build Coastguard Worker         }
3355*4bdc9457SAndroid Build Coastguard Worker       }
3356*4bdc9457SAndroid Build Coastguard Worker     }
3357*4bdc9457SAndroid Build Coastguard Worker   }
3358*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel)3359*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel) {
3360*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3361*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3362*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3363*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3364*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3365*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3366*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3367*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3368*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3369*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
3370*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3371*4bdc9457SAndroid Build Coastguard Worker     }
3372*4bdc9457SAndroid Build Coastguard Worker   }
3373*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel_subtile)3374*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel_subtile) {
3375*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3376*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3377*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3378*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3379*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3380*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3381*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3382*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3383*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3384*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3385*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3386*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
3387*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3388*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3389*4bdc9457SAndroid Build Coastguard Worker         }
3390*4bdc9457SAndroid Build Coastguard Worker       }
3391*4bdc9457SAndroid Build Coastguard Worker     }
3392*4bdc9457SAndroid Build Coastguard Worker   }
3393*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_small_kernel)3394*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_small_kernel) {
3395*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3396*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3397*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3398*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3399*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3400*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3401*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3402*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3403*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3404*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3405*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3406*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3407*4bdc9457SAndroid Build Coastguard Worker       }
3408*4bdc9457SAndroid Build Coastguard Worker     }
3409*4bdc9457SAndroid Build Coastguard Worker   }
3410*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_small_kernel)3411*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_small_kernel) {
3412*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3413*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
3414*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3415*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3416*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3417*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3418*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3419*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3420*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3421*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3422*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3423*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3424*4bdc9457SAndroid Build Coastguard Worker       }
3425*4bdc9457SAndroid Build Coastguard Worker     }
3426*4bdc9457SAndroid Build Coastguard Worker   }
3427*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm_subtile)3428*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm_subtile) {
3429*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3430*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3431*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3432*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3433*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3434*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3435*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3436*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
3437*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3438*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3439*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3440*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
3441*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3442*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3443*4bdc9457SAndroid Build Coastguard Worker         }
3444*4bdc9457SAndroid Build Coastguard Worker       }
3445*4bdc9457SAndroid Build Coastguard Worker     }
3446*4bdc9457SAndroid Build Coastguard Worker   }
3447*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,a_offset)3448*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, a_offset) {
3449*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3450*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3451*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3452*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3453*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3454*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3455*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3456*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3457*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3458*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
3459*4bdc9457SAndroid Build Coastguard Worker         .a_offset(17)
3460*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3461*4bdc9457SAndroid Build Coastguard Worker     }
3462*4bdc9457SAndroid Build Coastguard Worker   }
3463*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,zero)3464*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, zero) {
3465*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
3466*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 3; mz++) {
3467*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3468*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3469*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3470*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3471*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3472*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3473*4bdc9457SAndroid Build Coastguard Worker           .n(8)
3474*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3475*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3476*4bdc9457SAndroid Build Coastguard Worker           .a_offset(17)
3477*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
3478*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3479*4bdc9457SAndroid Build Coastguard Worker       }
3480*4bdc9457SAndroid Build Coastguard Worker     }
3481*4bdc9457SAndroid Build Coastguard Worker   }
3482*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm)3483*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm) {
3484*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3485*4bdc9457SAndroid Build Coastguard Worker       .mr(3)
3486*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3487*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3488*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
3489*4bdc9457SAndroid Build Coastguard Worker       .m(3)
3490*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3491*4bdc9457SAndroid Build Coastguard Worker       .k(1)
3492*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
3493*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_3x8__wasmrelaxedsimd_fma_loadsplat);
3494*4bdc9457SAndroid Build Coastguard Worker   }
3495*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMRELAXEDSIMD
3496*4bdc9457SAndroid Build Coastguard Worker 
3497*4bdc9457SAndroid Build Coastguard Worker 
3498*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_eq_4)3499*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_eq_4) {
3500*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3501*4bdc9457SAndroid Build Coastguard Worker       .mr(3)
3502*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3503*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3504*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
3505*4bdc9457SAndroid Build Coastguard Worker       .m(3)
3506*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3507*4bdc9457SAndroid Build Coastguard Worker       .k(4)
3508*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3509*4bdc9457SAndroid Build Coastguard Worker   }
3510*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,strided_cn)3511*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, strided_cn) {
3512*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3513*4bdc9457SAndroid Build Coastguard Worker       .mr(3)
3514*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3515*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3516*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
3517*4bdc9457SAndroid Build Coastguard Worker       .m(3)
3518*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3519*4bdc9457SAndroid Build Coastguard Worker       .k(4)
3520*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
3521*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3522*4bdc9457SAndroid Build Coastguard Worker   }
3523*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_eq_4_subtile)3524*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_eq_4_subtile) {
3525*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
3526*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 3; m++) {
3527*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3528*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3529*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3530*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3531*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3532*4bdc9457SAndroid Build Coastguard Worker           .m(m)
3533*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3534*4bdc9457SAndroid Build Coastguard Worker           .k(4)
3535*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
3536*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3537*4bdc9457SAndroid Build Coastguard Worker       }
3538*4bdc9457SAndroid Build Coastguard Worker     }
3539*4bdc9457SAndroid Build Coastguard Worker   }
3540*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_eq_4_subtile_m)3541*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_eq_4_subtile_m) {
3542*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 3; m++) {
3543*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3544*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3545*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3546*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3547*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
3548*4bdc9457SAndroid Build Coastguard Worker         .m(m)
3549*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3550*4bdc9457SAndroid Build Coastguard Worker         .k(4)
3551*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
3552*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3553*4bdc9457SAndroid Build Coastguard Worker     }
3554*4bdc9457SAndroid Build Coastguard Worker   }
3555*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_eq_4_subtile_n)3556*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_eq_4_subtile_n) {
3557*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
3558*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3559*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3560*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3561*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3562*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
3563*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3564*4bdc9457SAndroid Build Coastguard Worker         .n(n)
3565*4bdc9457SAndroid Build Coastguard Worker         .k(4)
3566*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
3567*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3568*4bdc9457SAndroid Build Coastguard Worker     }
3569*4bdc9457SAndroid Build Coastguard Worker   }
3570*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_lt_4)3571*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_lt_4) {
3572*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
3573*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3574*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3575*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3576*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3577*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
3578*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3579*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3580*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3581*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3582*4bdc9457SAndroid Build Coastguard Worker     }
3583*4bdc9457SAndroid Build Coastguard Worker   }
3584*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_lt_4_subtile)3585*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_lt_4_subtile) {
3586*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
3587*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3588*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3589*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3590*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3591*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3592*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3593*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
3594*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3595*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3596*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3597*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3598*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3599*4bdc9457SAndroid Build Coastguard Worker         }
3600*4bdc9457SAndroid Build Coastguard Worker       }
3601*4bdc9457SAndroid Build Coastguard Worker     }
3602*4bdc9457SAndroid Build Coastguard Worker   }
3603*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_gt_4)3604*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_gt_4) {
3605*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
3606*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3607*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3608*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3609*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3610*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
3611*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3612*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3613*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3614*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3615*4bdc9457SAndroid Build Coastguard Worker     }
3616*4bdc9457SAndroid Build Coastguard Worker   }
3617*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_gt_4_subtile)3618*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_gt_4_subtile) {
3619*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
3620*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3621*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3622*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3623*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3624*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3625*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3626*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
3627*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3628*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3629*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3630*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3631*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3632*4bdc9457SAndroid Build Coastguard Worker         }
3633*4bdc9457SAndroid Build Coastguard Worker       }
3634*4bdc9457SAndroid Build Coastguard Worker     }
3635*4bdc9457SAndroid Build Coastguard Worker   }
3636*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_div_4)3637*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_div_4) {
3638*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
3639*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3640*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3641*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3642*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3643*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
3644*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3645*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3646*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3647*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3648*4bdc9457SAndroid Build Coastguard Worker     }
3649*4bdc9457SAndroid Build Coastguard Worker   }
3650*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,k_div_4_subtile)3651*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, k_div_4_subtile) {
3652*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
3653*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3654*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3655*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3656*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3657*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3658*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3659*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
3660*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3661*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3662*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3663*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3664*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3665*4bdc9457SAndroid Build Coastguard Worker         }
3666*4bdc9457SAndroid Build Coastguard Worker       }
3667*4bdc9457SAndroid Build Coastguard Worker     }
3668*4bdc9457SAndroid Build Coastguard Worker   }
3669*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_gt_8)3670*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_gt_8) {
3671*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3672*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3673*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3674*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3675*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3676*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3677*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3678*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3679*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3680*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3681*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3682*4bdc9457SAndroid Build Coastguard Worker       }
3683*4bdc9457SAndroid Build Coastguard Worker     }
3684*4bdc9457SAndroid Build Coastguard Worker   }
3685*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_gt_8_strided_cn)3686*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_gt_8_strided_cn) {
3687*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3688*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3689*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3690*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3691*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3692*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3693*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3694*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3695*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3696*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3697*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
3698*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3699*4bdc9457SAndroid Build Coastguard Worker       }
3700*4bdc9457SAndroid Build Coastguard Worker     }
3701*4bdc9457SAndroid Build Coastguard Worker   }
3702*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_gt_8_subtile)3703*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_gt_8_subtile) {
3704*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3705*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3706*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3707*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3708*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3709*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3710*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3711*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
3712*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3713*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3714*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3715*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3716*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3717*4bdc9457SAndroid Build Coastguard Worker         }
3718*4bdc9457SAndroid Build Coastguard Worker       }
3719*4bdc9457SAndroid Build Coastguard Worker     }
3720*4bdc9457SAndroid Build Coastguard Worker   }
3721*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_div_8)3722*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_div_8) {
3723*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3724*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3725*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3726*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3727*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3728*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3729*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3730*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3731*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3732*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3733*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3734*4bdc9457SAndroid Build Coastguard Worker       }
3735*4bdc9457SAndroid Build Coastguard Worker     }
3736*4bdc9457SAndroid Build Coastguard Worker   }
3737*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_div_8_strided_cn)3738*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_div_8_strided_cn) {
3739*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3740*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3741*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3742*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3743*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3744*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3745*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3746*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3747*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3748*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3749*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
3750*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3751*4bdc9457SAndroid Build Coastguard Worker       }
3752*4bdc9457SAndroid Build Coastguard Worker     }
3753*4bdc9457SAndroid Build Coastguard Worker   }
3754*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_div_8_subtile)3755*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_div_8_subtile) {
3756*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3757*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3758*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3759*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3760*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3761*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3762*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3763*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
3764*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3765*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3766*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3767*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3768*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3769*4bdc9457SAndroid Build Coastguard Worker         }
3770*4bdc9457SAndroid Build Coastguard Worker       }
3771*4bdc9457SAndroid Build Coastguard Worker     }
3772*4bdc9457SAndroid Build Coastguard Worker   }
3773*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,small_kernel)3774*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, small_kernel) {
3775*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
3776*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3777*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3778*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3779*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3780*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
3781*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3782*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3783*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3784*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
3785*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3786*4bdc9457SAndroid Build Coastguard Worker     }
3787*4bdc9457SAndroid Build Coastguard Worker   }
3788*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,small_kernel_subtile)3789*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, small_kernel_subtile) {
3790*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
3791*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3792*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3793*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3794*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3795*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3796*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3797*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
3798*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3799*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3800*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3801*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
3802*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3803*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3804*4bdc9457SAndroid Build Coastguard Worker         }
3805*4bdc9457SAndroid Build Coastguard Worker       }
3806*4bdc9457SAndroid Build Coastguard Worker     }
3807*4bdc9457SAndroid Build Coastguard Worker   }
3808*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_gt_8_small_kernel)3809*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_gt_8_small_kernel) {
3810*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
3811*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3812*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3813*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3814*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3815*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3816*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3817*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3818*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3819*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3820*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3821*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3822*4bdc9457SAndroid Build Coastguard Worker       }
3823*4bdc9457SAndroid Build Coastguard Worker     }
3824*4bdc9457SAndroid Build Coastguard Worker   }
3825*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,n_div_8_small_kernel)3826*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, n_div_8_small_kernel) {
3827*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
3828*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
3829*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3830*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3831*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3832*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3833*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3834*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3835*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3836*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3837*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3838*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3839*4bdc9457SAndroid Build Coastguard Worker       }
3840*4bdc9457SAndroid Build Coastguard Worker     }
3841*4bdc9457SAndroid Build Coastguard Worker   }
3842*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,strided_cm_subtile)3843*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, strided_cm_subtile) {
3844*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
3845*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
3846*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 3; m++) {
3847*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
3848*4bdc9457SAndroid Build Coastguard Worker             .mr(3)
3849*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
3850*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
3851*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
3852*4bdc9457SAndroid Build Coastguard Worker             .m(m)
3853*4bdc9457SAndroid Build Coastguard Worker             .n(n)
3854*4bdc9457SAndroid Build Coastguard Worker             .k(k)
3855*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
3856*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
3857*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3858*4bdc9457SAndroid Build Coastguard Worker         }
3859*4bdc9457SAndroid Build Coastguard Worker       }
3860*4bdc9457SAndroid Build Coastguard Worker     }
3861*4bdc9457SAndroid Build Coastguard Worker   }
3862*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,a_offset)3863*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, a_offset) {
3864*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
3865*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3866*4bdc9457SAndroid Build Coastguard Worker         .mr(3)
3867*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3868*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3869*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
3870*4bdc9457SAndroid Build Coastguard Worker         .m(3)
3871*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3872*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3873*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
3874*4bdc9457SAndroid Build Coastguard Worker         .a_offset(67)
3875*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3876*4bdc9457SAndroid Build Coastguard Worker     }
3877*4bdc9457SAndroid Build Coastguard Worker   }
3878*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,zero)3879*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, zero) {
3880*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
3881*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 3; mz++) {
3882*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3883*4bdc9457SAndroid Build Coastguard Worker           .mr(3)
3884*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3885*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3886*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
3887*4bdc9457SAndroid Build Coastguard Worker           .m(3)
3888*4bdc9457SAndroid Build Coastguard Worker           .n(8)
3889*4bdc9457SAndroid Build Coastguard Worker           .k(k)
3890*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
3891*4bdc9457SAndroid Build Coastguard Worker           .a_offset(67)
3892*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
3893*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3894*4bdc9457SAndroid Build Coastguard Worker       }
3895*4bdc9457SAndroid Build Coastguard Worker     }
3896*4bdc9457SAndroid Build Coastguard Worker   }
3897*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA,strided_cm)3898*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_3X8S4__WASMRELAXEDSIMD_FMA, strided_cm) {
3899*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3900*4bdc9457SAndroid Build Coastguard Worker       .mr(3)
3901*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3902*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3903*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
3904*4bdc9457SAndroid Build Coastguard Worker       .m(3)
3905*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3906*4bdc9457SAndroid Build Coastguard Worker       .k(4)
3907*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
3908*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_3x8s4__wasmrelaxedsimd_fma);
3909*4bdc9457SAndroid Build Coastguard Worker   }
3910*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMRELAXEDSIMD
3911*4bdc9457SAndroid Build Coastguard Worker 
3912*4bdc9457SAndroid Build Coastguard Worker 
3913*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1)3914*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1) {
3915*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3916*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
3917*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3918*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3919*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
3920*4bdc9457SAndroid Build Coastguard Worker       .m(4)
3921*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3922*4bdc9457SAndroid Build Coastguard Worker       .k(1)
3923*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
3924*4bdc9457SAndroid Build Coastguard Worker   }
3925*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cn)3926*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cn) {
3927*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
3928*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
3929*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
3930*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
3931*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
3932*4bdc9457SAndroid Build Coastguard Worker       .m(4)
3933*4bdc9457SAndroid Build Coastguard Worker       .n(8)
3934*4bdc9457SAndroid Build Coastguard Worker       .k(1)
3935*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
3936*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
3937*4bdc9457SAndroid Build Coastguard Worker   }
3938*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile)3939*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile) {
3940*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
3941*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 4; m++) {
3942*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
3943*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
3944*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
3945*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
3946*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
3947*4bdc9457SAndroid Build Coastguard Worker           .m(m)
3948*4bdc9457SAndroid Build Coastguard Worker           .n(n)
3949*4bdc9457SAndroid Build Coastguard Worker           .k(1)
3950*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
3951*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
3952*4bdc9457SAndroid Build Coastguard Worker       }
3953*4bdc9457SAndroid Build Coastguard Worker     }
3954*4bdc9457SAndroid Build Coastguard Worker   }
3955*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_m)3956*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_m) {
3957*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 4; m++) {
3958*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3959*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
3960*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3961*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3962*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3963*4bdc9457SAndroid Build Coastguard Worker         .m(m)
3964*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3965*4bdc9457SAndroid Build Coastguard Worker         .k(1)
3966*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
3967*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
3968*4bdc9457SAndroid Build Coastguard Worker     }
3969*4bdc9457SAndroid Build Coastguard Worker   }
3970*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_n)3971*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_n) {
3972*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
3973*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3974*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
3975*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3976*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3977*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3978*4bdc9457SAndroid Build Coastguard Worker         .m(4)
3979*4bdc9457SAndroid Build Coastguard Worker         .n(n)
3980*4bdc9457SAndroid Build Coastguard Worker         .k(1)
3981*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
3982*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
3983*4bdc9457SAndroid Build Coastguard Worker     }
3984*4bdc9457SAndroid Build Coastguard Worker   }
3985*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1)3986*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1) {
3987*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
3988*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
3989*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
3990*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
3991*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
3992*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
3993*4bdc9457SAndroid Build Coastguard Worker         .m(4)
3994*4bdc9457SAndroid Build Coastguard Worker         .n(8)
3995*4bdc9457SAndroid Build Coastguard Worker         .k(k)
3996*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
3997*4bdc9457SAndroid Build Coastguard Worker     }
3998*4bdc9457SAndroid Build Coastguard Worker   }
3999*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1_subtile)4000*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1_subtile) {
4001*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
4002*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4003*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4004*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4005*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4006*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4007*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4008*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4009*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4010*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4011*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4012*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4013*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4014*4bdc9457SAndroid Build Coastguard Worker         }
4015*4bdc9457SAndroid Build Coastguard Worker       }
4016*4bdc9457SAndroid Build Coastguard Worker     }
4017*4bdc9457SAndroid Build Coastguard Worker   }
4018*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8)4019*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8) {
4020*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4021*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4022*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4023*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4024*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4025*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4026*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4027*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4028*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4029*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4030*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4031*4bdc9457SAndroid Build Coastguard Worker       }
4032*4bdc9457SAndroid Build Coastguard Worker     }
4033*4bdc9457SAndroid Build Coastguard Worker   }
4034*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_strided_cn)4035*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_strided_cn) {
4036*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4037*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4038*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4039*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4040*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4041*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4042*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4043*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4044*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4045*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4046*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
4047*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4048*4bdc9457SAndroid Build Coastguard Worker       }
4049*4bdc9457SAndroid Build Coastguard Worker     }
4050*4bdc9457SAndroid Build Coastguard Worker   }
4051*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_subtile)4052*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_subtile) {
4053*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4054*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4055*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4056*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4057*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4058*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4059*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4060*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4061*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4062*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4063*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4064*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4065*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4066*4bdc9457SAndroid Build Coastguard Worker         }
4067*4bdc9457SAndroid Build Coastguard Worker       }
4068*4bdc9457SAndroid Build Coastguard Worker     }
4069*4bdc9457SAndroid Build Coastguard Worker   }
4070*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8)4071*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8) {
4072*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4073*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4074*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4075*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4076*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4077*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4078*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4079*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4080*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4081*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4082*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4083*4bdc9457SAndroid Build Coastguard Worker       }
4084*4bdc9457SAndroid Build Coastguard Worker     }
4085*4bdc9457SAndroid Build Coastguard Worker   }
4086*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_strided_cn)4087*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_strided_cn) {
4088*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4089*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4090*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4091*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4092*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4093*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4094*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4095*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4096*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4097*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4098*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
4099*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4100*4bdc9457SAndroid Build Coastguard Worker       }
4101*4bdc9457SAndroid Build Coastguard Worker     }
4102*4bdc9457SAndroid Build Coastguard Worker   }
4103*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_subtile)4104*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_subtile) {
4105*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4106*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4107*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4108*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4109*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4110*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4111*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4112*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4113*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4114*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4115*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4116*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4117*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4118*4bdc9457SAndroid Build Coastguard Worker         }
4119*4bdc9457SAndroid Build Coastguard Worker       }
4120*4bdc9457SAndroid Build Coastguard Worker     }
4121*4bdc9457SAndroid Build Coastguard Worker   }
4122*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel)4123*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel) {
4124*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4125*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4126*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4127*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4128*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4129*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
4130*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4131*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4132*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4133*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
4134*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4135*4bdc9457SAndroid Build Coastguard Worker     }
4136*4bdc9457SAndroid Build Coastguard Worker   }
4137*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel_subtile)4138*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel_subtile) {
4139*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4140*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4141*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4142*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4143*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4144*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4145*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4146*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4147*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4148*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4149*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4150*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
4151*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4152*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4153*4bdc9457SAndroid Build Coastguard Worker         }
4154*4bdc9457SAndroid Build Coastguard Worker       }
4155*4bdc9457SAndroid Build Coastguard Worker     }
4156*4bdc9457SAndroid Build Coastguard Worker   }
4157*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_small_kernel)4158*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_small_kernel) {
4159*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4160*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4161*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4162*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4163*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4164*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4165*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4166*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4167*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4168*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4169*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4170*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4171*4bdc9457SAndroid Build Coastguard Worker       }
4172*4bdc9457SAndroid Build Coastguard Worker     }
4173*4bdc9457SAndroid Build Coastguard Worker   }
4174*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_small_kernel)4175*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_small_kernel) {
4176*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4177*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4178*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4179*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4180*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4181*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4182*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4183*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4184*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4185*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4186*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4187*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4188*4bdc9457SAndroid Build Coastguard Worker       }
4189*4bdc9457SAndroid Build Coastguard Worker     }
4190*4bdc9457SAndroid Build Coastguard Worker   }
4191*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm_subtile)4192*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm_subtile) {
4193*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4194*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4195*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4196*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4197*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4198*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4199*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4200*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4201*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4202*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4203*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4204*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
4205*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4206*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4207*4bdc9457SAndroid Build Coastguard Worker         }
4208*4bdc9457SAndroid Build Coastguard Worker       }
4209*4bdc9457SAndroid Build Coastguard Worker     }
4210*4bdc9457SAndroid Build Coastguard Worker   }
4211*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,a_offset)4212*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, a_offset) {
4213*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4214*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4215*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4216*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4217*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4218*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
4219*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4220*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4221*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4222*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
4223*4bdc9457SAndroid Build Coastguard Worker         .a_offset(23)
4224*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4225*4bdc9457SAndroid Build Coastguard Worker     }
4226*4bdc9457SAndroid Build Coastguard Worker   }
4227*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,zero)4228*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, zero) {
4229*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4230*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 4; mz++) {
4231*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4232*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4233*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4234*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4235*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4236*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4237*4bdc9457SAndroid Build Coastguard Worker           .n(8)
4238*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4239*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4240*4bdc9457SAndroid Build Coastguard Worker           .a_offset(23)
4241*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
4242*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4243*4bdc9457SAndroid Build Coastguard Worker       }
4244*4bdc9457SAndroid Build Coastguard Worker     }
4245*4bdc9457SAndroid Build Coastguard Worker   }
4246*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm)4247*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm) {
4248*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
4249*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
4250*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
4251*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
4252*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
4253*4bdc9457SAndroid Build Coastguard Worker       .m(4)
4254*4bdc9457SAndroid Build Coastguard Worker       .n(8)
4255*4bdc9457SAndroid Build Coastguard Worker       .k(1)
4256*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
4257*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8__wasmrelaxedsimd_fma_loadsplat);
4258*4bdc9457SAndroid Build Coastguard Worker   }
4259*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMRELAXEDSIMD
4260*4bdc9457SAndroid Build Coastguard Worker 
4261*4bdc9457SAndroid Build Coastguard Worker 
4262*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_eq_4)4263*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_eq_4) {
4264*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
4265*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
4266*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
4267*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
4268*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
4269*4bdc9457SAndroid Build Coastguard Worker       .m(4)
4270*4bdc9457SAndroid Build Coastguard Worker       .n(8)
4271*4bdc9457SAndroid Build Coastguard Worker       .k(4)
4272*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4273*4bdc9457SAndroid Build Coastguard Worker   }
4274*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,strided_cn)4275*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, strided_cn) {
4276*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
4277*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
4278*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
4279*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
4280*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
4281*4bdc9457SAndroid Build Coastguard Worker       .m(4)
4282*4bdc9457SAndroid Build Coastguard Worker       .n(8)
4283*4bdc9457SAndroid Build Coastguard Worker       .k(4)
4284*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
4285*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4286*4bdc9457SAndroid Build Coastguard Worker   }
4287*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_eq_4_subtile)4288*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_eq_4_subtile) {
4289*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
4290*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 4; m++) {
4291*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4292*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4293*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4294*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4295*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4296*4bdc9457SAndroid Build Coastguard Worker           .m(m)
4297*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4298*4bdc9457SAndroid Build Coastguard Worker           .k(4)
4299*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
4300*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4301*4bdc9457SAndroid Build Coastguard Worker       }
4302*4bdc9457SAndroid Build Coastguard Worker     }
4303*4bdc9457SAndroid Build Coastguard Worker   }
4304*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_eq_4_subtile_m)4305*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_eq_4_subtile_m) {
4306*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 4; m++) {
4307*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4308*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4309*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4310*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4311*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
4312*4bdc9457SAndroid Build Coastguard Worker         .m(m)
4313*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4314*4bdc9457SAndroid Build Coastguard Worker         .k(4)
4315*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
4316*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4317*4bdc9457SAndroid Build Coastguard Worker     }
4318*4bdc9457SAndroid Build Coastguard Worker   }
4319*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_eq_4_subtile_n)4320*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_eq_4_subtile_n) {
4321*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
4322*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4323*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4324*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4325*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4326*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
4327*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4328*4bdc9457SAndroid Build Coastguard Worker         .n(n)
4329*4bdc9457SAndroid Build Coastguard Worker         .k(4)
4330*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
4331*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4332*4bdc9457SAndroid Build Coastguard Worker     }
4333*4bdc9457SAndroid Build Coastguard Worker   }
4334*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_lt_4)4335*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_lt_4) {
4336*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
4337*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4338*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4339*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4340*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4341*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
4342*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4343*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4344*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4345*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4346*4bdc9457SAndroid Build Coastguard Worker     }
4347*4bdc9457SAndroid Build Coastguard Worker   }
4348*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_lt_4_subtile)4349*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_lt_4_subtile) {
4350*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k < 4; k++) {
4351*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4352*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4353*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4354*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4355*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4356*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4357*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
4358*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4359*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4360*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4361*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4362*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4363*4bdc9457SAndroid Build Coastguard Worker         }
4364*4bdc9457SAndroid Build Coastguard Worker       }
4365*4bdc9457SAndroid Build Coastguard Worker     }
4366*4bdc9457SAndroid Build Coastguard Worker   }
4367*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_gt_4)4368*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_gt_4) {
4369*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
4370*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4371*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4372*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4373*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4374*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
4375*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4376*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4377*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4378*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4379*4bdc9457SAndroid Build Coastguard Worker     }
4380*4bdc9457SAndroid Build Coastguard Worker   }
4381*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_gt_4_subtile)4382*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_gt_4_subtile) {
4383*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 5; k < 8; k++) {
4384*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4385*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4386*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4387*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4388*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4389*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4390*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
4391*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4392*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4393*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4394*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4395*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4396*4bdc9457SAndroid Build Coastguard Worker         }
4397*4bdc9457SAndroid Build Coastguard Worker       }
4398*4bdc9457SAndroid Build Coastguard Worker     }
4399*4bdc9457SAndroid Build Coastguard Worker   }
4400*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_div_4)4401*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_div_4) {
4402*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
4403*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4404*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4405*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4406*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4407*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
4408*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4409*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4410*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4411*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4412*4bdc9457SAndroid Build Coastguard Worker     }
4413*4bdc9457SAndroid Build Coastguard Worker   }
4414*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,k_div_4_subtile)4415*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, k_div_4_subtile) {
4416*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 8; k <= 40; k += 4) {
4417*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4418*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4419*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4420*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4421*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4422*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4423*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
4424*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4425*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4426*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4427*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4428*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4429*4bdc9457SAndroid Build Coastguard Worker         }
4430*4bdc9457SAndroid Build Coastguard Worker       }
4431*4bdc9457SAndroid Build Coastguard Worker     }
4432*4bdc9457SAndroid Build Coastguard Worker   }
4433*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_gt_8)4434*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_gt_8) {
4435*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4436*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4437*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4438*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4439*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4440*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4441*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4442*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4443*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4444*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4445*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4446*4bdc9457SAndroid Build Coastguard Worker       }
4447*4bdc9457SAndroid Build Coastguard Worker     }
4448*4bdc9457SAndroid Build Coastguard Worker   }
4449*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_gt_8_strided_cn)4450*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_gt_8_strided_cn) {
4451*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4452*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4453*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4454*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4455*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4456*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4457*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4458*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4459*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4460*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4461*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
4462*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4463*4bdc9457SAndroid Build Coastguard Worker       }
4464*4bdc9457SAndroid Build Coastguard Worker     }
4465*4bdc9457SAndroid Build Coastguard Worker   }
4466*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_gt_8_subtile)4467*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_gt_8_subtile) {
4468*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4469*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4470*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4471*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4472*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4473*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4474*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4475*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
4476*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4477*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4478*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4479*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4480*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4481*4bdc9457SAndroid Build Coastguard Worker         }
4482*4bdc9457SAndroid Build Coastguard Worker       }
4483*4bdc9457SAndroid Build Coastguard Worker     }
4484*4bdc9457SAndroid Build Coastguard Worker   }
4485*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_div_8)4486*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_div_8) {
4487*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4488*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4489*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4490*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4491*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4492*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4493*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4494*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4495*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4496*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4497*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4498*4bdc9457SAndroid Build Coastguard Worker       }
4499*4bdc9457SAndroid Build Coastguard Worker     }
4500*4bdc9457SAndroid Build Coastguard Worker   }
4501*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_div_8_strided_cn)4502*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_div_8_strided_cn) {
4503*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4504*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4505*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4506*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4507*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4508*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4509*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4510*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4511*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4512*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4513*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
4514*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4515*4bdc9457SAndroid Build Coastguard Worker       }
4516*4bdc9457SAndroid Build Coastguard Worker     }
4517*4bdc9457SAndroid Build Coastguard Worker   }
4518*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_div_8_subtile)4519*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_div_8_subtile) {
4520*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4521*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4522*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4523*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4524*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4525*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4526*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4527*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
4528*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4529*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4530*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4531*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4532*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4533*4bdc9457SAndroid Build Coastguard Worker         }
4534*4bdc9457SAndroid Build Coastguard Worker       }
4535*4bdc9457SAndroid Build Coastguard Worker     }
4536*4bdc9457SAndroid Build Coastguard Worker   }
4537*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,small_kernel)4538*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, small_kernel) {
4539*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
4540*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4541*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4542*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4543*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4544*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
4545*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4546*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4547*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4548*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
4549*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4550*4bdc9457SAndroid Build Coastguard Worker     }
4551*4bdc9457SAndroid Build Coastguard Worker   }
4552*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,small_kernel_subtile)4553*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, small_kernel_subtile) {
4554*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
4555*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4556*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4557*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4558*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4559*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4560*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4561*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
4562*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4563*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4564*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4565*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
4566*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4567*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4568*4bdc9457SAndroid Build Coastguard Worker         }
4569*4bdc9457SAndroid Build Coastguard Worker       }
4570*4bdc9457SAndroid Build Coastguard Worker     }
4571*4bdc9457SAndroid Build Coastguard Worker   }
4572*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_gt_8_small_kernel)4573*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_gt_8_small_kernel) {
4574*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4575*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4576*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4577*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4578*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4579*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4580*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4581*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4582*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4583*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4584*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4585*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4586*4bdc9457SAndroid Build Coastguard Worker       }
4587*4bdc9457SAndroid Build Coastguard Worker     }
4588*4bdc9457SAndroid Build Coastguard Worker   }
4589*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,n_div_8_small_kernel)4590*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, n_div_8_small_kernel) {
4591*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4592*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 20; k += 5) {
4593*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4594*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4595*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4596*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4597*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4598*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4599*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4600*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4601*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4602*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4603*4bdc9457SAndroid Build Coastguard Worker       }
4604*4bdc9457SAndroid Build Coastguard Worker     }
4605*4bdc9457SAndroid Build Coastguard Worker   }
4606*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,strided_cm_subtile)4607*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, strided_cm_subtile) {
4608*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
4609*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4610*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 4; m++) {
4611*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4612*4bdc9457SAndroid Build Coastguard Worker             .mr(4)
4613*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4614*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4615*4bdc9457SAndroid Build Coastguard Worker             .sr(4)
4616*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4617*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4618*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4619*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
4620*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4621*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4622*4bdc9457SAndroid Build Coastguard Worker         }
4623*4bdc9457SAndroid Build Coastguard Worker       }
4624*4bdc9457SAndroid Build Coastguard Worker     }
4625*4bdc9457SAndroid Build Coastguard Worker   }
4626*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,a_offset)4627*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, a_offset) {
4628*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
4629*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4630*4bdc9457SAndroid Build Coastguard Worker         .mr(4)
4631*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4632*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4633*4bdc9457SAndroid Build Coastguard Worker         .sr(4)
4634*4bdc9457SAndroid Build Coastguard Worker         .m(4)
4635*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4636*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4637*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
4638*4bdc9457SAndroid Build Coastguard Worker         .a_offset(83)
4639*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4640*4bdc9457SAndroid Build Coastguard Worker     }
4641*4bdc9457SAndroid Build Coastguard Worker   }
4642*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,zero)4643*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, zero) {
4644*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 20; k += 5) {
4645*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 4; mz++) {
4646*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4647*4bdc9457SAndroid Build Coastguard Worker           .mr(4)
4648*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4649*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4650*4bdc9457SAndroid Build Coastguard Worker           .sr(4)
4651*4bdc9457SAndroid Build Coastguard Worker           .m(4)
4652*4bdc9457SAndroid Build Coastguard Worker           .n(8)
4653*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4654*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4655*4bdc9457SAndroid Build Coastguard Worker           .a_offset(83)
4656*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
4657*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4658*4bdc9457SAndroid Build Coastguard Worker       }
4659*4bdc9457SAndroid Build Coastguard Worker     }
4660*4bdc9457SAndroid Build Coastguard Worker   }
4661*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA,strided_cm)4662*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_4X8S4__WASMRELAXEDSIMD_FMA, strided_cm) {
4663*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
4664*4bdc9457SAndroid Build Coastguard Worker       .mr(4)
4665*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
4666*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
4667*4bdc9457SAndroid Build Coastguard Worker       .sr(4)
4668*4bdc9457SAndroid Build Coastguard Worker       .m(4)
4669*4bdc9457SAndroid Build Coastguard Worker       .n(8)
4670*4bdc9457SAndroid Build Coastguard Worker       .k(4)
4671*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
4672*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_4x8s4__wasmrelaxedsimd_fma);
4673*4bdc9457SAndroid Build Coastguard Worker   }
4674*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMRELAXEDSIMD
4675*4bdc9457SAndroid Build Coastguard Worker 
4676*4bdc9457SAndroid Build Coastguard Worker 
4677*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1)4678*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1) {
4679*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
4680*4bdc9457SAndroid Build Coastguard Worker       .mr(5)
4681*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
4682*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
4683*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
4684*4bdc9457SAndroid Build Coastguard Worker       .m(5)
4685*4bdc9457SAndroid Build Coastguard Worker       .n(8)
4686*4bdc9457SAndroid Build Coastguard Worker       .k(1)
4687*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4688*4bdc9457SAndroid Build Coastguard Worker   }
4689*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cn)4690*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cn) {
4691*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
4692*4bdc9457SAndroid Build Coastguard Worker       .mr(5)
4693*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
4694*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
4695*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
4696*4bdc9457SAndroid Build Coastguard Worker       .m(5)
4697*4bdc9457SAndroid Build Coastguard Worker       .n(8)
4698*4bdc9457SAndroid Build Coastguard Worker       .k(1)
4699*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
4700*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4701*4bdc9457SAndroid Build Coastguard Worker   }
4702*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile)4703*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile) {
4704*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
4705*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 5; m++) {
4706*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4707*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4708*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4709*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4710*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4711*4bdc9457SAndroid Build Coastguard Worker           .m(m)
4712*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4713*4bdc9457SAndroid Build Coastguard Worker           .k(1)
4714*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
4715*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4716*4bdc9457SAndroid Build Coastguard Worker       }
4717*4bdc9457SAndroid Build Coastguard Worker     }
4718*4bdc9457SAndroid Build Coastguard Worker   }
4719*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_m)4720*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_m) {
4721*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 5; m++) {
4722*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4723*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
4724*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4725*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4726*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
4727*4bdc9457SAndroid Build Coastguard Worker         .m(m)
4728*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4729*4bdc9457SAndroid Build Coastguard Worker         .k(1)
4730*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
4731*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4732*4bdc9457SAndroid Build Coastguard Worker     }
4733*4bdc9457SAndroid Build Coastguard Worker   }
4734*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_n)4735*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_n) {
4736*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
4737*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4738*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
4739*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4740*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4741*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
4742*4bdc9457SAndroid Build Coastguard Worker         .m(5)
4743*4bdc9457SAndroid Build Coastguard Worker         .n(n)
4744*4bdc9457SAndroid Build Coastguard Worker         .k(1)
4745*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
4746*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4747*4bdc9457SAndroid Build Coastguard Worker     }
4748*4bdc9457SAndroid Build Coastguard Worker   }
4749*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1)4750*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1) {
4751*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
4752*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4753*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
4754*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4755*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4756*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
4757*4bdc9457SAndroid Build Coastguard Worker         .m(5)
4758*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4759*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4760*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4761*4bdc9457SAndroid Build Coastguard Worker     }
4762*4bdc9457SAndroid Build Coastguard Worker   }
4763*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1_subtile)4764*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1_subtile) {
4765*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
4766*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4767*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
4768*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4769*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
4770*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4771*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4772*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4773*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4774*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4775*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4776*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4777*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4778*4bdc9457SAndroid Build Coastguard Worker         }
4779*4bdc9457SAndroid Build Coastguard Worker       }
4780*4bdc9457SAndroid Build Coastguard Worker     }
4781*4bdc9457SAndroid Build Coastguard Worker   }
4782*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8)4783*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8) {
4784*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4785*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4786*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4787*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4788*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4789*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4790*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4791*4bdc9457SAndroid Build Coastguard Worker           .m(5)
4792*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4793*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4794*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4795*4bdc9457SAndroid Build Coastguard Worker       }
4796*4bdc9457SAndroid Build Coastguard Worker     }
4797*4bdc9457SAndroid Build Coastguard Worker   }
4798*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_strided_cn)4799*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_strided_cn) {
4800*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4801*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4802*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4803*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4804*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4805*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4806*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4807*4bdc9457SAndroid Build Coastguard Worker           .m(5)
4808*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4809*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4810*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
4811*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4812*4bdc9457SAndroid Build Coastguard Worker       }
4813*4bdc9457SAndroid Build Coastguard Worker     }
4814*4bdc9457SAndroid Build Coastguard Worker   }
4815*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_subtile)4816*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_subtile) {
4817*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4818*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4819*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
4820*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4821*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
4822*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4823*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4824*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4825*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4826*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4827*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4828*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4829*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4830*4bdc9457SAndroid Build Coastguard Worker         }
4831*4bdc9457SAndroid Build Coastguard Worker       }
4832*4bdc9457SAndroid Build Coastguard Worker     }
4833*4bdc9457SAndroid Build Coastguard Worker   }
4834*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8)4835*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8) {
4836*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4837*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4838*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4839*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4840*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4841*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4842*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4843*4bdc9457SAndroid Build Coastguard Worker           .m(5)
4844*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4845*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4846*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4847*4bdc9457SAndroid Build Coastguard Worker       }
4848*4bdc9457SAndroid Build Coastguard Worker     }
4849*4bdc9457SAndroid Build Coastguard Worker   }
4850*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_strided_cn)4851*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_strided_cn) {
4852*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4853*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4854*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4855*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4856*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4857*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4858*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4859*4bdc9457SAndroid Build Coastguard Worker           .m(5)
4860*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4861*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4862*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
4863*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4864*4bdc9457SAndroid Build Coastguard Worker       }
4865*4bdc9457SAndroid Build Coastguard Worker     }
4866*4bdc9457SAndroid Build Coastguard Worker   }
4867*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_subtile)4868*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_subtile) {
4869*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4870*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4871*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
4872*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4873*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
4874*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4875*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4876*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4877*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4878*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4879*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4880*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4881*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4882*4bdc9457SAndroid Build Coastguard Worker         }
4883*4bdc9457SAndroid Build Coastguard Worker       }
4884*4bdc9457SAndroid Build Coastguard Worker     }
4885*4bdc9457SAndroid Build Coastguard Worker   }
4886*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel)4887*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel) {
4888*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4889*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4890*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
4891*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4892*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4893*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
4894*4bdc9457SAndroid Build Coastguard Worker         .m(5)
4895*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4896*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4897*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
4898*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4899*4bdc9457SAndroid Build Coastguard Worker     }
4900*4bdc9457SAndroid Build Coastguard Worker   }
4901*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel_subtile)4902*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel_subtile) {
4903*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4904*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4905*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
4906*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4907*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
4908*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4909*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4910*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4911*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4912*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4913*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4914*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
4915*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4916*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4917*4bdc9457SAndroid Build Coastguard Worker         }
4918*4bdc9457SAndroid Build Coastguard Worker       }
4919*4bdc9457SAndroid Build Coastguard Worker     }
4920*4bdc9457SAndroid Build Coastguard Worker   }
4921*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_small_kernel)4922*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_small_kernel) {
4923*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
4924*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4925*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4926*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4927*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4928*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4929*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4930*4bdc9457SAndroid Build Coastguard Worker           .m(5)
4931*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4932*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4933*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4934*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4935*4bdc9457SAndroid Build Coastguard Worker       }
4936*4bdc9457SAndroid Build Coastguard Worker     }
4937*4bdc9457SAndroid Build Coastguard Worker   }
4938*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_small_kernel)4939*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_small_kernel) {
4940*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
4941*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
4942*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4943*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4944*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4945*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4946*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
4947*4bdc9457SAndroid Build Coastguard Worker           .m(5)
4948*4bdc9457SAndroid Build Coastguard Worker           .n(n)
4949*4bdc9457SAndroid Build Coastguard Worker           .k(k)
4950*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
4951*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4952*4bdc9457SAndroid Build Coastguard Worker       }
4953*4bdc9457SAndroid Build Coastguard Worker     }
4954*4bdc9457SAndroid Build Coastguard Worker   }
4955*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm_subtile)4956*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm_subtile) {
4957*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4958*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
4959*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 5; m++) {
4960*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
4961*4bdc9457SAndroid Build Coastguard Worker             .mr(5)
4962*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
4963*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
4964*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
4965*4bdc9457SAndroid Build Coastguard Worker             .m(m)
4966*4bdc9457SAndroid Build Coastguard Worker             .n(n)
4967*4bdc9457SAndroid Build Coastguard Worker             .k(k)
4968*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
4969*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
4970*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4971*4bdc9457SAndroid Build Coastguard Worker         }
4972*4bdc9457SAndroid Build Coastguard Worker       }
4973*4bdc9457SAndroid Build Coastguard Worker     }
4974*4bdc9457SAndroid Build Coastguard Worker   }
4975*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,a_offset)4976*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, a_offset) {
4977*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4978*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
4979*4bdc9457SAndroid Build Coastguard Worker         .mr(5)
4980*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
4981*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
4982*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
4983*4bdc9457SAndroid Build Coastguard Worker         .m(5)
4984*4bdc9457SAndroid Build Coastguard Worker         .n(8)
4985*4bdc9457SAndroid Build Coastguard Worker         .k(k)
4986*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
4987*4bdc9457SAndroid Build Coastguard Worker         .a_offset(29)
4988*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
4989*4bdc9457SAndroid Build Coastguard Worker     }
4990*4bdc9457SAndroid Build Coastguard Worker   }
4991*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,zero)4992*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, zero) {
4993*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
4994*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 5; mz++) {
4995*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
4996*4bdc9457SAndroid Build Coastguard Worker           .mr(5)
4997*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
4998*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
4999*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5000*4bdc9457SAndroid Build Coastguard Worker           .m(5)
5001*4bdc9457SAndroid Build Coastguard Worker           .n(8)
5002*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5003*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
5004*4bdc9457SAndroid Build Coastguard Worker           .a_offset(29)
5005*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
5006*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
5007*4bdc9457SAndroid Build Coastguard Worker       }
5008*4bdc9457SAndroid Build Coastguard Worker     }
5009*4bdc9457SAndroid Build Coastguard Worker   }
5010*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm)5011*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_5X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm) {
5012*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5013*4bdc9457SAndroid Build Coastguard Worker       .mr(5)
5014*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
5015*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5016*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5017*4bdc9457SAndroid Build Coastguard Worker       .m(5)
5018*4bdc9457SAndroid Build Coastguard Worker       .n(8)
5019*4bdc9457SAndroid Build Coastguard Worker       .k(1)
5020*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
5021*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_5x8__wasmrelaxedsimd_fma_loadsplat);
5022*4bdc9457SAndroid Build Coastguard Worker   }
5023*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMRELAXEDSIMD
5024*4bdc9457SAndroid Build Coastguard Worker 
5025*4bdc9457SAndroid Build Coastguard Worker 
5026*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1)5027*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1) {
5028*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5029*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
5030*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
5031*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5032*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5033*4bdc9457SAndroid Build Coastguard Worker       .m(6)
5034*4bdc9457SAndroid Build Coastguard Worker       .n(8)
5035*4bdc9457SAndroid Build Coastguard Worker       .k(1)
5036*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5037*4bdc9457SAndroid Build Coastguard Worker   }
5038*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cn)5039*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cn) {
5040*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5041*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
5042*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
5043*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5044*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5045*4bdc9457SAndroid Build Coastguard Worker       .m(6)
5046*4bdc9457SAndroid Build Coastguard Worker       .n(8)
5047*4bdc9457SAndroid Build Coastguard Worker       .k(1)
5048*4bdc9457SAndroid Build Coastguard Worker       .cn_stride(11)
5049*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5050*4bdc9457SAndroid Build Coastguard Worker   }
5051*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile)5052*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile) {
5053*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
5054*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 6; m++) {
5055*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5056*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5057*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5058*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5059*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5060*4bdc9457SAndroid Build Coastguard Worker           .m(m)
5061*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5062*4bdc9457SAndroid Build Coastguard Worker           .k(1)
5063*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
5064*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5065*4bdc9457SAndroid Build Coastguard Worker       }
5066*4bdc9457SAndroid Build Coastguard Worker     }
5067*4bdc9457SAndroid Build Coastguard Worker   }
5068*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_m)5069*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_m) {
5070*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 6; m++) {
5071*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5072*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
5073*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
5074*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5075*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5076*4bdc9457SAndroid Build Coastguard Worker         .m(m)
5077*4bdc9457SAndroid Build Coastguard Worker         .n(8)
5078*4bdc9457SAndroid Build Coastguard Worker         .k(1)
5079*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
5080*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5081*4bdc9457SAndroid Build Coastguard Worker     }
5082*4bdc9457SAndroid Build Coastguard Worker   }
5083*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_eq_1_subtile_n)5084*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_eq_1_subtile_n) {
5085*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 8; n++) {
5086*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5087*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
5088*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
5089*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5090*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5091*4bdc9457SAndroid Build Coastguard Worker         .m(6)
5092*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5093*4bdc9457SAndroid Build Coastguard Worker         .k(1)
5094*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
5095*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5096*4bdc9457SAndroid Build Coastguard Worker     }
5097*4bdc9457SAndroid Build Coastguard Worker   }
5098*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1)5099*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1) {
5100*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
5101*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5102*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
5103*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
5104*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5105*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5106*4bdc9457SAndroid Build Coastguard Worker         .m(6)
5107*4bdc9457SAndroid Build Coastguard Worker         .n(8)
5108*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5109*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5110*4bdc9457SAndroid Build Coastguard Worker     }
5111*4bdc9457SAndroid Build Coastguard Worker   }
5112*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,k_gt_1_subtile)5113*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, k_gt_1_subtile) {
5114*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 2; k < 10; k++) {
5115*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
5116*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
5117*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
5118*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
5119*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
5120*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
5121*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
5122*4bdc9457SAndroid Build Coastguard Worker             .m(m)
5123*4bdc9457SAndroid Build Coastguard Worker             .n(n)
5124*4bdc9457SAndroid Build Coastguard Worker             .k(k)
5125*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
5126*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5127*4bdc9457SAndroid Build Coastguard Worker         }
5128*4bdc9457SAndroid Build Coastguard Worker       }
5129*4bdc9457SAndroid Build Coastguard Worker     }
5130*4bdc9457SAndroid Build Coastguard Worker   }
5131*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8)5132*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8) {
5133*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
5134*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5135*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5136*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5137*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5138*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5139*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5140*4bdc9457SAndroid Build Coastguard Worker           .m(6)
5141*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5142*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5143*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5144*4bdc9457SAndroid Build Coastguard Worker       }
5145*4bdc9457SAndroid Build Coastguard Worker     }
5146*4bdc9457SAndroid Build Coastguard Worker   }
5147*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_strided_cn)5148*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_strided_cn) {
5149*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
5150*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5151*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5152*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5153*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5154*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5155*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5156*4bdc9457SAndroid Build Coastguard Worker           .m(6)
5157*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5158*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5159*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
5160*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5161*4bdc9457SAndroid Build Coastguard Worker       }
5162*4bdc9457SAndroid Build Coastguard Worker     }
5163*4bdc9457SAndroid Build Coastguard Worker   }
5164*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_subtile)5165*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_subtile) {
5166*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
5167*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5168*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
5169*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
5170*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
5171*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
5172*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
5173*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
5174*4bdc9457SAndroid Build Coastguard Worker             .m(m)
5175*4bdc9457SAndroid Build Coastguard Worker             .n(n)
5176*4bdc9457SAndroid Build Coastguard Worker             .k(k)
5177*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
5178*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5179*4bdc9457SAndroid Build Coastguard Worker         }
5180*4bdc9457SAndroid Build Coastguard Worker       }
5181*4bdc9457SAndroid Build Coastguard Worker     }
5182*4bdc9457SAndroid Build Coastguard Worker   }
5183*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8)5184*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8) {
5185*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
5186*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5187*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5188*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5189*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5190*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5191*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5192*4bdc9457SAndroid Build Coastguard Worker           .m(6)
5193*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5194*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5195*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5196*4bdc9457SAndroid Build Coastguard Worker       }
5197*4bdc9457SAndroid Build Coastguard Worker     }
5198*4bdc9457SAndroid Build Coastguard Worker   }
5199*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_strided_cn)5200*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_strided_cn) {
5201*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
5202*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5203*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5204*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5205*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5206*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5207*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5208*4bdc9457SAndroid Build Coastguard Worker           .m(6)
5209*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5210*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5211*4bdc9457SAndroid Build Coastguard Worker           .cn_stride(11)
5212*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5213*4bdc9457SAndroid Build Coastguard Worker       }
5214*4bdc9457SAndroid Build Coastguard Worker     }
5215*4bdc9457SAndroid Build Coastguard Worker   }
5216*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_subtile)5217*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_subtile) {
5218*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
5219*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5220*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
5221*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
5222*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
5223*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
5224*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
5225*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
5226*4bdc9457SAndroid Build Coastguard Worker             .m(m)
5227*4bdc9457SAndroid Build Coastguard Worker             .n(n)
5228*4bdc9457SAndroid Build Coastguard Worker             .k(k)
5229*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
5230*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5231*4bdc9457SAndroid Build Coastguard Worker         }
5232*4bdc9457SAndroid Build Coastguard Worker       }
5233*4bdc9457SAndroid Build Coastguard Worker     }
5234*4bdc9457SAndroid Build Coastguard Worker   }
5235*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel)5236*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel) {
5237*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5238*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5239*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
5240*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
5241*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5242*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5243*4bdc9457SAndroid Build Coastguard Worker         .m(6)
5244*4bdc9457SAndroid Build Coastguard Worker         .n(8)
5245*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5246*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
5247*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5248*4bdc9457SAndroid Build Coastguard Worker     }
5249*4bdc9457SAndroid Build Coastguard Worker   }
5250*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,small_kernel_subtile)5251*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, small_kernel_subtile) {
5252*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5253*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
5254*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
5255*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
5256*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
5257*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
5258*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
5259*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
5260*4bdc9457SAndroid Build Coastguard Worker             .m(m)
5261*4bdc9457SAndroid Build Coastguard Worker             .n(n)
5262*4bdc9457SAndroid Build Coastguard Worker             .k(k)
5263*4bdc9457SAndroid Build Coastguard Worker             .ks(3)
5264*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
5265*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5266*4bdc9457SAndroid Build Coastguard Worker         }
5267*4bdc9457SAndroid Build Coastguard Worker       }
5268*4bdc9457SAndroid Build Coastguard Worker     }
5269*4bdc9457SAndroid Build Coastguard Worker   }
5270*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_gt_8_small_kernel)5271*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_gt_8_small_kernel) {
5272*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 9; n < 16; n++) {
5273*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5274*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5275*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5276*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5277*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5278*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5279*4bdc9457SAndroid Build Coastguard Worker           .m(6)
5280*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5281*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5282*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
5283*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5284*4bdc9457SAndroid Build Coastguard Worker       }
5285*4bdc9457SAndroid Build Coastguard Worker     }
5286*4bdc9457SAndroid Build Coastguard Worker   }
5287*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,n_div_8_small_kernel)5288*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, n_div_8_small_kernel) {
5289*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 16; n <= 24; n += 8) {
5290*4bdc9457SAndroid Build Coastguard Worker       for (size_t k = 1; k <= 5; k += 2) {
5291*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5292*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5293*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5294*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5295*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5296*4bdc9457SAndroid Build Coastguard Worker           .m(6)
5297*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5298*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5299*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
5300*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5301*4bdc9457SAndroid Build Coastguard Worker       }
5302*4bdc9457SAndroid Build Coastguard Worker     }
5303*4bdc9457SAndroid Build Coastguard Worker   }
5304*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm_subtile)5305*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm_subtile) {
5306*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5307*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t n = 1; n <= 8; n++) {
5308*4bdc9457SAndroid Build Coastguard Worker         for (uint32_t m = 1; m <= 6; m++) {
5309*4bdc9457SAndroid Build Coastguard Worker           GemmMicrokernelTester()
5310*4bdc9457SAndroid Build Coastguard Worker             .mr(6)
5311*4bdc9457SAndroid Build Coastguard Worker             .nr(8)
5312*4bdc9457SAndroid Build Coastguard Worker             .kr(1)
5313*4bdc9457SAndroid Build Coastguard Worker             .sr(1)
5314*4bdc9457SAndroid Build Coastguard Worker             .m(m)
5315*4bdc9457SAndroid Build Coastguard Worker             .n(n)
5316*4bdc9457SAndroid Build Coastguard Worker             .k(k)
5317*4bdc9457SAndroid Build Coastguard Worker             .cm_stride(11)
5318*4bdc9457SAndroid Build Coastguard Worker             .iterations(1)
5319*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5320*4bdc9457SAndroid Build Coastguard Worker         }
5321*4bdc9457SAndroid Build Coastguard Worker       }
5322*4bdc9457SAndroid Build Coastguard Worker     }
5323*4bdc9457SAndroid Build Coastguard Worker   }
5324*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,a_offset)5325*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, a_offset) {
5326*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5327*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5328*4bdc9457SAndroid Build Coastguard Worker         .mr(6)
5329*4bdc9457SAndroid Build Coastguard Worker         .nr(8)
5330*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5331*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5332*4bdc9457SAndroid Build Coastguard Worker         .m(6)
5333*4bdc9457SAndroid Build Coastguard Worker         .n(8)
5334*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5335*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
5336*4bdc9457SAndroid Build Coastguard Worker         .a_offset(37)
5337*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5338*4bdc9457SAndroid Build Coastguard Worker     }
5339*4bdc9457SAndroid Build Coastguard Worker   }
5340*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,zero)5341*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, zero) {
5342*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5343*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t mz = 0; mz < 6; mz++) {
5344*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5345*4bdc9457SAndroid Build Coastguard Worker           .mr(6)
5346*4bdc9457SAndroid Build Coastguard Worker           .nr(8)
5347*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5348*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5349*4bdc9457SAndroid Build Coastguard Worker           .m(6)
5350*4bdc9457SAndroid Build Coastguard Worker           .n(8)
5351*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5352*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
5353*4bdc9457SAndroid Build Coastguard Worker           .a_offset(37)
5354*4bdc9457SAndroid Build Coastguard Worker           .zero_index(mz)
5355*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5356*4bdc9457SAndroid Build Coastguard Worker       }
5357*4bdc9457SAndroid Build Coastguard Worker     }
5358*4bdc9457SAndroid Build Coastguard Worker   }
5359*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT,strided_cm)5360*4bdc9457SAndroid Build Coastguard Worker   TEST(F32_IGEMM_6X8__WASMRELAXEDSIMD_FMA_LOADSPLAT, strided_cm) {
5361*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5362*4bdc9457SAndroid Build Coastguard Worker       .mr(6)
5363*4bdc9457SAndroid Build Coastguard Worker       .nr(8)
5364*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5365*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5366*4bdc9457SAndroid Build Coastguard Worker       .m(6)
5367*4bdc9457SAndroid Build Coastguard Worker       .n(8)
5368*4bdc9457SAndroid Build Coastguard Worker       .k(1)
5369*4bdc9457SAndroid Build Coastguard Worker       .cm_stride(11)
5370*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_6x8__wasmrelaxedsimd_fma_loadsplat);
5371*4bdc9457SAndroid Build Coastguard Worker   }
5372*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_WASMRELAXEDSIMD
5373*4bdc9457SAndroid Build Coastguard Worker 
5374*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,k_eq_1)5375*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, k_eq_1) {
5376*4bdc9457SAndroid Build Coastguard Worker   GemmMicrokernelTester()
5377*4bdc9457SAndroid Build Coastguard Worker     .mr(2)
5378*4bdc9457SAndroid Build Coastguard Worker     .nr(4)
5379*4bdc9457SAndroid Build Coastguard Worker     .kr(1)
5380*4bdc9457SAndroid Build Coastguard Worker     .sr(1)
5381*4bdc9457SAndroid Build Coastguard Worker     .m(2)
5382*4bdc9457SAndroid Build Coastguard Worker     .n(4)
5383*4bdc9457SAndroid Build Coastguard Worker     .k(1)
5384*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5385*4bdc9457SAndroid Build Coastguard Worker }
5386*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,strided_cn)5387*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, strided_cn) {
5388*4bdc9457SAndroid Build Coastguard Worker   GemmMicrokernelTester()
5389*4bdc9457SAndroid Build Coastguard Worker     .mr(2)
5390*4bdc9457SAndroid Build Coastguard Worker     .nr(4)
5391*4bdc9457SAndroid Build Coastguard Worker     .kr(1)
5392*4bdc9457SAndroid Build Coastguard Worker     .sr(1)
5393*4bdc9457SAndroid Build Coastguard Worker     .m(2)
5394*4bdc9457SAndroid Build Coastguard Worker     .n(4)
5395*4bdc9457SAndroid Build Coastguard Worker     .k(1)
5396*4bdc9457SAndroid Build Coastguard Worker     .cn_stride(7)
5397*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5398*4bdc9457SAndroid Build Coastguard Worker }
5399*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,k_eq_1_subtile)5400*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, k_eq_1_subtile) {
5401*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 1; n <= 4; n++) {
5402*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t m = 1; m <= 2; m++) {
5403*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5404*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5405*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5406*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5407*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5408*4bdc9457SAndroid Build Coastguard Worker         .m(m)
5409*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5410*4bdc9457SAndroid Build Coastguard Worker         .k(1)
5411*4bdc9457SAndroid Build Coastguard Worker         .iterations(1)
5412*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5413*4bdc9457SAndroid Build Coastguard Worker     }
5414*4bdc9457SAndroid Build Coastguard Worker   }
5415*4bdc9457SAndroid Build Coastguard Worker }
5416*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,k_eq_1_subtile_m)5417*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, k_eq_1_subtile_m) {
5418*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t m = 1; m <= 2; m++) {
5419*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5420*4bdc9457SAndroid Build Coastguard Worker       .mr(2)
5421*4bdc9457SAndroid Build Coastguard Worker       .nr(4)
5422*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5423*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5424*4bdc9457SAndroid Build Coastguard Worker       .m(m)
5425*4bdc9457SAndroid Build Coastguard Worker       .n(4)
5426*4bdc9457SAndroid Build Coastguard Worker       .k(1)
5427*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
5428*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5429*4bdc9457SAndroid Build Coastguard Worker   }
5430*4bdc9457SAndroid Build Coastguard Worker }
5431*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,k_eq_1_subtile_n)5432*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, k_eq_1_subtile_n) {
5433*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 1; n <= 4; n++) {
5434*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5435*4bdc9457SAndroid Build Coastguard Worker       .mr(2)
5436*4bdc9457SAndroid Build Coastguard Worker       .nr(4)
5437*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5438*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5439*4bdc9457SAndroid Build Coastguard Worker       .m(2)
5440*4bdc9457SAndroid Build Coastguard Worker       .n(n)
5441*4bdc9457SAndroid Build Coastguard Worker       .k(1)
5442*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
5443*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5444*4bdc9457SAndroid Build Coastguard Worker   }
5445*4bdc9457SAndroid Build Coastguard Worker }
5446*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,k_gt_1)5447*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, k_gt_1) {
5448*4bdc9457SAndroid Build Coastguard Worker   for (size_t k = 2; k < 10; k++) {
5449*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5450*4bdc9457SAndroid Build Coastguard Worker       .mr(2)
5451*4bdc9457SAndroid Build Coastguard Worker       .nr(4)
5452*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5453*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5454*4bdc9457SAndroid Build Coastguard Worker       .m(2)
5455*4bdc9457SAndroid Build Coastguard Worker       .n(4)
5456*4bdc9457SAndroid Build Coastguard Worker       .k(k)
5457*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5458*4bdc9457SAndroid Build Coastguard Worker   }
5459*4bdc9457SAndroid Build Coastguard Worker }
5460*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,k_gt_1_subtile)5461*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, k_gt_1_subtile) {
5462*4bdc9457SAndroid Build Coastguard Worker   for (size_t k = 2; k < 10; k++) {
5463*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 4; n++) {
5464*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 2; m++) {
5465*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5466*4bdc9457SAndroid Build Coastguard Worker           .mr(2)
5467*4bdc9457SAndroid Build Coastguard Worker           .nr(4)
5468*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5469*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5470*4bdc9457SAndroid Build Coastguard Worker           .m(m)
5471*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5472*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5473*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
5474*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5475*4bdc9457SAndroid Build Coastguard Worker       }
5476*4bdc9457SAndroid Build Coastguard Worker     }
5477*4bdc9457SAndroid Build Coastguard Worker   }
5478*4bdc9457SAndroid Build Coastguard Worker }
5479*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_gt_4)5480*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_gt_4) {
5481*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 5; n < 8; n++) {
5482*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5483*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5484*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5485*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5486*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5487*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5488*4bdc9457SAndroid Build Coastguard Worker         .m(2)
5489*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5490*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5491*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5492*4bdc9457SAndroid Build Coastguard Worker     }
5493*4bdc9457SAndroid Build Coastguard Worker   }
5494*4bdc9457SAndroid Build Coastguard Worker }
5495*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_gt_4_strided_cn)5496*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_gt_4_strided_cn) {
5497*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 5; n < 8; n++) {
5498*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5499*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5500*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5501*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5502*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5503*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5504*4bdc9457SAndroid Build Coastguard Worker         .m(2)
5505*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5506*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5507*4bdc9457SAndroid Build Coastguard Worker         .cn_stride(7)
5508*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5509*4bdc9457SAndroid Build Coastguard Worker     }
5510*4bdc9457SAndroid Build Coastguard Worker   }
5511*4bdc9457SAndroid Build Coastguard Worker }
5512*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_gt_4_subtile)5513*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_gt_4_subtile) {
5514*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 5; n < 8; n++) {
5515*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5516*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 2; m++) {
5517*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5518*4bdc9457SAndroid Build Coastguard Worker           .mr(2)
5519*4bdc9457SAndroid Build Coastguard Worker           .nr(4)
5520*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5521*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5522*4bdc9457SAndroid Build Coastguard Worker           .m(m)
5523*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5524*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5525*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
5526*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5527*4bdc9457SAndroid Build Coastguard Worker       }
5528*4bdc9457SAndroid Build Coastguard Worker     }
5529*4bdc9457SAndroid Build Coastguard Worker   }
5530*4bdc9457SAndroid Build Coastguard Worker }
5531*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_div_4)5532*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_div_4) {
5533*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 8; n <= 12; n += 4) {
5534*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5535*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5536*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5537*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5538*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5539*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5540*4bdc9457SAndroid Build Coastguard Worker         .m(2)
5541*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5542*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5543*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5544*4bdc9457SAndroid Build Coastguard Worker     }
5545*4bdc9457SAndroid Build Coastguard Worker   }
5546*4bdc9457SAndroid Build Coastguard Worker }
5547*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_div_4_strided_cn)5548*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_div_4_strided_cn) {
5549*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 8; n <= 12; n += 4) {
5550*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5551*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5552*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5553*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5554*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5555*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5556*4bdc9457SAndroid Build Coastguard Worker         .m(2)
5557*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5558*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5559*4bdc9457SAndroid Build Coastguard Worker         .cn_stride(7)
5560*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5561*4bdc9457SAndroid Build Coastguard Worker     }
5562*4bdc9457SAndroid Build Coastguard Worker   }
5563*4bdc9457SAndroid Build Coastguard Worker }
5564*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_div_4_subtile)5565*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_div_4_subtile) {
5566*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 8; n <= 12; n += 4) {
5567*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5568*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 2; m++) {
5569*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5570*4bdc9457SAndroid Build Coastguard Worker           .mr(2)
5571*4bdc9457SAndroid Build Coastguard Worker           .nr(4)
5572*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5573*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5574*4bdc9457SAndroid Build Coastguard Worker           .m(m)
5575*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5576*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5577*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
5578*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5579*4bdc9457SAndroid Build Coastguard Worker       }
5580*4bdc9457SAndroid Build Coastguard Worker     }
5581*4bdc9457SAndroid Build Coastguard Worker   }
5582*4bdc9457SAndroid Build Coastguard Worker }
5583*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,small_kernel)5584*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, small_kernel) {
5585*4bdc9457SAndroid Build Coastguard Worker   for (size_t k = 1; k <= 5; k += 2) {
5586*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5587*4bdc9457SAndroid Build Coastguard Worker       .mr(2)
5588*4bdc9457SAndroid Build Coastguard Worker       .nr(4)
5589*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5590*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5591*4bdc9457SAndroid Build Coastguard Worker       .m(2)
5592*4bdc9457SAndroid Build Coastguard Worker       .n(4)
5593*4bdc9457SAndroid Build Coastguard Worker       .k(k)
5594*4bdc9457SAndroid Build Coastguard Worker       .ks(3)
5595*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5596*4bdc9457SAndroid Build Coastguard Worker   }
5597*4bdc9457SAndroid Build Coastguard Worker }
5598*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,small_kernel_subtile)5599*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, small_kernel_subtile) {
5600*4bdc9457SAndroid Build Coastguard Worker   for (size_t k = 1; k <= 5; k += 2) {
5601*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 4; n++) {
5602*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 2; m++) {
5603*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5604*4bdc9457SAndroid Build Coastguard Worker           .mr(2)
5605*4bdc9457SAndroid Build Coastguard Worker           .nr(4)
5606*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5607*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5608*4bdc9457SAndroid Build Coastguard Worker           .m(m)
5609*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5610*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5611*4bdc9457SAndroid Build Coastguard Worker           .ks(3)
5612*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
5613*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5614*4bdc9457SAndroid Build Coastguard Worker       }
5615*4bdc9457SAndroid Build Coastguard Worker     }
5616*4bdc9457SAndroid Build Coastguard Worker   }
5617*4bdc9457SAndroid Build Coastguard Worker }
5618*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_gt_4_small_kernel)5619*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_gt_4_small_kernel) {
5620*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 5; n < 8; n++) {
5621*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5622*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5623*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5624*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5625*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5626*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5627*4bdc9457SAndroid Build Coastguard Worker         .m(2)
5628*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5629*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5630*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
5631*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5632*4bdc9457SAndroid Build Coastguard Worker     }
5633*4bdc9457SAndroid Build Coastguard Worker   }
5634*4bdc9457SAndroid Build Coastguard Worker }
5635*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,n_div_4_small_kernel)5636*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, n_div_4_small_kernel) {
5637*4bdc9457SAndroid Build Coastguard Worker   for (uint32_t n = 8; n <= 12; n += 4) {
5638*4bdc9457SAndroid Build Coastguard Worker     for (size_t k = 1; k <= 5; k += 2) {
5639*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5640*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5641*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5642*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5643*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5644*4bdc9457SAndroid Build Coastguard Worker         .m(2)
5645*4bdc9457SAndroid Build Coastguard Worker         .n(n)
5646*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5647*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
5648*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5649*4bdc9457SAndroid Build Coastguard Worker     }
5650*4bdc9457SAndroid Build Coastguard Worker   }
5651*4bdc9457SAndroid Build Coastguard Worker }
5652*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,strided_cm_subtile)5653*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, strided_cm_subtile) {
5654*4bdc9457SAndroid Build Coastguard Worker   for (size_t k = 1; k <= 5; k += 2) {
5655*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t n = 1; n <= 4; n++) {
5656*4bdc9457SAndroid Build Coastguard Worker       for (uint32_t m = 1; m <= 2; m++) {
5657*4bdc9457SAndroid Build Coastguard Worker         GemmMicrokernelTester()
5658*4bdc9457SAndroid Build Coastguard Worker           .mr(2)
5659*4bdc9457SAndroid Build Coastguard Worker           .nr(4)
5660*4bdc9457SAndroid Build Coastguard Worker           .kr(1)
5661*4bdc9457SAndroid Build Coastguard Worker           .sr(1)
5662*4bdc9457SAndroid Build Coastguard Worker           .m(m)
5663*4bdc9457SAndroid Build Coastguard Worker           .n(n)
5664*4bdc9457SAndroid Build Coastguard Worker           .k(k)
5665*4bdc9457SAndroid Build Coastguard Worker           .cm_stride(7)
5666*4bdc9457SAndroid Build Coastguard Worker           .iterations(1)
5667*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5668*4bdc9457SAndroid Build Coastguard Worker       }
5669*4bdc9457SAndroid Build Coastguard Worker     }
5670*4bdc9457SAndroid Build Coastguard Worker   }
5671*4bdc9457SAndroid Build Coastguard Worker }
5672*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,a_offset)5673*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, a_offset) {
5674*4bdc9457SAndroid Build Coastguard Worker   for (size_t k = 1; k <= 5; k += 2) {
5675*4bdc9457SAndroid Build Coastguard Worker     GemmMicrokernelTester()
5676*4bdc9457SAndroid Build Coastguard Worker       .mr(2)
5677*4bdc9457SAndroid Build Coastguard Worker       .nr(4)
5678*4bdc9457SAndroid Build Coastguard Worker       .kr(1)
5679*4bdc9457SAndroid Build Coastguard Worker       .sr(1)
5680*4bdc9457SAndroid Build Coastguard Worker       .m(2)
5681*4bdc9457SAndroid Build Coastguard Worker       .n(4)
5682*4bdc9457SAndroid Build Coastguard Worker       .k(k)
5683*4bdc9457SAndroid Build Coastguard Worker       .ks(3)
5684*4bdc9457SAndroid Build Coastguard Worker       .a_offset(13)
5685*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5686*4bdc9457SAndroid Build Coastguard Worker   }
5687*4bdc9457SAndroid Build Coastguard Worker }
5688*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,zero)5689*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, zero) {
5690*4bdc9457SAndroid Build Coastguard Worker   for (size_t k = 1; k <= 5; k += 2) {
5691*4bdc9457SAndroid Build Coastguard Worker     for (uint32_t mz = 0; mz < 2; mz++) {
5692*4bdc9457SAndroid Build Coastguard Worker       GemmMicrokernelTester()
5693*4bdc9457SAndroid Build Coastguard Worker         .mr(2)
5694*4bdc9457SAndroid Build Coastguard Worker         .nr(4)
5695*4bdc9457SAndroid Build Coastguard Worker         .kr(1)
5696*4bdc9457SAndroid Build Coastguard Worker         .sr(1)
5697*4bdc9457SAndroid Build Coastguard Worker         .m(2)
5698*4bdc9457SAndroid Build Coastguard Worker         .n(4)
5699*4bdc9457SAndroid Build Coastguard Worker         .k(k)
5700*4bdc9457SAndroid Build Coastguard Worker         .ks(3)
5701*4bdc9457SAndroid Build Coastguard Worker         .a_offset(13)
5702*4bdc9457SAndroid Build Coastguard Worker         .zero_index(mz)
5703*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5704*4bdc9457SAndroid Build Coastguard Worker     }
5705*4bdc9457SAndroid Build Coastguard Worker   }
5706*4bdc9457SAndroid Build Coastguard Worker }
5707*4bdc9457SAndroid Build Coastguard Worker 
TEST(F32_IGEMM_2X4__SCALAR,strided_cm)5708*4bdc9457SAndroid Build Coastguard Worker TEST(F32_IGEMM_2X4__SCALAR, strided_cm) {
5709*4bdc9457SAndroid Build Coastguard Worker   GemmMicrokernelTester()
5710*4bdc9457SAndroid Build Coastguard Worker     .mr(2)
5711*4bdc9457SAndroid Build Coastguard Worker     .nr(4)
5712*4bdc9457SAndroid Build Coastguard Worker     .kr(1)
5713*4bdc9457SAndroid Build Coastguard Worker     .sr(1)
5714*4bdc9457SAndroid Build Coastguard Worker     .m(2)
5715*4bdc9457SAndroid Build Coastguard Worker     .n(4)
5716*4bdc9457SAndroid Build Coastguard Worker     .k(1)
5717*4bdc9457SAndroid Build Coastguard Worker     .cm_stride(7)
5718*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_f32_igemm_ukernel_2x4__scalar);
5719*4bdc9457SAndroid Build Coastguard Worker }
5720