27 #if defined(ARM_COMPUTE_ENABLE_SVE)
31 void sve_transpose_interleave_6VL_1x8(uint8_t *out,
const uint8_t *in,
size_t width,
size_t in_stride,
size_t height)
33 uint8_t *pad_row =
reinterpret_cast<uint8_t *
>(alloca(width *
sizeof(uint8_t)));
36 memset(pad_row, 0, width *
sizeof(uint8_t));
39 size_t out_stride = 6 * roundup<size_t>(height, 8) * get_vector_length<uint64_t>();
45 "add x9, x10, %x[in_stride]\n"
46 "add x28, x9, %x[in_stride]\n"
47 "add x27, x28, %x[in_stride]\n"
48 "add x26, x27, %x[in_stride]\n"
49 "add x25, x26, %x[in_stride]\n"
50 "add x24, x25, %x[in_stride]\n"
51 "add x23, x24, %x[in_stride]\n"
52 "cmp %x[height], #0x7\n"
53 "add %x[in], x23, %x[in_stride]\n"
54 "csel x23, x23, %x[pad_row], GT\n"
55 "csel x24, x24, %x[pad_row], GE\n"
56 "cmp %x[height], #0x5\n"
57 "mov x22, %x[width]\n"
58 "cntb x21, ALL, MUL #3\n"
59 "csel x25, x25, %x[pad_row], GT\n"
60 "csel x26, x26, %x[pad_row], GE\n"
61 "cmp %x[height], #0x3\n"
62 "csel x27, x27, %x[pad_row], GT\n"
63 "csel x28, x28, %x[pad_row], GE\n"
64 "cmp %x[height], #0x1\n"
65 "csel x9, x9, %x[pad_row], GT\n"
68 "sub %x[height], %x[height], #0x8\n"
71 "ld1b { z21.b }, p1/Z, [x10]\n"
72 "ld1b { z25.b }, p1/Z, [x9]\n"
75 "ld1b { z20.b }, p1/Z, [x28]\n"
76 "ld1b { z24.b }, p1/Z, [x27]\n"
77 "ld1b { z19.b }, p1/Z, [x26]\n"
78 "ld1b { z18.b }, p1/Z, [x25]\n"
79 "zip1 z7.b, z21.b, z19.b\n"
80 "zip1 z6.b, z25.b, z18.b\n"
81 "ld1b { z17.b }, p1/Z, [x24]\n"
82 "ld1b { z16.b }, p1/Z, [x23]\n"
83 "zip1 z28.b, z20.b, z17.b\n"
84 "zip1 z27.b, z24.b, z16.b\n"
85 "ld1b { z23.b }, p1/Z, [x10, #1, MUL VL]\n"
86 "ld1b { z22.b }, p1/Z, [x9, #1, MUL VL]\n"
87 "zip2 z5.b, z21.b, z19.b\n"
88 "zip2 z4.b, z20.b, z17.b\n"
89 "ld1b { z21.b }, p1/Z, [x28, #1, MUL VL]\n"
90 "ld1b { z20.b }, p1/Z, [x27, #1, MUL VL]\n"
91 "zip2 z3.b, z25.b, z18.b\n"
92 "zip2 z2.b, z24.b, z16.b\n"
93 "ld1b { z19.b }, p1/Z, [x26, #1, MUL VL]\n"
94 "ld1b { z18.b }, p1/Z, [x25, #1, MUL VL]\n"
95 "zip1 z1.b, z23.b, z19.b\n"
96 "zip1 z15.b, z22.b, z18.b\n"
97 "ld1b { z17.b }, p1/Z, [x24, #1, MUL VL]\n"
98 "ld1b { z16.b }, p1/Z, [x23, #1, MUL VL]\n"
99 "zip1 z0.b, z21.b, z17.b\n"
100 "zip1 z31.b, z20.b, z16.b\n"
101 "ld1b { z26.b }, p1/Z, [x10, #2, MUL VL]\n"
102 "ld1b { z30.b }, p1/Z, [x9, #2, MUL VL]\n"
103 "zip2 z14.b, z23.b, z19.b\n"
104 "zip2 z13.b, z21.b, z17.b\n"
105 "ld1b { z25.b }, p1/Z, [x28, #2, MUL VL]\n"
106 "ld1b { z24.b }, p1/Z, [x27, #2, MUL VL]\n"
107 "zip2 z12.b, z22.b, z18.b\n"
108 "zip2 z11.b, z20.b, z16.b\n"
109 "ld1b { z23.b }, p1/Z, [x26, #2, MUL VL]\n"
110 "ld1b { z22.b }, p1/Z, [x25, #2, MUL VL]\n"
111 "zip1 z10.b, z26.b, z23.b\n"
112 "zip1 z9.b, z30.b, z22.b\n"
113 "ld1b { z21.b }, p1/Z, [x24, #2, MUL VL]\n"
114 "ld1b { z17.b }, p1/Z, [x23, #2, MUL VL]\n"
115 "zip1 z29.b, z25.b, z21.b\n"
116 "zip1 z8.b, z24.b, z17.b\n"
117 "zip1 z19.b, z7.b, z28.b\n"
118 "zip1 z16.b, z6.b, z27.b\n"
119 "addvl x10, x10, #3\n"
121 "zip2 z28.b, z7.b, z28.b\n"
122 "zip2 z18.b, z6.b, z27.b\n"
123 "addvl x28, x28, #3\n"
124 "addvl x27, x27, #3\n"
125 "zip1 z27.b, z5.b, z4.b\n"
126 "zip1 z20.b, z3.b, z2.b\n"
127 "addvl x26, x26, #3\n"
128 "addvl x25, x25, #3\n"
129 "zip2 z7.b, z26.b, z23.b\n"
130 "zip2 z26.b, z25.b, z21.b\n"
131 "addvl x24, x24, #3\n"
132 "addvl x23, x23, #3\n"
133 "zip2 z6.b, z30.b, z22.b\n"
134 "zip2 z25.b, z24.b, z17.b\n"
135 "zip2 z5.b, z5.b, z4.b\n"
136 "zip2 z4.b, z3.b, z2.b\n"
137 "zip1 z3.b, z1.b, z0.b\n"
138 "zip1 z2.b, z15.b, z31.b\n"
139 "zip2 z1.b, z1.b, z0.b\n"
140 "zip2 z0.b, z15.b, z31.b\n"
141 "zip1 z31.b, z14.b, z13.b\n"
142 "zip1 z30.b, z12.b, z11.b\n"
143 "zip2 z24.b, z14.b, z13.b\n"
144 "zip2 z23.b, z12.b, z11.b\n"
145 "zip1 z22.b, z10.b, z29.b\n"
146 "zip1 z21.b, z9.b, z8.b\n"
147 "zip1 z17.b, z19.b, z16.b\n"
148 "zip2 z16.b, z19.b, z16.b\n"
149 "st1b { z17.b }, p1, [x20]\n"
150 "zip1 z19.b, z28.b, z18.b\n"
151 "zip2 z18.b, z28.b, z18.b\n"
152 "st1b { z16.b }, p1, [x20, #1, MUL VL]\n"
153 "zip1 z17.b, z27.b, z20.b\n"
154 "zip2 z16.b, z27.b, z20.b\n"
155 "st1b { z19.b }, p1, [x20, #2, MUL VL]\n"
156 "st1b { z18.b }, p1, [x20, #3, MUL VL]\n"
157 "zip2 z29.b, z10.b, z29.b\n"
158 "zip2 z20.b, z9.b, z8.b\n"
159 "st1b { z17.b }, p1, [x20, #4, MUL VL]\n"
160 "zip1 z28.b, z7.b, z26.b\n"
161 "zip1 z27.b, z6.b, z25.b\n"
162 "st1b { z16.b }, p1, [x20, #5, MUL VL]\n"
163 "add x20, x20, %x[out_stride]\n"
164 "zip2 z26.b, z7.b, z26.b\n"
165 "zip2 z25.b, z6.b, z25.b\n"
166 "zip1 z17.b, z5.b, z4.b\n"
167 "zip2 z16.b, z5.b, z4.b\n"
168 "st1b { z17.b }, p1, [x20]\n"
169 "zip1 z18.b, z3.b, z2.b\n"
170 "zip2 z17.b, z3.b, z2.b\n"
171 "st1b { z16.b }, p1, [x20, #1, MUL VL]\n"
172 "zip1 z16.b, z1.b, z0.b\n"
173 "zip2 z19.b, z1.b, z0.b\n"
174 "st1b { z18.b }, p1, [x20, #2, MUL VL]\n"
175 "st1b { z17.b }, p1, [x20, #3, MUL VL]\n"
176 "zip1 z18.b, z31.b, z30.b\n"
177 "zip2 z17.b, z31.b, z30.b\n"
178 "st1b { z16.b }, p1, [x20, #4, MUL VL]\n"
179 "zip1 z16.b, z24.b, z23.b\n"
180 "zip2 z24.b, z24.b, z23.b\n"
181 "st1b { z19.b }, p1, [x20, #5, MUL VL]\n"
182 "add x20, x20, %x[out_stride]\n"
183 "zip1 z23.b, z22.b, z21.b\n"
184 "zip2 z22.b, z22.b, z21.b\n"
185 "st1b { z18.b }, p1, [x20]\n"
186 "zip1 z21.b, z29.b, z20.b\n"
187 "zip2 z20.b, z29.b, z20.b\n"
188 "st1b { z17.b }, p1, [x20, #1, MUL VL]\n"
189 "zip1 z19.b, z28.b, z27.b\n"
190 "zip2 z18.b, z28.b, z27.b\n"
191 "st1b { z16.b }, p1, [x20, #2, MUL VL]\n"
192 "zip1 z17.b, z26.b, z25.b\n"
193 "zip2 z16.b, z26.b, z25.b\n"
194 "st1b { z24.b }, p1, [x20, #3, MUL VL]\n"
195 "st1b { z23.b }, p1, [x20, #4, MUL VL]\n"
196 "st1b { z22.b }, p1, [x20, #5, MUL VL]\n"
197 "add x20, x20, %x[out_stride]\n"
198 "st1b { z21.b }, p1, [x20]\n"
199 "st1b { z20.b }, p1, [x20, #1, MUL VL]\n"
200 "st1b { z19.b }, p1, [x20, #2, MUL VL]\n"
201 "st1b { z18.b }, p1, [x20, #3, MUL VL]\n"
202 "st1b { z17.b }, p1, [x20, #4, MUL VL]\n"
203 "st1b { z16.b }, p1, [x20, #5, MUL VL]\n"
204 "add x20, x20, %x[out_stride]\n"
209 "whilelt p0.b, XZR, x22\n"
210 "ld1b { z23.b }, p0/Z, [x10]\n"
211 "ld1b { z27.b }, p0/Z, [x9]\n"
212 "decd x22, ALL, MUL #6\n"
213 "ld1b { z21.b }, p0/Z, [x28]\n"
214 "ld1b { z26.b }, p0/Z, [x27]\n"
216 "incd x10, ALL, MUL #6\n"
217 "ld1b { z20.b }, p0/Z, [x26]\n"
218 "ld1b { z19.b }, p0/Z, [x25]\n"
219 "zip1 z25.b, z23.b, z20.b\n"
220 "zip1 z24.b, z27.b, z19.b\n"
221 "ld1b { z17.b }, p0/Z, [x24]\n"
222 "ld1b { z16.b }, p0/Z, [x23]\n"
223 "zip1 z22.b, z21.b, z17.b\n"
224 "zip1 z18.b, z26.b, z16.b\n"
225 "zip2 z23.b, z23.b, z20.b\n"
226 "zip2 z21.b, z21.b, z17.b\n"
227 "incd x9, ALL, MUL #6\n"
228 "incd x28, ALL, MUL #6\n"
229 "zip2 z20.b, z27.b, z19.b\n"
230 "zip2 z17.b, z26.b, z16.b\n"
231 "incd x27, ALL, MUL #6\n"
232 "incd x26, ALL, MUL #6\n"
233 "zip1 z19.b, z25.b, z22.b\n"
234 "zip1 z16.b, z24.b, z18.b\n"
235 "incd x25, ALL, MUL #6\n"
236 "incd x24, ALL, MUL #6\n"
237 "zip2 z22.b, z25.b, z22.b\n"
238 "zip2 z18.b, z24.b, z18.b\n"
239 "incd x23, ALL, MUL #6\n"
240 "zip1 z21.b, z23.b, z21.b\n"
241 "zip1 z20.b, z20.b, z17.b\n"
242 "zip1 z17.b, z19.b, z16.b\n"
243 "zip2 z16.b, z19.b, z16.b\n"
244 "st1b { z17.b }, p1, [x20]\n"
245 "zip1 z19.b, z22.b, z18.b\n"
246 "zip2 z18.b, z22.b, z18.b\n"
247 "st1b { z16.b }, p1, [x20, #1, MUL VL]\n"
248 "zip1 z17.b, z21.b, z20.b\n"
249 "zip2 z16.b, z21.b, z20.b\n"
250 "st1b { z19.b }, p1, [x20, #2, MUL VL]\n"
251 "st1b { z18.b }, p1, [x20, #3, MUL VL]\n"
252 "st1b { z17.b }, p1, [x20, #4, MUL VL]\n"
253 "st1b { z16.b }, p1, [x20, #5, MUL VL]\n"
254 "add x20, x20, %x[out_stride]\n"
257 "cmp %x[height], #0x1\n"
258 "addvl %x[out], %x[out], #6\n"
260 : [height]
"+&r" (height), [in]
"+&r" (in), [out]
"+&r" (out)
261 : [in_stride]
"r" (in_stride), [out_stride]
"r" (out_stride), [pad_row]
"r" (pad_row), [width]
"r" (width)
262 :
"cc",
"memory",
"p0",
"p1",
"x9",
"x10",
"x20",
"x21",
"x22",
"x23",
"x24",
"x25",
"x26",
"x27",
"x28",
"z0",
"z1",
"z2",
"z3",
"z4",
"z5",
"z6",
"z7",
"z8",
"z9",
"z10",
"z11",
"z12",
"z13",
"z14",
"z15",
"z16",
"z17",
"z18",
"z19",
"z20",
"z21",
"z22",
"z23",
"z24",
"z25",
"z26",
"z27",
"z28",
"z29",
"z30",
"z31"
269 void Transform<6, 8, true, VLType::SVE>(
270 uint8_t *out,
const uint8_t *in,
int stride,
int x0,
int xmax,
int k0,
int kmax)
272 sve_transpose_interleave_6VL_1x8(
273 reinterpret_cast<uint8_t *
>(out),
274 reinterpret_cast<const uint8_t *
>(in + k0 * stride + x0),
275 (xmax-x0) *
sizeof(uint8_t) / 1,
276 stride *
sizeof(uint8_t),
282 void Transform<6, 8, true, VLType::SVE>(
283 int8_t *out,
const int8_t *in,
int stride,
int x0,
int xmax,
int k0,
int kmax)
285 sve_transpose_interleave_6VL_1x8(
286 reinterpret_cast<uint8_t *
>(out),
287 reinterpret_cast<const uint8_t *
>(in + k0 * stride + x0),
288 (xmax-x0) *
sizeof(int8_t) / 1,
289 stride *
sizeof(int8_t),
295 #endif // defined(ARM_COMPUTE_ENABLE_SVE)