1cabdff1aSopenharmony_ci;******************************************************************************
2cabdff1aSopenharmony_ci;* VP9 loop filter SIMD optimizations
3cabdff1aSopenharmony_ci;*
4cabdff1aSopenharmony_ci;* Copyright (C) 2013-2014 Clément Bœsch <u pkh me>
5cabdff1aSopenharmony_ci;* Copyright (C) 2014 Ronald S. Bultje <rsbultje@gmail.com>
6cabdff1aSopenharmony_ci;*
7cabdff1aSopenharmony_ci;* This file is part of FFmpeg.
8cabdff1aSopenharmony_ci;*
9cabdff1aSopenharmony_ci;* FFmpeg is free software; you can redistribute it and/or
10cabdff1aSopenharmony_ci;* modify it under the terms of the GNU Lesser General Public
11cabdff1aSopenharmony_ci;* License as published by the Free Software Foundation; either
12cabdff1aSopenharmony_ci;* version 2.1 of the License, or (at your option) any later version.
13cabdff1aSopenharmony_ci;*
14cabdff1aSopenharmony_ci;* FFmpeg is distributed in the hope that it will be useful,
15cabdff1aSopenharmony_ci;* but WITHOUT ANY WARRANTY; without even the implied warranty of
16cabdff1aSopenharmony_ci;* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
17cabdff1aSopenharmony_ci;* Lesser General Public License for more details.
18cabdff1aSopenharmony_ci;*
19cabdff1aSopenharmony_ci;* You should have received a copy of the GNU Lesser General Public
20cabdff1aSopenharmony_ci;* License along with FFmpeg; if not, write to the Free Software
21cabdff1aSopenharmony_ci;* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22cabdff1aSopenharmony_ci;******************************************************************************
23cabdff1aSopenharmony_ci
24cabdff1aSopenharmony_ci%include "libavutil/x86/x86util.asm"
25cabdff1aSopenharmony_ci
26cabdff1aSopenharmony_ciSECTION_RODATA
27cabdff1aSopenharmony_ci
28cabdff1aSopenharmony_cicextern pb_3
29cabdff1aSopenharmony_cicextern pb_80
30cabdff1aSopenharmony_ci
31cabdff1aSopenharmony_cipb_4:   times 16 db 0x04
32cabdff1aSopenharmony_cipb_10:  times 16 db 0x10
33cabdff1aSopenharmony_cipb_40:  times 16 db 0x40
34cabdff1aSopenharmony_cipb_81:  times 16 db 0x81
35cabdff1aSopenharmony_cipb_f8:  times 16 db 0xf8
36cabdff1aSopenharmony_cipb_fe:  times 16 db 0xfe
37cabdff1aSopenharmony_cipb_ff:  times 16 db 0xff
38cabdff1aSopenharmony_ci
39cabdff1aSopenharmony_cicextern pw_4
40cabdff1aSopenharmony_cicextern pw_8
41cabdff1aSopenharmony_ci
42cabdff1aSopenharmony_ci; with mix functions, two 8-bit thresholds are stored in a 16-bit storage,
43cabdff1aSopenharmony_ci; the following mask is used to splat both in the same register
44cabdff1aSopenharmony_cimask_mix: times 8 db 0
45cabdff1aSopenharmony_ci          times 8 db 1
46cabdff1aSopenharmony_ci
47cabdff1aSopenharmony_cimask_mix84: times 8 db 0xff
48cabdff1aSopenharmony_ci            times 8 db 0x00
49cabdff1aSopenharmony_cimask_mix48: times 8 db 0x00
50cabdff1aSopenharmony_ci            times 8 db 0xff
51cabdff1aSopenharmony_ci
52cabdff1aSopenharmony_ciSECTION .text
53cabdff1aSopenharmony_ci
54cabdff1aSopenharmony_ci%macro SCRATCH 3
55cabdff1aSopenharmony_ci%ifdef m8
56cabdff1aSopenharmony_ci    SWAP                %1, %2
57cabdff1aSopenharmony_ci%else
58cabdff1aSopenharmony_ci    mova              [%3], m%1
59cabdff1aSopenharmony_ci%endif
60cabdff1aSopenharmony_ci%endmacro
61cabdff1aSopenharmony_ci
62cabdff1aSopenharmony_ci%macro UNSCRATCH 3
63cabdff1aSopenharmony_ci%ifdef m8
64cabdff1aSopenharmony_ci    SWAP                %1, %2
65cabdff1aSopenharmony_ci%else
66cabdff1aSopenharmony_ci    mova               m%1, [%3]
67cabdff1aSopenharmony_ci%endif
68cabdff1aSopenharmony_ci%endmacro
69cabdff1aSopenharmony_ci
70cabdff1aSopenharmony_ci; %1 = abs(%2-%3)
71cabdff1aSopenharmony_ci%macro ABSSUB 4 ; dst, src1 (RO), src2 (RO), tmp
72cabdff1aSopenharmony_ci%ifdef m8
73cabdff1aSopenharmony_ci    psubusb             %1, %3, %2
74cabdff1aSopenharmony_ci    psubusb             %4, %2, %3
75cabdff1aSopenharmony_ci%else
76cabdff1aSopenharmony_ci    mova                %1, %3
77cabdff1aSopenharmony_ci    mova                %4, %2
78cabdff1aSopenharmony_ci    psubusb             %1, %2
79cabdff1aSopenharmony_ci    psubusb             %4, %3
80cabdff1aSopenharmony_ci%endif
81cabdff1aSopenharmony_ci    por                 %1, %4
82cabdff1aSopenharmony_ci%endmacro
83cabdff1aSopenharmony_ci
84cabdff1aSopenharmony_ci; %1 = %1>%2
85cabdff1aSopenharmony_ci%macro CMP_GT 2-3 ; src/dst, cmp, pb_80
86cabdff1aSopenharmony_ci%if %0 == 3
87cabdff1aSopenharmony_ci    pxor                %1, %3
88cabdff1aSopenharmony_ci%endif
89cabdff1aSopenharmony_ci    pcmpgtb             %1, %2
90cabdff1aSopenharmony_ci%endmacro
91cabdff1aSopenharmony_ci
92cabdff1aSopenharmony_ci; %1 = abs(%2-%3) > %4
93cabdff1aSopenharmony_ci%macro ABSSUB_GT 5-6 [pb_80]; dst, src1, src2, cmp, tmp, [pb_80]
94cabdff1aSopenharmony_ci    ABSSUB              %1, %2, %3, %5      ; dst = abs(src1-src2)
95cabdff1aSopenharmony_ci    CMP_GT              %1, %4, %6          ; dst > cmp
96cabdff1aSopenharmony_ci%endmacro
97cabdff1aSopenharmony_ci
98cabdff1aSopenharmony_ci%macro MASK_APPLY 4 ; %1=new_data/dst %2=old_data %3=mask %4=tmp
99cabdff1aSopenharmony_ci    pand                %1, %3              ; new &= mask
100cabdff1aSopenharmony_ci    pandn               %4, %3, %2          ; tmp = ~mask & old
101cabdff1aSopenharmony_ci    por                 %1, %4              ; new&mask | old&~mask
102cabdff1aSopenharmony_ci%endmacro
103cabdff1aSopenharmony_ci
104cabdff1aSopenharmony_ci%macro UNPACK 4
105cabdff1aSopenharmony_ci%ifdef m8
106cabdff1aSopenharmony_ci    punpck%1bw          %2, %3, %4
107cabdff1aSopenharmony_ci%else
108cabdff1aSopenharmony_ci    mova                %2, %3
109cabdff1aSopenharmony_ci    punpck%1bw          %2, %4
110cabdff1aSopenharmony_ci%endif
111cabdff1aSopenharmony_ci%endmacro
112cabdff1aSopenharmony_ci
113cabdff1aSopenharmony_ci%macro FILTER_SUBx2_ADDx2 11 ; %1=dst %2=h/l %3=cache %4=stack_off %5=sub1 %6=sub2 %7=add1
114cabdff1aSopenharmony_ci                             ; %8=add2 %9=rshift, [unpack], [unpack_is_mem_on_x86_32]
115cabdff1aSopenharmony_ci    psubw               %3, [rsp+%4+%5*mmsize*2]
116cabdff1aSopenharmony_ci    psubw               %3, [rsp+%4+%6*mmsize*2]
117cabdff1aSopenharmony_ci    paddw               %3, [rsp+%4+%7*mmsize*2]
118cabdff1aSopenharmony_ci%ifnidn %10, ""
119cabdff1aSopenharmony_ci%if %11 == 0
120cabdff1aSopenharmony_ci    punpck%2bw          %1, %10, m0
121cabdff1aSopenharmony_ci%else
122cabdff1aSopenharmony_ci    UNPACK          %2, %1, %10, m0
123cabdff1aSopenharmony_ci%endif
124cabdff1aSopenharmony_ci    mova [rsp+%4+%8*mmsize*2], %1
125cabdff1aSopenharmony_ci    paddw               %3, %1
126cabdff1aSopenharmony_ci%else
127cabdff1aSopenharmony_ci    paddw               %3, [rsp+%4+%8*mmsize*2]
128cabdff1aSopenharmony_ci%endif
129cabdff1aSopenharmony_ci    psraw               %1, %3, %9
130cabdff1aSopenharmony_ci%endmacro
131cabdff1aSopenharmony_ci
132cabdff1aSopenharmony_ci; FIXME interleave l/h better (for instruction pairing)
133cabdff1aSopenharmony_ci%macro FILTER_INIT 9 ; tmp1, tmp2, cacheL, cacheH, dstp, stack_off, filterid, mask, source
134cabdff1aSopenharmony_ci    FILTER%7_INIT       %1, l, %3, %6 +      0
135cabdff1aSopenharmony_ci    FILTER%7_INIT       %2, h, %4, %6 + mmsize
136cabdff1aSopenharmony_ci    packuswb            %1, %2
137cabdff1aSopenharmony_ci    MASK_APPLY          %1, %9, %8, %2
138cabdff1aSopenharmony_ci    mova                %5, %1
139cabdff1aSopenharmony_ci%endmacro
140cabdff1aSopenharmony_ci
141cabdff1aSopenharmony_ci
142cabdff1aSopenharmony_ci%macro FILTER_UPDATE 12-16 "", "", "", 0 ; tmp1, tmp2, cacheL, cacheH, dstp, stack_off, -, -, +, +, rshift,
143cabdff1aSopenharmony_ci                                         ; mask, [source], [unpack + src], [unpack_is_mem_on_x86_32]
144cabdff1aSopenharmony_ci; FIXME interleave this properly with the subx2/addx2
145cabdff1aSopenharmony_ci%ifnidn %15, ""
146cabdff1aSopenharmony_ci%if %16 == 0 || ARCH_X86_64
147cabdff1aSopenharmony_ci    mova               %14, %15
148cabdff1aSopenharmony_ci%endif
149cabdff1aSopenharmony_ci%endif
150cabdff1aSopenharmony_ci    FILTER_SUBx2_ADDx2  %1, l, %3, %6 +      0, %7, %8, %9, %10, %11, %14, %16
151cabdff1aSopenharmony_ci    FILTER_SUBx2_ADDx2  %2, h, %4, %6 + mmsize, %7, %8, %9, %10, %11, %14, %16
152cabdff1aSopenharmony_ci    packuswb            %1, %2
153cabdff1aSopenharmony_ci%ifnidn %13, ""
154cabdff1aSopenharmony_ci    MASK_APPLY          %1, %13, %12, %2
155cabdff1aSopenharmony_ci%else
156cabdff1aSopenharmony_ci    MASK_APPLY          %1, %5, %12, %2
157cabdff1aSopenharmony_ci%endif
158cabdff1aSopenharmony_ci    mova                %5, %1
159cabdff1aSopenharmony_ci%endmacro
160cabdff1aSopenharmony_ci
161cabdff1aSopenharmony_ci%macro SRSHIFT3B_2X 4 ; reg1, reg2, [pb_10], tmp
162cabdff1aSopenharmony_ci    mova                %4, [pb_f8]
163cabdff1aSopenharmony_ci    pand                %1, %4
164cabdff1aSopenharmony_ci    pand                %2, %4
165cabdff1aSopenharmony_ci    psrlq               %1, 3
166cabdff1aSopenharmony_ci    psrlq               %2, 3
167cabdff1aSopenharmony_ci    pxor                %1, %3
168cabdff1aSopenharmony_ci    pxor                %2, %3
169cabdff1aSopenharmony_ci    psubb               %1, %3
170cabdff1aSopenharmony_ci    psubb               %2, %3
171cabdff1aSopenharmony_ci%endmacro
172cabdff1aSopenharmony_ci
173cabdff1aSopenharmony_ci%macro EXTRACT_POS_NEG 3 ; i8, neg, pos
174cabdff1aSopenharmony_ci    pxor                %3, %3
175cabdff1aSopenharmony_ci    pxor                %2, %2
176cabdff1aSopenharmony_ci    pcmpgtb             %3, %1                          ; i8 < 0 mask
177cabdff1aSopenharmony_ci    psubb               %2, %1                          ; neg values (only the originally - will be kept)
178cabdff1aSopenharmony_ci    pand                %2, %3                          ; negative values of i8 (but stored as +)
179cabdff1aSopenharmony_ci    pandn               %3, %1                          ; positive values of i8
180cabdff1aSopenharmony_ci%endmacro
181cabdff1aSopenharmony_ci
182cabdff1aSopenharmony_ci; clip_u8(u8 + i8)
183cabdff1aSopenharmony_ci%macro SIGN_ADD 4 ; dst, u8, i8, tmp1
184cabdff1aSopenharmony_ci    EXTRACT_POS_NEG     %3, %4, %1
185cabdff1aSopenharmony_ci    paddusb             %1, %2                          ; add the positives
186cabdff1aSopenharmony_ci    psubusb             %1, %4                          ; sub the negatives
187cabdff1aSopenharmony_ci%endmacro
188cabdff1aSopenharmony_ci
189cabdff1aSopenharmony_ci; clip_u8(u8 - i8)
190cabdff1aSopenharmony_ci%macro SIGN_SUB 4 ; dst, u8, i8, tmp1
191cabdff1aSopenharmony_ci    EXTRACT_POS_NEG     %3, %1, %4
192cabdff1aSopenharmony_ci    paddusb             %1, %2                          ; add the negatives
193cabdff1aSopenharmony_ci    psubusb             %1, %4                          ; sub the positives
194cabdff1aSopenharmony_ci%endmacro
195cabdff1aSopenharmony_ci
196cabdff1aSopenharmony_ci%macro FILTER6_INIT 4 ; %1=dst %2=h/l %3=cache, %4=stack_off
197cabdff1aSopenharmony_ci    UNPACK          %2, %1, rp3, m0                     ; p3: B->W
198cabdff1aSopenharmony_ci    mova [rsp+%4+0*mmsize*2], %1
199cabdff1aSopenharmony_ci    paddw               %3, %1, %1                      ; p3*2
200cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p3*3
201cabdff1aSopenharmony_ci    punpck%2bw          %1, m1,  m0                     ; p2: B->W
202cabdff1aSopenharmony_ci    mova [rsp+%4+1*mmsize*2], %1
203cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p3*3 + p2
204cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p3*3 + p2*2
205cabdff1aSopenharmony_ci    UNPACK          %2, %1, rp1, m0                     ; p1: B->W
206cabdff1aSopenharmony_ci    mova [rsp+%4+2*mmsize*2], %1
207cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p3*3 + p2*2 + p1
208cabdff1aSopenharmony_ci    UNPACK          %2, %1, rp0, m0                     ; p0: B->W
209cabdff1aSopenharmony_ci    mova [rsp+%4+3*mmsize*2], %1
210cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p3*3 + p2*2 + p1 + p0
211cabdff1aSopenharmony_ci    UNPACK          %2, %1, rq0, m0                     ; q0: B->W
212cabdff1aSopenharmony_ci    mova [rsp+%4+4*mmsize*2], %1
213cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p3*3 + p2*2 + p1 + p0 + q0
214cabdff1aSopenharmony_ci    paddw               %3, [pw_4]                      ; p3*3 + p2*2 + p1 + p0 + q0 + 4
215cabdff1aSopenharmony_ci    psraw               %1, %3, 3                       ; (p3*3 + p2*2 + p1 + p0 + q0 + 4) >> 3
216cabdff1aSopenharmony_ci%endmacro
217cabdff1aSopenharmony_ci
218cabdff1aSopenharmony_ci%macro FILTER14_INIT 4 ; %1=dst %2=h/l %3=cache, %4=stack_off
219cabdff1aSopenharmony_ci    punpck%2bw          %1, m2, m0                      ; p7: B->W
220cabdff1aSopenharmony_ci    mova [rsp+%4+ 8*mmsize*2], %1
221cabdff1aSopenharmony_ci    psllw               %3, %1, 3                       ; p7*8
222cabdff1aSopenharmony_ci    psubw               %3, %1                          ; p7*7
223cabdff1aSopenharmony_ci    punpck%2bw          %1, m3, m0                      ; p6: B->W
224cabdff1aSopenharmony_ci    mova [rsp+%4+ 9*mmsize*2], %1
225cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p7*7 + p6
226cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p7*7 + p6*2
227cabdff1aSopenharmony_ci    UNPACK          %2, %1, rp5, m0                     ; p5: B->W
228cabdff1aSopenharmony_ci    mova [rsp+%4+10*mmsize*2], %1
229cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p7*7 + p6*2 + p5
230cabdff1aSopenharmony_ci    UNPACK          %2, %1, rp4, m0                     ; p4: B->W
231cabdff1aSopenharmony_ci    mova [rsp+%4+11*mmsize*2], %1
232cabdff1aSopenharmony_ci    paddw               %3, %1                          ; p7*7 + p6*2 + p5 + p4
233cabdff1aSopenharmony_ci    paddw               %3, [rsp+%4+ 0*mmsize*2]        ; p7*7 + p6*2 + p5 + p4 + p3
234cabdff1aSopenharmony_ci    paddw               %3, [rsp+%4+ 1*mmsize*2]        ; p7*7 + p6*2 + p5 + .. + p2
235cabdff1aSopenharmony_ci    paddw               %3, [rsp+%4+ 2*mmsize*2]        ; p7*7 + p6*2 + p5 + .. + p1
236cabdff1aSopenharmony_ci    paddw               %3, [rsp+%4+ 3*mmsize*2]        ; p7*7 + p6*2 + p5 + .. + p0
237cabdff1aSopenharmony_ci    paddw               %3, [rsp+%4+ 4*mmsize*2]        ; p7*7 + p6*2 + p5 + .. + p0 + q0
238cabdff1aSopenharmony_ci    paddw               %3, [pw_8]                      ; p7*7 + p6*2 + p5 + .. + p0 + q0 + 8
239cabdff1aSopenharmony_ci    psraw               %1, %3, 4                       ; (p7*7 + p6*2 + p5 + .. + p0 + q0 + 8) >> 4
240cabdff1aSopenharmony_ci%endmacro
241cabdff1aSopenharmony_ci
242cabdff1aSopenharmony_ci%macro TRANSPOSE16x16B 17
243cabdff1aSopenharmony_ci    mova %17, m%16
244cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %1,  %2,  %16
245cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %3,  %4,  %16
246cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %5,  %6,  %16
247cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %7,  %8,  %16
248cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %9,  %10, %16
249cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %11, %12, %16
250cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %13, %14, %16
251cabdff1aSopenharmony_ci    mova m%16,  %17
252cabdff1aSopenharmony_ci    mova  %17, m%14
253cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %15, %16, %14
254cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %1,  %3,  %14
255cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %2,  %4,  %14
256cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %5,  %7,  %14
257cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %6,  %8,  %14
258cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %9,  %11, %14
259cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %10, %12, %14
260cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %13, %15, %14
261cabdff1aSopenharmony_ci    mova m%14,  %17
262cabdff1aSopenharmony_ci    mova  %17, m%12
263cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %14, %16, %12
264cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %1,  %5,  %12
265cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %2,  %6,  %12
266cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %3,  %7,  %12
267cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %4,  %8,  %12
268cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %9,  %13, %12
269cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %10, %14, %12
270cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %11, %15, %12
271cabdff1aSopenharmony_ci    mova m%12, %17
272cabdff1aSopenharmony_ci    mova  %17, m%8
273cabdff1aSopenharmony_ci    SBUTTERFLY dq,  %12, %16, %8
274cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %1,  %9,  %8
275cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %2,  %10, %8
276cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %3,  %11, %8
277cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %4,  %12, %8
278cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %5,  %13, %8
279cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %6,  %14, %8
280cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %7,  %15, %8
281cabdff1aSopenharmony_ci    mova m%8, %17
282cabdff1aSopenharmony_ci    mova %17, m%1
283cabdff1aSopenharmony_ci    SBUTTERFLY qdq, %8,  %16, %1
284cabdff1aSopenharmony_ci    mova m%1, %17
285cabdff1aSopenharmony_ci    SWAP %2,  %9
286cabdff1aSopenharmony_ci    SWAP %3,  %5
287cabdff1aSopenharmony_ci    SWAP %4,  %13
288cabdff1aSopenharmony_ci    SWAP %6,  %11
289cabdff1aSopenharmony_ci    SWAP %8,  %15
290cabdff1aSopenharmony_ci    SWAP %12, %14
291cabdff1aSopenharmony_ci%endmacro
292cabdff1aSopenharmony_ci
293cabdff1aSopenharmony_ci%macro TRANSPOSE8x8B 13
294cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %1, %2, %7
295cabdff1aSopenharmony_ci    movdq%10 m%7, %9
296cabdff1aSopenharmony_ci    movdqa %11, m%2
297cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %3, %4, %2
298cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %5, %6, %2
299cabdff1aSopenharmony_ci    SBUTTERFLY bw,  %7, %8, %2
300cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %1, %3, %2
301cabdff1aSopenharmony_ci    movdqa m%2, %11
302cabdff1aSopenharmony_ci    movdqa %11, m%3
303cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %2, %4, %3
304cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %5, %7, %3
305cabdff1aSopenharmony_ci    SBUTTERFLY wd,  %6, %8, %3
306cabdff1aSopenharmony_ci    SBUTTERFLY dq, %1, %5, %3
307cabdff1aSopenharmony_ci    SBUTTERFLY dq, %2, %6, %3
308cabdff1aSopenharmony_ci    movdqa m%3, %11
309cabdff1aSopenharmony_ci    movh   %12, m%2
310cabdff1aSopenharmony_ci    movhps %13, m%2
311cabdff1aSopenharmony_ci    SBUTTERFLY dq, %3, %7, %2
312cabdff1aSopenharmony_ci    SBUTTERFLY dq, %4, %8, %2
313cabdff1aSopenharmony_ci    SWAP %2, %5
314cabdff1aSopenharmony_ci    SWAP %4, %7
315cabdff1aSopenharmony_ci%endmacro
316cabdff1aSopenharmony_ci
317cabdff1aSopenharmony_ci%macro DEFINE_REAL_P7_TO_Q7 0-1 0
318cabdff1aSopenharmony_ci%define P7 dstq  + 4*mstrideq  + %1
319cabdff1aSopenharmony_ci%define P6 dstq  +   mstride3q + %1
320cabdff1aSopenharmony_ci%define P5 dstq  + 2*mstrideq  + %1
321cabdff1aSopenharmony_ci%define P4 dstq  +   mstrideq  + %1
322cabdff1aSopenharmony_ci%define P3 dstq                + %1
323cabdff1aSopenharmony_ci%define P2 dstq  +    strideq  + %1
324cabdff1aSopenharmony_ci%define P1 dstq  + 2* strideq  + %1
325cabdff1aSopenharmony_ci%define P0 dstq  +    stride3q + %1
326cabdff1aSopenharmony_ci%define Q0 dstq  + 4* strideq  + %1
327cabdff1aSopenharmony_ci%define Q1 dst2q +   mstride3q + %1
328cabdff1aSopenharmony_ci%define Q2 dst2q + 2*mstrideq  + %1
329cabdff1aSopenharmony_ci%define Q3 dst2q +   mstrideq  + %1
330cabdff1aSopenharmony_ci%define Q4 dst2q               + %1
331cabdff1aSopenharmony_ci%define Q5 dst2q +    strideq  + %1
332cabdff1aSopenharmony_ci%define Q6 dst2q + 2* strideq  + %1
333cabdff1aSopenharmony_ci%define Q7 dst2q +    stride3q + %1
334cabdff1aSopenharmony_ci%endmacro
335cabdff1aSopenharmony_ci
336cabdff1aSopenharmony_ci%macro DEFINE_TRANSPOSED_P7_TO_Q7 0-1 0
337cabdff1aSopenharmony_ci%define P3 rsp +  0*mmsize + %1
338cabdff1aSopenharmony_ci%define P2 rsp +  1*mmsize + %1
339cabdff1aSopenharmony_ci%define P1 rsp +  2*mmsize + %1
340cabdff1aSopenharmony_ci%define P0 rsp +  3*mmsize + %1
341cabdff1aSopenharmony_ci%define Q0 rsp +  4*mmsize + %1
342cabdff1aSopenharmony_ci%define Q1 rsp +  5*mmsize + %1
343cabdff1aSopenharmony_ci%define Q2 rsp +  6*mmsize + %1
344cabdff1aSopenharmony_ci%define Q3 rsp +  7*mmsize + %1
345cabdff1aSopenharmony_ci%if mmsize == 16
346cabdff1aSopenharmony_ci%define P7 rsp +  8*mmsize + %1
347cabdff1aSopenharmony_ci%define P6 rsp +  9*mmsize + %1
348cabdff1aSopenharmony_ci%define P5 rsp + 10*mmsize + %1
349cabdff1aSopenharmony_ci%define P4 rsp + 11*mmsize + %1
350cabdff1aSopenharmony_ci%define Q4 rsp + 12*mmsize + %1
351cabdff1aSopenharmony_ci%define Q5 rsp + 13*mmsize + %1
352cabdff1aSopenharmony_ci%define Q6 rsp + 14*mmsize + %1
353cabdff1aSopenharmony_ci%define Q7 rsp + 15*mmsize + %1
354cabdff1aSopenharmony_ci%endif
355cabdff1aSopenharmony_ci%endmacro
356cabdff1aSopenharmony_ci
357cabdff1aSopenharmony_ci; ..............AB -> AAAAAAAABBBBBBBB
358cabdff1aSopenharmony_ci%macro SPLATB_MIX 1-2 [mask_mix]
359cabdff1aSopenharmony_ci%if cpuflag(ssse3)
360cabdff1aSopenharmony_ci    pshufb     %1, %2
361cabdff1aSopenharmony_ci%else
362cabdff1aSopenharmony_ci    punpcklbw  %1, %1
363cabdff1aSopenharmony_ci    punpcklwd  %1, %1
364cabdff1aSopenharmony_ci    punpckldq  %1, %1
365cabdff1aSopenharmony_ci%endif
366cabdff1aSopenharmony_ci%endmacro
367cabdff1aSopenharmony_ci
368cabdff1aSopenharmony_ci%macro LOOPFILTER 5 ; %1=v/h %2=size1 %3+%4=stack, %5=mmx/32bit stack only
369cabdff1aSopenharmony_ci%assign %%ext 0
370cabdff1aSopenharmony_ci%if ARCH_X86_32 || mmsize == 8
371cabdff1aSopenharmony_ci%assign %%ext %5
372cabdff1aSopenharmony_ci%endif
373cabdff1aSopenharmony_ci
374cabdff1aSopenharmony_ci%if UNIX64
375cabdff1aSopenharmony_cicglobal vp9_loop_filter_%1_%2_ %+ mmsize, 5, 9, 16, %3 + %4 + %%ext, dst, stride, E, I, H, mstride, dst2, stride3, mstride3
376cabdff1aSopenharmony_ci%else
377cabdff1aSopenharmony_ci%if WIN64
378cabdff1aSopenharmony_cicglobal vp9_loop_filter_%1_%2_ %+ mmsize, 4, 8, 16, %3 + %4 + %%ext, dst, stride, E, I, mstride, dst2, stride3, mstride3
379cabdff1aSopenharmony_ci%else
380cabdff1aSopenharmony_cicglobal vp9_loop_filter_%1_%2_ %+ mmsize, 2, 6, 16, %3 + %4 + %%ext, dst, stride, mstride, dst2, stride3, mstride3
381cabdff1aSopenharmony_ci%define Ed dword r2m
382cabdff1aSopenharmony_ci%define Id dword r3m
383cabdff1aSopenharmony_ci%endif
384cabdff1aSopenharmony_ci%define Hd dword r4m
385cabdff1aSopenharmony_ci%endif
386cabdff1aSopenharmony_ci
387cabdff1aSopenharmony_ci    mov               mstrideq, strideq
388cabdff1aSopenharmony_ci    neg               mstrideq
389cabdff1aSopenharmony_ci
390cabdff1aSopenharmony_ci    lea               stride3q, [strideq*3]
391cabdff1aSopenharmony_ci    lea              mstride3q, [mstrideq*3]
392cabdff1aSopenharmony_ci
393cabdff1aSopenharmony_ci%ifidn %1, h
394cabdff1aSopenharmony_ci%if %2 != 16
395cabdff1aSopenharmony_ci%if mmsize == 16
396cabdff1aSopenharmony_ci%define movx movh
397cabdff1aSopenharmony_ci%else
398cabdff1aSopenharmony_ci%define movx mova
399cabdff1aSopenharmony_ci%endif
400cabdff1aSopenharmony_ci    lea                   dstq, [dstq + 4*strideq - 4]
401cabdff1aSopenharmony_ci%else
402cabdff1aSopenharmony_ci%define movx movu
403cabdff1aSopenharmony_ci    lea                   dstq, [dstq + 4*strideq - 8] ; go from top center (h pos) to center left (v pos)
404cabdff1aSopenharmony_ci%endif
405cabdff1aSopenharmony_ci%else
406cabdff1aSopenharmony_ci    lea                   dstq, [dstq + 4*mstrideq]
407cabdff1aSopenharmony_ci%endif
408cabdff1aSopenharmony_ci    ; FIXME we shouldn't need two dts registers if mmsize == 8
409cabdff1aSopenharmony_ci    lea                  dst2q, [dstq + 8*strideq]
410cabdff1aSopenharmony_ci
411cabdff1aSopenharmony_ci    DEFINE_REAL_P7_TO_Q7
412cabdff1aSopenharmony_ci
413cabdff1aSopenharmony_ci%ifidn %1, h
414cabdff1aSopenharmony_ci    movx                    m0, [P7]
415cabdff1aSopenharmony_ci    movx                    m1, [P6]
416cabdff1aSopenharmony_ci    movx                    m2, [P5]
417cabdff1aSopenharmony_ci    movx                    m3, [P4]
418cabdff1aSopenharmony_ci    movx                    m4, [P3]
419cabdff1aSopenharmony_ci    movx                    m5, [P2]
420cabdff1aSopenharmony_ci%if (ARCH_X86_64 && mmsize == 16) || %2 > 16
421cabdff1aSopenharmony_ci    movx                    m6, [P1]
422cabdff1aSopenharmony_ci%endif
423cabdff1aSopenharmony_ci    movx                    m7, [P0]
424cabdff1aSopenharmony_ci%ifdef m8
425cabdff1aSopenharmony_ci    movx                    m8, [Q0]
426cabdff1aSopenharmony_ci    movx                    m9, [Q1]
427cabdff1aSopenharmony_ci    movx                   m10, [Q2]
428cabdff1aSopenharmony_ci    movx                   m11, [Q3]
429cabdff1aSopenharmony_ci    movx                   m12, [Q4]
430cabdff1aSopenharmony_ci    movx                   m13, [Q5]
431cabdff1aSopenharmony_ci    movx                   m14, [Q6]
432cabdff1aSopenharmony_ci    movx                   m15, [Q7]
433cabdff1aSopenharmony_ci    DEFINE_TRANSPOSED_P7_TO_Q7
434cabdff1aSopenharmony_ci%if %2 == 16
435cabdff1aSopenharmony_ci    TRANSPOSE16x16B 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, [rsp]
436cabdff1aSopenharmony_ci    mova           [P7],  m0
437cabdff1aSopenharmony_ci    mova           [P6],  m1
438cabdff1aSopenharmony_ci    mova           [P5],  m2
439cabdff1aSopenharmony_ci    mova           [P4],  m3
440cabdff1aSopenharmony_ci%else ; %2 == 44/48/84/88
441cabdff1aSopenharmony_ci    ; 8x16 transpose
442cabdff1aSopenharmony_ci    punpcklbw        m0,  m1
443cabdff1aSopenharmony_ci    punpcklbw        m2,  m3
444cabdff1aSopenharmony_ci    punpcklbw        m4,  m5
445cabdff1aSopenharmony_ci    punpcklbw        m6,  m7
446cabdff1aSopenharmony_ci    punpcklbw        m8,  m9
447cabdff1aSopenharmony_ci    punpcklbw       m10, m11
448cabdff1aSopenharmony_ci    punpcklbw       m12, m13
449cabdff1aSopenharmony_ci    punpcklbw       m14, m15
450cabdff1aSopenharmony_ci    TRANSPOSE8x8W     0, 2, 4, 6, 8, 10, 12, 14, 15
451cabdff1aSopenharmony_ci    SWAP              0,  4
452cabdff1aSopenharmony_ci    SWAP              2,  5
453cabdff1aSopenharmony_ci    SWAP              0,  6
454cabdff1aSopenharmony_ci    SWAP              0,  7
455cabdff1aSopenharmony_ci    SWAP             10,  9
456cabdff1aSopenharmony_ci    SWAP             12, 10
457cabdff1aSopenharmony_ci    SWAP             14, 11
458cabdff1aSopenharmony_ci%endif ; %2
459cabdff1aSopenharmony_ci    mova           [P3],  m4
460cabdff1aSopenharmony_ci    mova           [P2],  m5
461cabdff1aSopenharmony_ci    mova           [P1],  m6
462cabdff1aSopenharmony_ci    mova           [P0],  m7
463cabdff1aSopenharmony_ci    mova           [Q0],  m8
464cabdff1aSopenharmony_ci    mova           [Q1],  m9
465cabdff1aSopenharmony_ci    mova           [Q2], m10
466cabdff1aSopenharmony_ci    mova           [Q3], m11
467cabdff1aSopenharmony_ci%if %2 == 16
468cabdff1aSopenharmony_ci    mova           [Q4], m12
469cabdff1aSopenharmony_ci    mova           [Q5], m13
470cabdff1aSopenharmony_ci    mova           [Q6], m14
471cabdff1aSopenharmony_ci    mova           [Q7], m15
472cabdff1aSopenharmony_ci%endif ; %2
473cabdff1aSopenharmony_ci%else ; x86-32
474cabdff1aSopenharmony_ci%if %2 == 16
475cabdff1aSopenharmony_ci    TRANSPOSE8x8B    0, 1, 2, 3, 4, 5, 6, 7, [P1], u, [rsp+%3+%4], [rsp+64], [rsp+80]
476cabdff1aSopenharmony_ci    DEFINE_TRANSPOSED_P7_TO_Q7
477cabdff1aSopenharmony_ci    movh          [P7], m0
478cabdff1aSopenharmony_ci    movh          [P5], m1
479cabdff1aSopenharmony_ci    movh          [P3], m2
480cabdff1aSopenharmony_ci    movh          [P1], m3
481cabdff1aSopenharmony_ci    movh          [Q2], m5
482cabdff1aSopenharmony_ci    movh          [Q4], m6
483cabdff1aSopenharmony_ci    movh          [Q6], m7
484cabdff1aSopenharmony_ci    movhps        [P6], m0
485cabdff1aSopenharmony_ci    movhps        [P4], m1
486cabdff1aSopenharmony_ci    movhps        [P2], m2
487cabdff1aSopenharmony_ci    movhps        [P0], m3
488cabdff1aSopenharmony_ci    movhps        [Q3], m5
489cabdff1aSopenharmony_ci    movhps        [Q5], m6
490cabdff1aSopenharmony_ci    movhps        [Q7], m7
491cabdff1aSopenharmony_ci    DEFINE_REAL_P7_TO_Q7
492cabdff1aSopenharmony_ci    movx                    m0, [Q0]
493cabdff1aSopenharmony_ci    movx                    m1, [Q1]
494cabdff1aSopenharmony_ci    movx                    m2, [Q2]
495cabdff1aSopenharmony_ci    movx                    m3, [Q3]
496cabdff1aSopenharmony_ci    movx                    m4, [Q4]
497cabdff1aSopenharmony_ci    movx                    m5, [Q5]
498cabdff1aSopenharmony_ci    movx                    m7, [Q7]
499cabdff1aSopenharmony_ci    TRANSPOSE8x8B 0, 1, 2, 3, 4, 5, 6, 7, [Q6], u, [rsp+%3+%4], [rsp+72], [rsp+88]
500cabdff1aSopenharmony_ci    DEFINE_TRANSPOSED_P7_TO_Q7 8
501cabdff1aSopenharmony_ci    movh          [P7], m0
502cabdff1aSopenharmony_ci    movh          [P5], m1
503cabdff1aSopenharmony_ci    movh          [P3], m2
504cabdff1aSopenharmony_ci    movh          [P1], m3
505cabdff1aSopenharmony_ci    movh          [Q2], m5
506cabdff1aSopenharmony_ci    movh          [Q4], m6
507cabdff1aSopenharmony_ci    movh          [Q6], m7
508cabdff1aSopenharmony_ci    movhps        [P6], m0
509cabdff1aSopenharmony_ci    movhps        [P4], m1
510cabdff1aSopenharmony_ci    movhps        [P2], m2
511cabdff1aSopenharmony_ci    movhps        [P0], m3
512cabdff1aSopenharmony_ci    movhps        [Q3], m5
513cabdff1aSopenharmony_ci    movhps        [Q5], m6
514cabdff1aSopenharmony_ci    movhps        [Q7], m7
515cabdff1aSopenharmony_ci    DEFINE_TRANSPOSED_P7_TO_Q7
516cabdff1aSopenharmony_ci%elif %2 > 16 ; %2 == 44/48/84/88
517cabdff1aSopenharmony_ci    punpcklbw        m0, m1
518cabdff1aSopenharmony_ci    punpcklbw        m2, m3
519cabdff1aSopenharmony_ci    punpcklbw        m4, m5
520cabdff1aSopenharmony_ci    punpcklbw        m6, m7
521cabdff1aSopenharmony_ci    movx             m1, [Q0]
522cabdff1aSopenharmony_ci    movx             m3, [Q1]
523cabdff1aSopenharmony_ci    movx             m5, [Q2]
524cabdff1aSopenharmony_ci    movx             m7, [Q3]
525cabdff1aSopenharmony_ci    punpcklbw        m1, m3
526cabdff1aSopenharmony_ci    punpcklbw        m5, m7
527cabdff1aSopenharmony_ci    movx             m3, [Q4]
528cabdff1aSopenharmony_ci    movx             m7, [Q5]
529cabdff1aSopenharmony_ci    punpcklbw        m3, m7
530cabdff1aSopenharmony_ci    mova          [rsp], m3
531cabdff1aSopenharmony_ci    movx             m3, [Q6]
532cabdff1aSopenharmony_ci    movx             m7, [Q7]
533cabdff1aSopenharmony_ci    punpcklbw        m3, m7
534cabdff1aSopenharmony_ci    DEFINE_TRANSPOSED_P7_TO_Q7
535cabdff1aSopenharmony_ci    TRANSPOSE8x8W     0, 2, 4, 6, 1, 5, 7, 3, [rsp], [Q0], 1
536cabdff1aSopenharmony_ci    mova           [P3],  m0
537cabdff1aSopenharmony_ci    mova           [P2],  m2
538cabdff1aSopenharmony_ci    mova           [P1],  m4
539cabdff1aSopenharmony_ci    mova           [P0],  m6
540cabdff1aSopenharmony_ci    mova           [Q1],  m5
541cabdff1aSopenharmony_ci    mova           [Q2],  m7
542cabdff1aSopenharmony_ci    mova           [Q3],  m3
543cabdff1aSopenharmony_ci%else ; %2 == 4 || %2 == 8
544cabdff1aSopenharmony_ci    SBUTTERFLY       bw, 0, 1, 6
545cabdff1aSopenharmony_ci    SBUTTERFLY       bw, 2, 3, 6
546cabdff1aSopenharmony_ci    SBUTTERFLY       bw, 4, 5, 6
547cabdff1aSopenharmony_ci    mova [rsp+4*mmsize], m5
548cabdff1aSopenharmony_ci    mova             m6, [P1]
549cabdff1aSopenharmony_ci    SBUTTERFLY       bw, 6, 7, 5
550cabdff1aSopenharmony_ci    DEFINE_TRANSPOSED_P7_TO_Q7
551cabdff1aSopenharmony_ci    TRANSPOSE4x4W     0, 2, 4, 6, 5
552cabdff1aSopenharmony_ci    mova           [P3], m0
553cabdff1aSopenharmony_ci    mova           [P2], m2
554cabdff1aSopenharmony_ci    mova           [P1], m4
555cabdff1aSopenharmony_ci    mova           [P0], m6
556cabdff1aSopenharmony_ci    mova             m5, [rsp+4*mmsize]
557cabdff1aSopenharmony_ci    TRANSPOSE4x4W     1, 3, 5, 7, 0
558cabdff1aSopenharmony_ci    mova           [Q0], m1
559cabdff1aSopenharmony_ci    mova           [Q1], m3
560cabdff1aSopenharmony_ci    mova           [Q2], m5
561cabdff1aSopenharmony_ci    mova           [Q3], m7
562cabdff1aSopenharmony_ci%endif ; %2
563cabdff1aSopenharmony_ci%endif ; x86-32/64
564cabdff1aSopenharmony_ci%endif ; %1 == h
565cabdff1aSopenharmony_ci
566cabdff1aSopenharmony_ci    ; calc fm mask
567cabdff1aSopenharmony_ci%if %2 == 16 || mmsize == 8
568cabdff1aSopenharmony_ci%if cpuflag(ssse3)
569cabdff1aSopenharmony_ci    pxor                m0, m0
570cabdff1aSopenharmony_ci%endif
571cabdff1aSopenharmony_ci    SPLATB_REG          m2, I, m0                       ; I I I I ...
572cabdff1aSopenharmony_ci    SPLATB_REG          m3, E, m0                       ; E E E E ...
573cabdff1aSopenharmony_ci%else
574cabdff1aSopenharmony_ci%if cpuflag(ssse3)
575cabdff1aSopenharmony_ci    mova                m0, [mask_mix]
576cabdff1aSopenharmony_ci%endif
577cabdff1aSopenharmony_ci    movd                m2, Id
578cabdff1aSopenharmony_ci    movd                m3, Ed
579cabdff1aSopenharmony_ci    SPLATB_MIX          m2, m0
580cabdff1aSopenharmony_ci    SPLATB_MIX          m3, m0
581cabdff1aSopenharmony_ci%endif
582cabdff1aSopenharmony_ci    mova                m0, [pb_80]
583cabdff1aSopenharmony_ci    pxor                m2, m0
584cabdff1aSopenharmony_ci    pxor                m3, m0
585cabdff1aSopenharmony_ci%ifdef m8
586cabdff1aSopenharmony_ci%ifidn %1, v
587cabdff1aSopenharmony_ci    mova                m8, [P3]
588cabdff1aSopenharmony_ci    mova                m9, [P2]
589cabdff1aSopenharmony_ci    mova               m10, [P1]
590cabdff1aSopenharmony_ci    mova               m11, [P0]
591cabdff1aSopenharmony_ci    mova               m12, [Q0]
592cabdff1aSopenharmony_ci    mova               m13, [Q1]
593cabdff1aSopenharmony_ci    mova               m14, [Q2]
594cabdff1aSopenharmony_ci    mova               m15, [Q3]
595cabdff1aSopenharmony_ci%else
596cabdff1aSopenharmony_ci    ; In case of horizontal, P3..Q3 are already present in some registers due
597cabdff1aSopenharmony_ci    ; to the previous transpose, so we just swap registers.
598cabdff1aSopenharmony_ci    SWAP                 8,  4, 12
599cabdff1aSopenharmony_ci    SWAP                 9,  5, 13
600cabdff1aSopenharmony_ci    SWAP                10,  6, 14
601cabdff1aSopenharmony_ci    SWAP                11,  7, 15
602cabdff1aSopenharmony_ci%endif
603cabdff1aSopenharmony_ci%define rp3 m8
604cabdff1aSopenharmony_ci%define rp2 m9
605cabdff1aSopenharmony_ci%define rp1 m10
606cabdff1aSopenharmony_ci%define rp0 m11
607cabdff1aSopenharmony_ci%define rq0 m12
608cabdff1aSopenharmony_ci%define rq1 m13
609cabdff1aSopenharmony_ci%define rq2 m14
610cabdff1aSopenharmony_ci%define rq3 m15
611cabdff1aSopenharmony_ci%else
612cabdff1aSopenharmony_ci%define rp3 [P3]
613cabdff1aSopenharmony_ci%define rp2 [P2]
614cabdff1aSopenharmony_ci%define rp1 [P1]
615cabdff1aSopenharmony_ci%define rp0 [P0]
616cabdff1aSopenharmony_ci%define rq0 [Q0]
617cabdff1aSopenharmony_ci%define rq1 [Q1]
618cabdff1aSopenharmony_ci%define rq2 [Q2]
619cabdff1aSopenharmony_ci%define rq3 [Q3]
620cabdff1aSopenharmony_ci%endif
621cabdff1aSopenharmony_ci    ABSSUB_GT           m5, rp3, rp2, m2, m7, m0        ; m5 = abs(p3-p2) <= I
622cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rp2, rp1, m2, m7, m0        ; m1 = abs(p2-p1) <= I
623cabdff1aSopenharmony_ci    por                 m5, m1
624cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rp1, rp0, m2, m7, m0        ; m1 = abs(p1-p0) <= I
625cabdff1aSopenharmony_ci    por                 m5, m1
626cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rq0, rq1, m2, m7, m0        ; m1 = abs(q1-q0) <= I
627cabdff1aSopenharmony_ci    por                 m5, m1
628cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rq1, rq2, m2, m7, m0        ; m1 = abs(q2-q1) <= I
629cabdff1aSopenharmony_ci    por                 m5, m1
630cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rq2, rq3, m2, m7, m0        ; m1 = abs(q3-q2) <= I
631cabdff1aSopenharmony_ci    por                 m5, m1
632cabdff1aSopenharmony_ci    ABSSUB              m1, rp0, rq0, m7                ; abs(p0-q0)
633cabdff1aSopenharmony_ci    paddusb             m1, m1                          ; abs(p0-q0) * 2
634cabdff1aSopenharmony_ci    ABSSUB              m2, rp1, rq1, m7                ; abs(p1-q1)
635cabdff1aSopenharmony_ci    pand                m2, [pb_fe]                     ; drop lsb so shift can work
636cabdff1aSopenharmony_ci    psrlq               m2, 1                           ; abs(p1-q1)/2
637cabdff1aSopenharmony_ci    paddusb             m1, m2                          ; abs(p0-q0)*2 + abs(p1-q1)/2
638cabdff1aSopenharmony_ci    pxor                m1, m0
639cabdff1aSopenharmony_ci    pcmpgtb             m1, m3
640cabdff1aSopenharmony_ci    por                 m1, m5                          ; fm final value
641cabdff1aSopenharmony_ci    SWAP                 1, 3
642cabdff1aSopenharmony_ci    pxor                m3, [pb_ff]
643cabdff1aSopenharmony_ci
644cabdff1aSopenharmony_ci    ; (m3: fm, m8..15: p3 p2 p1 p0 q0 q1 q2 q3)
645cabdff1aSopenharmony_ci    ; calc flat8in (if not 44_16) and hev masks
646cabdff1aSopenharmony_ci%if %2 != 44 && %2 != 4
647cabdff1aSopenharmony_ci    mova                m6, [pb_81]                     ; [1 1 1 1 ...] ^ 0x80
648cabdff1aSopenharmony_ci    ABSSUB_GT           m2, rp3, rp0, m6, m5            ; abs(p3 - p0) <= 1
649cabdff1aSopenharmony_ci%ifdef m8
650cabdff1aSopenharmony_ci    mova                m8, [pb_80]
651cabdff1aSopenharmony_ci%define rb80 m8
652cabdff1aSopenharmony_ci%else
653cabdff1aSopenharmony_ci%define rb80 [pb_80]
654cabdff1aSopenharmony_ci%endif
655cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rp2, rp0, m6, m5, rb80      ; abs(p2 - p0) <= 1
656cabdff1aSopenharmony_ci    por                 m2, m1
657cabdff1aSopenharmony_ci    ABSSUB              m4, rp1, rp0, m5                ; abs(p1 - p0)
658cabdff1aSopenharmony_ci%if %2 <= 16
659cabdff1aSopenharmony_ci%if cpuflag(ssse3)
660cabdff1aSopenharmony_ci    pxor                m0, m0
661cabdff1aSopenharmony_ci%endif
662cabdff1aSopenharmony_ci    SPLATB_REG          m7, H, m0                       ; H H H H ...
663cabdff1aSopenharmony_ci%else
664cabdff1aSopenharmony_ci    movd                m7, Hd
665cabdff1aSopenharmony_ci    SPLATB_MIX          m7
666cabdff1aSopenharmony_ci%endif
667cabdff1aSopenharmony_ci    pxor                m7, rb80
668cabdff1aSopenharmony_ci    pxor                m4, rb80
669cabdff1aSopenharmony_ci    pcmpgtb             m0, m4, m7                      ; abs(p1 - p0) > H (1/2 hev condition)
670cabdff1aSopenharmony_ci    CMP_GT              m4, m6                          ; abs(p1 - p0) <= 1
671cabdff1aSopenharmony_ci    por                 m2, m4                          ; (flat8in)
672cabdff1aSopenharmony_ci    ABSSUB              m4, rq1, rq0, m1                ; abs(q1 - q0)
673cabdff1aSopenharmony_ci    pxor                m4, rb80
674cabdff1aSopenharmony_ci    pcmpgtb             m5, m4, m7                      ; abs(q1 - q0) > H (2/2 hev condition)
675cabdff1aSopenharmony_ci    por                 m0, m5                          ; hev final value
676cabdff1aSopenharmony_ci    CMP_GT              m4, m6                          ; abs(q1 - q0) <= 1
677cabdff1aSopenharmony_ci    por                 m2, m4                          ; (flat8in)
678cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rq2, rq0, m6, m5, rb80      ; abs(q2 - q0) <= 1
679cabdff1aSopenharmony_ci    por                 m2, m1
680cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rq3, rq0, m6, m5, rb80      ; abs(q3 - q0) <= 1
681cabdff1aSopenharmony_ci    por                 m2, m1                          ; flat8in final value
682cabdff1aSopenharmony_ci    pxor                m2, [pb_ff]
683cabdff1aSopenharmony_ci%if %2 == 84 || %2 == 48
684cabdff1aSopenharmony_ci    pand                m2, [mask_mix%2]
685cabdff1aSopenharmony_ci%endif
686cabdff1aSopenharmony_ci%else
687cabdff1aSopenharmony_ci    mova                m6, [pb_80]
688cabdff1aSopenharmony_ci%if %2 == 44
689cabdff1aSopenharmony_ci    movd                m7, Hd
690cabdff1aSopenharmony_ci    SPLATB_MIX          m7
691cabdff1aSopenharmony_ci%else
692cabdff1aSopenharmony_ci%if cpuflag(ssse3)
693cabdff1aSopenharmony_ci    pxor                m0, m0
694cabdff1aSopenharmony_ci%endif
695cabdff1aSopenharmony_ci    SPLATB_REG          m7, H, m0                       ; H H H H ...
696cabdff1aSopenharmony_ci%endif
697cabdff1aSopenharmony_ci    pxor                m7, m6
698cabdff1aSopenharmony_ci    ABSSUB              m4, rp1, rp0, m1                ; abs(p1 - p0)
699cabdff1aSopenharmony_ci    pxor                m4, m6
700cabdff1aSopenharmony_ci    pcmpgtb             m0, m4, m7                      ; abs(p1 - p0) > H (1/2 hev condition)
701cabdff1aSopenharmony_ci    ABSSUB              m4, rq1, rq0, m1                ; abs(q1 - q0)
702cabdff1aSopenharmony_ci    pxor                m4, m6
703cabdff1aSopenharmony_ci    pcmpgtb             m5, m4, m7                      ; abs(q1 - q0) > H (2/2 hev condition)
704cabdff1aSopenharmony_ci    por                 m0, m5                          ; hev final value
705cabdff1aSopenharmony_ci%endif
706cabdff1aSopenharmony_ci
707cabdff1aSopenharmony_ci%if %2 == 16
708cabdff1aSopenharmony_ci    ; (m0: hev, m2: flat8in, m3: fm, m6: pb_81, m9..15: p2 p1 p0 q0 q1 q2 q3)
709cabdff1aSopenharmony_ci    ; calc flat8out mask
710cabdff1aSopenharmony_ci%ifdef m8
711cabdff1aSopenharmony_ci    mova                m8, [P7]
712cabdff1aSopenharmony_ci    mova                m9, [P6]
713cabdff1aSopenharmony_ci%define rp7 m8
714cabdff1aSopenharmony_ci%define rp6 m9
715cabdff1aSopenharmony_ci%else
716cabdff1aSopenharmony_ci%define rp7 [P7]
717cabdff1aSopenharmony_ci%define rp6 [P6]
718cabdff1aSopenharmony_ci%endif
719cabdff1aSopenharmony_ci    ABSSUB_GT           m1, rp7, rp0, m6, m5            ; abs(p7 - p0) <= 1
720cabdff1aSopenharmony_ci    ABSSUB_GT           m7, rp6, rp0, m6, m5            ; abs(p6 - p0) <= 1
721cabdff1aSopenharmony_ci    por                 m1, m7
722cabdff1aSopenharmony_ci%ifdef m8
723cabdff1aSopenharmony_ci    mova                m8, [P5]
724cabdff1aSopenharmony_ci    mova                m9, [P4]
725cabdff1aSopenharmony_ci%define rp5 m8
726cabdff1aSopenharmony_ci%define rp4 m9
727cabdff1aSopenharmony_ci%else
728cabdff1aSopenharmony_ci%define rp5 [P5]
729cabdff1aSopenharmony_ci%define rp4 [P4]
730cabdff1aSopenharmony_ci%endif
731cabdff1aSopenharmony_ci    ABSSUB_GT           m7, rp5, rp0, m6, m5            ; abs(p5 - p0) <= 1
732cabdff1aSopenharmony_ci    por                 m1, m7
733cabdff1aSopenharmony_ci    ABSSUB_GT           m7, rp4, rp0, m6, m5            ; abs(p4 - p0) <= 1
734cabdff1aSopenharmony_ci    por                 m1, m7
735cabdff1aSopenharmony_ci%ifdef m8
736cabdff1aSopenharmony_ci    mova                m14, [Q4]
737cabdff1aSopenharmony_ci    mova                m15, [Q5]
738cabdff1aSopenharmony_ci%define rq4 m14
739cabdff1aSopenharmony_ci%define rq5 m15
740cabdff1aSopenharmony_ci%else
741cabdff1aSopenharmony_ci%define rq4 [Q4]
742cabdff1aSopenharmony_ci%define rq5 [Q5]
743cabdff1aSopenharmony_ci%endif
744cabdff1aSopenharmony_ci    ABSSUB_GT           m7, rq4, rq0, m6, m5            ; abs(q4 - q0) <= 1
745cabdff1aSopenharmony_ci    por                 m1, m7
746cabdff1aSopenharmony_ci    ABSSUB_GT           m7, rq5, rq0, m6, m5            ; abs(q5 - q0) <= 1
747cabdff1aSopenharmony_ci    por                 m1, m7
748cabdff1aSopenharmony_ci%ifdef m8
749cabdff1aSopenharmony_ci    mova                m14, [Q6]
750cabdff1aSopenharmony_ci    mova                m15, [Q7]
751cabdff1aSopenharmony_ci%define rq6 m14
752cabdff1aSopenharmony_ci%define rq7 m15
753cabdff1aSopenharmony_ci%else
754cabdff1aSopenharmony_ci%define rq6 [Q6]
755cabdff1aSopenharmony_ci%define rq7 [Q7]
756cabdff1aSopenharmony_ci%endif
757cabdff1aSopenharmony_ci    ABSSUB_GT           m7, rq6, rq0, m6, m5            ; abs(q4 - q0) <= 1
758cabdff1aSopenharmony_ci    por                 m1, m7
759cabdff1aSopenharmony_ci    ABSSUB_GT           m7, rq7, rq0, m6, m5            ; abs(q5 - q0) <= 1
760cabdff1aSopenharmony_ci    por                 m1, m7                          ; flat8out final value
761cabdff1aSopenharmony_ci    pxor                m1, [pb_ff]
762cabdff1aSopenharmony_ci%endif
763cabdff1aSopenharmony_ci
764cabdff1aSopenharmony_ci    ; if (fm) {
765cabdff1aSopenharmony_ci    ;     if (out && in) filter_14()
766cabdff1aSopenharmony_ci    ;     else if (in)   filter_6()
767cabdff1aSopenharmony_ci    ;     else if (hev)  filter_2()
768cabdff1aSopenharmony_ci    ;     else           filter_4()
769cabdff1aSopenharmony_ci    ; }
770cabdff1aSopenharmony_ci    ;
771cabdff1aSopenharmony_ci    ; f14:                                                                            fm &  out &  in
772cabdff1aSopenharmony_ci    ; f6:  fm & ~f14 & in        => fm & ~(out & in) & in                          => fm & ~out &  in
773cabdff1aSopenharmony_ci    ; f2:  fm & ~f14 & ~f6 & hev => fm & ~(out & in) & ~(~out & in) & hev          => fm &  ~in &  hev
774cabdff1aSopenharmony_ci    ; f4:  fm & ~f14 & ~f6 & ~f2 => fm & ~(out & in) & ~(~out & in) & ~(~in & hev) => fm &  ~in & ~hev
775cabdff1aSopenharmony_ci
776cabdff1aSopenharmony_ci    ; (m0: hev, [m1: flat8out], [m2: flat8in], m3: fm, m8..15: p5 p4 p1 p0 q0 q1 q6 q7)
777cabdff1aSopenharmony_ci    ; filter2()
778cabdff1aSopenharmony_ci%if %2 != 44 && %2 != 4
779cabdff1aSopenharmony_ci    mova                m6, [pb_80]                     ; already in m6 if 44_16
780cabdff1aSopenharmony_ci    SCRATCH              2, 15, rsp+%3+%4
781cabdff1aSopenharmony_ci%if %2 == 16
782cabdff1aSopenharmony_ci    SCRATCH              1,  8, rsp+%3+%4+16
783cabdff1aSopenharmony_ci%endif
784cabdff1aSopenharmony_ci%endif
785cabdff1aSopenharmony_ci    pxor                m2, m6, rq0                     ; q0 ^ 0x80
786cabdff1aSopenharmony_ci    pxor                m4, m6, rp0                     ; p0 ^ 0x80
787cabdff1aSopenharmony_ci    psubsb              m2, m4                          ; (signed) q0 - p0
788cabdff1aSopenharmony_ci    pxor                m4, m6, rp1                     ; p1 ^ 0x80
789cabdff1aSopenharmony_ci    pxor                m5, m6, rq1                     ; q1 ^ 0x80
790cabdff1aSopenharmony_ci    psubsb              m4, m5                          ; (signed) p1 - q1
791cabdff1aSopenharmony_ci    paddsb              m4, m2                          ;   (q0 - p0) + (p1 - q1)
792cabdff1aSopenharmony_ci    paddsb              m4, m2                          ; 2*(q0 - p0) + (p1 - q1)
793cabdff1aSopenharmony_ci    paddsb              m4, m2                          ; 3*(q0 - p0) + (p1 - q1)
794cabdff1aSopenharmony_ci    paddsb              m6, m4, [pb_4]                  ; m6: f1 = clip(f + 4, 127)
795cabdff1aSopenharmony_ci    paddsb              m4, [pb_3]                      ; m4: f2 = clip(f + 3, 127)
796cabdff1aSopenharmony_ci%ifdef m8
797cabdff1aSopenharmony_ci    mova                m14, [pb_10]                    ; will be reused in filter4()
798cabdff1aSopenharmony_ci%define rb10 m14
799cabdff1aSopenharmony_ci%else
800cabdff1aSopenharmony_ci%define rb10 [pb_10]
801cabdff1aSopenharmony_ci%endif
802cabdff1aSopenharmony_ci    SRSHIFT3B_2X        m6, m4, rb10, m7                ; f1 and f2 sign byte shift by 3
803cabdff1aSopenharmony_ci    SIGN_SUB            m7, rq0, m6, m5                 ; m7 = q0 - f1
804cabdff1aSopenharmony_ci    SIGN_ADD            m1, rp0, m4, m5                 ; m1 = p0 + f2
805cabdff1aSopenharmony_ci%if %2 != 44 && %2 != 4
806cabdff1aSopenharmony_ci%ifdef m8
807cabdff1aSopenharmony_ci    pandn               m6, m15, m3                     ;  ~mask(in) & mask(fm)
808cabdff1aSopenharmony_ci%else
809cabdff1aSopenharmony_ci    mova                m6, [rsp+%3+%4]
810cabdff1aSopenharmony_ci    pandn               m6, m3
811cabdff1aSopenharmony_ci%endif
812cabdff1aSopenharmony_ci    pand                m6, m0                          ; (~mask(in) & mask(fm)) & mask(hev)
813cabdff1aSopenharmony_ci%else
814cabdff1aSopenharmony_ci    pand                m6, m3, m0
815cabdff1aSopenharmony_ci%endif
816cabdff1aSopenharmony_ci    MASK_APPLY          m7, rq0, m6, m5                 ; m7 = filter2(q0) & mask / we write it in filter4()
817cabdff1aSopenharmony_ci    MASK_APPLY          m1, rp0, m6, m5                 ; m1 = filter2(p0) & mask / we write it in filter4()
818cabdff1aSopenharmony_ci
819cabdff1aSopenharmony_ci    ; (m0: hev, m1: p0', m2: q0-p0, m3: fm, m7: q0', [m8: flat8out], m10..13: p1 p0 q0 q1, m14: pb_10, [m15: flat8in], )
820cabdff1aSopenharmony_ci    ; filter4()
821cabdff1aSopenharmony_ci    mova                m4, m2
822cabdff1aSopenharmony_ci    paddsb              m2, m4                          ; 2 * (q0 - p0)
823cabdff1aSopenharmony_ci    paddsb              m2, m4                          ; 3 * (q0 - p0)
824cabdff1aSopenharmony_ci    paddsb              m6, m2, [pb_4]                  ; m6:  f1 = clip(f + 4, 127)
825cabdff1aSopenharmony_ci    paddsb              m2, [pb_3]                      ; m2: f2 = clip(f + 3, 127)
826cabdff1aSopenharmony_ci    SRSHIFT3B_2X        m6, m2, rb10, m4                ; f1 and f2 sign byte shift by 3
827cabdff1aSopenharmony_ci%if %2 != 44 && %2 != 4
828cabdff1aSopenharmony_ci%ifdef m8
829cabdff1aSopenharmony_ci    pandn               m5, m15, m3                     ;               ~mask(in) & mask(fm)
830cabdff1aSopenharmony_ci%else
831cabdff1aSopenharmony_ci    mova                m5, [rsp+%3+%4]
832cabdff1aSopenharmony_ci    pandn               m5, m3
833cabdff1aSopenharmony_ci%endif
834cabdff1aSopenharmony_ci    pandn               m0, m5                          ; ~mask(hev) & (~mask(in) & mask(fm))
835cabdff1aSopenharmony_ci%else
836cabdff1aSopenharmony_ci    pandn               m0, m3
837cabdff1aSopenharmony_ci%endif
838cabdff1aSopenharmony_ci    SIGN_SUB            m5, rq0, m6, m4                 ; q0 - f1
839cabdff1aSopenharmony_ci    MASK_APPLY          m5, m7, m0, m4                  ; filter4(q0) & mask
840cabdff1aSopenharmony_ci    mova                [Q0], m5
841cabdff1aSopenharmony_ci    SIGN_ADD            m7, rp0, m2, m4                 ; p0 + f2
842cabdff1aSopenharmony_ci    MASK_APPLY          m7, m1, m0, m4                  ; filter4(p0) & mask
843cabdff1aSopenharmony_ci    mova                [P0], m7
844cabdff1aSopenharmony_ci    paddb               m6, [pb_80]                     ;
845cabdff1aSopenharmony_ci    pxor                m1, m1                          ;   f=(f1+1)>>1
846cabdff1aSopenharmony_ci    pavgb               m6, m1                          ;
847cabdff1aSopenharmony_ci    psubb               m6, [pb_40]                     ;
848cabdff1aSopenharmony_ci    SIGN_ADD            m1, rp1, m6, m2                 ; p1 + f
849cabdff1aSopenharmony_ci    SIGN_SUB            m4, rq1, m6, m2                 ; q1 - f
850cabdff1aSopenharmony_ci    MASK_APPLY          m1, rp1, m0, m2                 ; m1 = filter4(p1)
851cabdff1aSopenharmony_ci    MASK_APPLY          m4, rq1, m0, m2                 ; m4 = filter4(q1)
852cabdff1aSopenharmony_ci    mova                [P1], m1
853cabdff1aSopenharmony_ci    mova                [Q1], m4
854cabdff1aSopenharmony_ci
855cabdff1aSopenharmony_ci%if %2 != 44 && %2 != 4
856cabdff1aSopenharmony_ci    UNSCRATCH            2, 15, rsp+%3+%4
857cabdff1aSopenharmony_ci%endif
858cabdff1aSopenharmony_ci
859cabdff1aSopenharmony_ci    ; ([m1: flat8out], m2: flat8in, m3: fm, m10..13: p1 p0 q0 q1)
860cabdff1aSopenharmony_ci    ; filter6()
861cabdff1aSopenharmony_ci%if %2 != 44 && %2 != 4
862cabdff1aSopenharmony_ci    pxor                m0, m0
863cabdff1aSopenharmony_ci%if %2 != 16
864cabdff1aSopenharmony_ci    pand                m3, m2
865cabdff1aSopenharmony_ci%else
866cabdff1aSopenharmony_ci    pand                m2, m3                          ;               mask(fm) & mask(in)
867cabdff1aSopenharmony_ci%ifdef m8
868cabdff1aSopenharmony_ci    pandn               m3, m8, m2                      ; ~mask(out) & (mask(fm) & mask(in))
869cabdff1aSopenharmony_ci%else
870cabdff1aSopenharmony_ci    mova                m3, [rsp+%3+%4+16]
871cabdff1aSopenharmony_ci    pandn               m3, m2
872cabdff1aSopenharmony_ci%endif
873cabdff1aSopenharmony_ci%endif
874cabdff1aSopenharmony_ci%ifdef m8
875cabdff1aSopenharmony_ci    mova               m14, [P3]
876cabdff1aSopenharmony_ci    mova                m9, [Q3]
877cabdff1aSopenharmony_ci%define rp3 m14
878cabdff1aSopenharmony_ci%define rq3 m9
879cabdff1aSopenharmony_ci%else
880cabdff1aSopenharmony_ci%define rp3 [P3]
881cabdff1aSopenharmony_ci%define rq3 [Q3]
882cabdff1aSopenharmony_ci%endif
883cabdff1aSopenharmony_ci    mova                m1, [P2]
884cabdff1aSopenharmony_ci    FILTER_INIT         m4, m5, m6, m7, [P2], %4, 6,             m3,  m1             ; [p2]
885cabdff1aSopenharmony_ci    mova                m1, [Q2]
886cabdff1aSopenharmony_ci    FILTER_UPDATE       m4, m5, m6, m7, [P1], %4, 0, 1, 2, 5, 3, m3,  "", rq1, "", 1 ; [p1] -p3 -p2 +p1 +q1
887cabdff1aSopenharmony_ci    FILTER_UPDATE       m4, m5, m6, m7, [P0], %4, 0, 2, 3, 6, 3, m3,  "", m1         ; [p0] -p3 -p1 +p0 +q2
888cabdff1aSopenharmony_ci    FILTER_UPDATE       m4, m5, m6, m7, [Q0], %4, 0, 3, 4, 7, 3, m3,  "", rq3, "", 1 ; [q0] -p3 -p0 +q0 +q3
889cabdff1aSopenharmony_ci    FILTER_UPDATE       m4, m5, m6, m7, [Q1], %4, 1, 4, 5, 7, 3, m3,  ""             ; [q1] -p2 -q0 +q1 +q3
890cabdff1aSopenharmony_ci    FILTER_UPDATE       m4, m5, m6, m7, [Q2], %4, 2, 5, 6, 7, 3, m3,  m1             ; [q2] -p1 -q1 +q2 +q3
891cabdff1aSopenharmony_ci%endif
892cabdff1aSopenharmony_ci
893cabdff1aSopenharmony_ci%if %2 == 16
894cabdff1aSopenharmony_ci    UNSCRATCH            1,  8, rsp+%3+%4+16
895cabdff1aSopenharmony_ci%endif
896cabdff1aSopenharmony_ci
897cabdff1aSopenharmony_ci    ; (m0: 0, [m1: flat8out], m2: fm & flat8in, m8..15: q2 q3 p1 p0 q0 q1 p3 p2)
898cabdff1aSopenharmony_ci    ; filter14()
899cabdff1aSopenharmony_ci    ;
900cabdff1aSopenharmony_ci    ;                            m2  m3  m8  m9 m14 m15 m10 m11 m12 m13
901cabdff1aSopenharmony_ci    ;
902cabdff1aSopenharmony_ci    ;                                    q2  q3  p3  p2  p1  p0  q0  q1
903cabdff1aSopenharmony_ci    ; p6  -7                     p7  p6  p5  p4   .   .   .   .   .
904cabdff1aSopenharmony_ci    ; p5  -6  -p7 -p6 +p5 +q1     .   .   .                           .
905cabdff1aSopenharmony_ci    ; p4  -5  -p7 -p5 +p4 +q2     .       .   .                      q2
906cabdff1aSopenharmony_ci    ; p3  -4  -p7 -p4 +p3 +q3     .           .   .                  q3
907cabdff1aSopenharmony_ci    ; p2  -3  -p7 -p3 +p2 +q4     .               .   .              q4
908cabdff1aSopenharmony_ci    ; p1  -2  -p7 -p2 +p1 +q5     .                   .   .          q5
909cabdff1aSopenharmony_ci    ; p0  -1  -p7 -p1 +p0 +q6     .                       .   .      q6
910cabdff1aSopenharmony_ci    ; q0  +0  -p7 -p0 +q0 +q7     .                           .   .  q7
911cabdff1aSopenharmony_ci    ; q1  +1  -p6 -q0 +q1 +q7    q1   .                           .   .
912cabdff1aSopenharmony_ci    ; q2  +2  -p5 -q1 +q2 +q7     .  q2   .                           .
913cabdff1aSopenharmony_ci    ; q3  +3  -p4 -q2 +q3 +q7         .  q3   .                       .
914cabdff1aSopenharmony_ci    ; q4  +4  -p3 -q3 +q4 +q7             .  q4   .                   .
915cabdff1aSopenharmony_ci    ; q5  +5  -p2 -q4 +q5 +q7                 .  q5   .               .
916cabdff1aSopenharmony_ci    ; q6  +6  -p1 -q5 +q6 +q7                     .  q6   .           .
917cabdff1aSopenharmony_ci
918cabdff1aSopenharmony_ci%if %2 == 16
919cabdff1aSopenharmony_ci    pand            m1, m2                                                              ; mask(out) & (mask(fm) & mask(in))
920cabdff1aSopenharmony_ci    mova            m2, [P7]
921cabdff1aSopenharmony_ci    mova            m3, [P6]
922cabdff1aSopenharmony_ci%ifdef m8
923cabdff1aSopenharmony_ci    mova            m8, [P5]
924cabdff1aSopenharmony_ci    mova            m9, [P4]
925cabdff1aSopenharmony_ci%define rp5 m8
926cabdff1aSopenharmony_ci%define rp4 m9
927cabdff1aSopenharmony_ci%define rp5s m8
928cabdff1aSopenharmony_ci%define rp4s m9
929cabdff1aSopenharmony_ci%define rp3s m14
930cabdff1aSopenharmony_ci%define rq4 m8
931cabdff1aSopenharmony_ci%define rq5 m9
932cabdff1aSopenharmony_ci%define rq6 m14
933cabdff1aSopenharmony_ci%define rq7 m15
934cabdff1aSopenharmony_ci%define rq4s m8
935cabdff1aSopenharmony_ci%define rq5s m9
936cabdff1aSopenharmony_ci%define rq6s m14
937cabdff1aSopenharmony_ci%else
938cabdff1aSopenharmony_ci%define rp5 [P5]
939cabdff1aSopenharmony_ci%define rp4 [P4]
940cabdff1aSopenharmony_ci%define rp5s ""
941cabdff1aSopenharmony_ci%define rp4s ""
942cabdff1aSopenharmony_ci%define rp3s ""
943cabdff1aSopenharmony_ci%define rq4 [Q4]
944cabdff1aSopenharmony_ci%define rq5 [Q5]
945cabdff1aSopenharmony_ci%define rq6 [Q6]
946cabdff1aSopenharmony_ci%define rq7 [Q7]
947cabdff1aSopenharmony_ci%define rq4s ""
948cabdff1aSopenharmony_ci%define rq5s ""
949cabdff1aSopenharmony_ci%define rq6s ""
950cabdff1aSopenharmony_ci%endif
951cabdff1aSopenharmony_ci    FILTER_INIT     m4, m5, m6, m7, [P6], %4, 14,                m1,  m3            ; [p6]
952cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [P5], %4,  8,  9, 10,  5, 4, m1, rp5s           ; [p5] -p7 -p6 +p5 +q1
953cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [P4], %4,  8, 10, 11,  6, 4, m1, rp4s           ; [p4] -p7 -p5 +p4 +q2
954cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [P3], %4,  8, 11,  0,  7, 4, m1, rp3s           ; [p3] -p7 -p4 +p3 +q3
955cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [P2], %4,  8,  0,  1, 12, 4, m1,  "", rq4, [Q4], 1 ; [p2] -p7 -p3 +p2 +q4
956cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [P1], %4,  8,  1,  2, 13, 4, m1,  "", rq5, [Q5], 1 ; [p1] -p7 -p2 +p1 +q5
957cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [P0], %4,  8,  2,  3, 14, 4, m1,  "", rq6, [Q6], 1 ; [p0] -p7 -p1 +p0 +q6
958cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [Q0], %4,  8,  3,  4, 15, 4, m1,  "", rq7, [Q7], 1 ; [q0] -p7 -p0 +q0 +q7
959cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [Q1], %4,  9,  4,  5, 15, 4, m1,  ""            ; [q1] -p6 -q0 +q1 +q7
960cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [Q2], %4, 10,  5,  6, 15, 4, m1,  ""            ; [q2] -p5 -q1 +q2 +q7
961cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [Q3], %4, 11,  6,  7, 15, 4, m1,  ""            ; [q3] -p4 -q2 +q3 +q7
962cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [Q4], %4,  0,  7, 12, 15, 4, m1, rq4s           ; [q4] -p3 -q3 +q4 +q7
963cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [Q5], %4,  1, 12, 13, 15, 4, m1, rq5s           ; [q5] -p2 -q4 +q5 +q7
964cabdff1aSopenharmony_ci    FILTER_UPDATE   m4, m5, m6, m7, [Q6], %4,  2, 13, 14, 15, 4, m1, rq6s           ; [q6] -p1 -q5 +q6 +q7
965cabdff1aSopenharmony_ci%endif
966cabdff1aSopenharmony_ci
967cabdff1aSopenharmony_ci%ifidn %1, h
968cabdff1aSopenharmony_ci%if %2 == 16
969cabdff1aSopenharmony_ci    mova                    m0, [P7]
970cabdff1aSopenharmony_ci    mova                    m1, [P6]
971cabdff1aSopenharmony_ci    mova                    m2, [P5]
972cabdff1aSopenharmony_ci    mova                    m3, [P4]
973cabdff1aSopenharmony_ci    mova                    m4, [P3]
974cabdff1aSopenharmony_ci    mova                    m5, [P2]
975cabdff1aSopenharmony_ci%if ARCH_X86_64
976cabdff1aSopenharmony_ci    mova                    m6, [P1]
977cabdff1aSopenharmony_ci%endif
978cabdff1aSopenharmony_ci    mova                    m7, [P0]
979cabdff1aSopenharmony_ci%if ARCH_X86_64
980cabdff1aSopenharmony_ci    mova                    m8, [Q0]
981cabdff1aSopenharmony_ci    mova                    m9, [Q1]
982cabdff1aSopenharmony_ci    mova                   m10, [Q2]
983cabdff1aSopenharmony_ci    mova                   m11, [Q3]
984cabdff1aSopenharmony_ci    mova                   m12, [Q4]
985cabdff1aSopenharmony_ci    mova                   m13, [Q5]
986cabdff1aSopenharmony_ci    mova                   m14, [Q6]
987cabdff1aSopenharmony_ci    mova                   m15, [Q7]
988cabdff1aSopenharmony_ci    TRANSPOSE16x16B 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, [rsp]
989cabdff1aSopenharmony_ci    DEFINE_REAL_P7_TO_Q7
990cabdff1aSopenharmony_ci    movu  [P7],  m0
991cabdff1aSopenharmony_ci    movu  [P6],  m1
992cabdff1aSopenharmony_ci    movu  [P5],  m2
993cabdff1aSopenharmony_ci    movu  [P4],  m3
994cabdff1aSopenharmony_ci    movu  [P3],  m4
995cabdff1aSopenharmony_ci    movu  [P2],  m5
996cabdff1aSopenharmony_ci    movu  [P1],  m6
997cabdff1aSopenharmony_ci    movu  [P0],  m7
998cabdff1aSopenharmony_ci    movu  [Q0],  m8
999cabdff1aSopenharmony_ci    movu  [Q1],  m9
1000cabdff1aSopenharmony_ci    movu  [Q2], m10
1001cabdff1aSopenharmony_ci    movu  [Q3], m11
1002cabdff1aSopenharmony_ci    movu  [Q4], m12
1003cabdff1aSopenharmony_ci    movu  [Q5], m13
1004cabdff1aSopenharmony_ci    movu  [Q6], m14
1005cabdff1aSopenharmony_ci    movu  [Q7], m15
1006cabdff1aSopenharmony_ci%else
1007cabdff1aSopenharmony_ci    DEFINE_REAL_P7_TO_Q7
1008cabdff1aSopenharmony_ci    TRANSPOSE8x8B 0, 1, 2, 3, 4, 5, 6, 7, [rsp+32], a, [rsp+%3+%4], [Q0], [Q1]
1009cabdff1aSopenharmony_ci    movh   [P7],  m0
1010cabdff1aSopenharmony_ci    movh   [P5],  m1
1011cabdff1aSopenharmony_ci    movh   [P3],  m2
1012cabdff1aSopenharmony_ci    movh   [P1],  m3
1013cabdff1aSopenharmony_ci    movh   [Q2],  m5
1014cabdff1aSopenharmony_ci    movh   [Q4],  m6
1015cabdff1aSopenharmony_ci    movh   [Q6],  m7
1016cabdff1aSopenharmony_ci    movhps [P6],  m0
1017cabdff1aSopenharmony_ci    movhps [P4],  m1
1018cabdff1aSopenharmony_ci    movhps [P2],  m2
1019cabdff1aSopenharmony_ci    movhps [P0],  m3
1020cabdff1aSopenharmony_ci    movhps [Q3],  m5
1021cabdff1aSopenharmony_ci    movhps [Q5],  m6
1022cabdff1aSopenharmony_ci    movhps [Q7],  m7
1023cabdff1aSopenharmony_ci    DEFINE_TRANSPOSED_P7_TO_Q7
1024cabdff1aSopenharmony_ci    mova                    m0, [Q0]
1025cabdff1aSopenharmony_ci    mova                    m1, [Q1]
1026cabdff1aSopenharmony_ci    mova                    m2, [Q2]
1027cabdff1aSopenharmony_ci    mova                    m3, [Q3]
1028cabdff1aSopenharmony_ci    mova                    m4, [Q4]
1029cabdff1aSopenharmony_ci    mova                    m5, [Q5]
1030cabdff1aSopenharmony_ci    mova                    m7, [Q7]
1031cabdff1aSopenharmony_ci    DEFINE_REAL_P7_TO_Q7 8
1032cabdff1aSopenharmony_ci    TRANSPOSE8x8B 0, 1, 2, 3, 4, 5, 6, 7, [rsp+224], a, [rsp+%3+%4], [Q0], [Q1]
1033cabdff1aSopenharmony_ci    movh   [P7],  m0
1034cabdff1aSopenharmony_ci    movh   [P5],  m1
1035cabdff1aSopenharmony_ci    movh   [P3],  m2
1036cabdff1aSopenharmony_ci    movh   [P1],  m3
1037cabdff1aSopenharmony_ci    movh   [Q2],  m5
1038cabdff1aSopenharmony_ci    movh   [Q4],  m6
1039cabdff1aSopenharmony_ci    movh   [Q6],  m7
1040cabdff1aSopenharmony_ci    movhps [P6],  m0
1041cabdff1aSopenharmony_ci    movhps [P4],  m1
1042cabdff1aSopenharmony_ci    movhps [P2],  m2
1043cabdff1aSopenharmony_ci    movhps [P0],  m3
1044cabdff1aSopenharmony_ci    movhps [Q3],  m5
1045cabdff1aSopenharmony_ci    movhps [Q5],  m6
1046cabdff1aSopenharmony_ci    movhps [Q7],  m7
1047cabdff1aSopenharmony_ci%endif
1048cabdff1aSopenharmony_ci%elif %2 == 44 || %2 == 4
1049cabdff1aSopenharmony_ci    SWAP 0, 1   ; m0 = p1
1050cabdff1aSopenharmony_ci    SWAP 1, 7   ; m1 = p0
1051cabdff1aSopenharmony_ci    SWAP 2, 5   ; m2 = q0
1052cabdff1aSopenharmony_ci    SWAP 3, 4   ; m3 = q1
1053cabdff1aSopenharmony_ci    DEFINE_REAL_P7_TO_Q7 2
1054cabdff1aSopenharmony_ci    SBUTTERFLY  bw, 0, 1, 4
1055cabdff1aSopenharmony_ci    SBUTTERFLY  bw, 2, 3, 4
1056cabdff1aSopenharmony_ci    SBUTTERFLY  wd, 0, 2, 4
1057cabdff1aSopenharmony_ci    SBUTTERFLY  wd, 1, 3, 4
1058cabdff1aSopenharmony_ci%if mmsize == 16
1059cabdff1aSopenharmony_ci    movd  [P7], m0
1060cabdff1aSopenharmony_ci    movd  [P3], m2
1061cabdff1aSopenharmony_ci    movd  [Q0], m1
1062cabdff1aSopenharmony_ci    movd  [Q4], m3
1063cabdff1aSopenharmony_ci    psrldq  m0, 4
1064cabdff1aSopenharmony_ci    psrldq  m1, 4
1065cabdff1aSopenharmony_ci    psrldq  m2, 4
1066cabdff1aSopenharmony_ci    psrldq  m3, 4
1067cabdff1aSopenharmony_ci    movd  [P6], m0
1068cabdff1aSopenharmony_ci    movd  [P2], m2
1069cabdff1aSopenharmony_ci    movd  [Q1], m1
1070cabdff1aSopenharmony_ci    movd  [Q5], m3
1071cabdff1aSopenharmony_ci    psrldq  m0, 4
1072cabdff1aSopenharmony_ci    psrldq  m1, 4
1073cabdff1aSopenharmony_ci    psrldq  m2, 4
1074cabdff1aSopenharmony_ci    psrldq  m3, 4
1075cabdff1aSopenharmony_ci    movd  [P5], m0
1076cabdff1aSopenharmony_ci    movd  [P1], m2
1077cabdff1aSopenharmony_ci    movd  [Q2], m1
1078cabdff1aSopenharmony_ci    movd  [Q6], m3
1079cabdff1aSopenharmony_ci    psrldq  m0, 4
1080cabdff1aSopenharmony_ci    psrldq  m1, 4
1081cabdff1aSopenharmony_ci    psrldq  m2, 4
1082cabdff1aSopenharmony_ci    psrldq  m3, 4
1083cabdff1aSopenharmony_ci    movd  [P4], m0
1084cabdff1aSopenharmony_ci    movd  [P0], m2
1085cabdff1aSopenharmony_ci    movd  [Q3], m1
1086cabdff1aSopenharmony_ci    movd  [Q7], m3
1087cabdff1aSopenharmony_ci%else
1088cabdff1aSopenharmony_ci    movd  [P7], m0
1089cabdff1aSopenharmony_ci    movd  [P5], m2
1090cabdff1aSopenharmony_ci    movd  [P3], m1
1091cabdff1aSopenharmony_ci    movd  [P1], m3
1092cabdff1aSopenharmony_ci    psrlq   m0, 32
1093cabdff1aSopenharmony_ci    psrlq   m2, 32
1094cabdff1aSopenharmony_ci    psrlq   m1, 32
1095cabdff1aSopenharmony_ci    psrlq   m3, 32
1096cabdff1aSopenharmony_ci    movd  [P6], m0
1097cabdff1aSopenharmony_ci    movd  [P4], m2
1098cabdff1aSopenharmony_ci    movd  [P2], m1
1099cabdff1aSopenharmony_ci    movd  [P0], m3
1100cabdff1aSopenharmony_ci%endif
1101cabdff1aSopenharmony_ci%else
1102cabdff1aSopenharmony_ci    ; the following code do a transpose of 8 full lines to 16 half
1103cabdff1aSopenharmony_ci    ; lines (high part). It is inlined to avoid the need of a staging area
1104cabdff1aSopenharmony_ci    mova                    m0, [P3]
1105cabdff1aSopenharmony_ci    mova                    m1, [P2]
1106cabdff1aSopenharmony_ci    mova                    m2, [P1]
1107cabdff1aSopenharmony_ci    mova                    m3, [P0]
1108cabdff1aSopenharmony_ci    mova                    m4, [Q0]
1109cabdff1aSopenharmony_ci    mova                    m5, [Q1]
1110cabdff1aSopenharmony_ci%ifdef m8
1111cabdff1aSopenharmony_ci    mova                    m6, [Q2]
1112cabdff1aSopenharmony_ci%endif
1113cabdff1aSopenharmony_ci    mova                    m7, [Q3]
1114cabdff1aSopenharmony_ci    DEFINE_REAL_P7_TO_Q7
1115cabdff1aSopenharmony_ci%ifdef m8
1116cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  0,  1, 8
1117cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  2,  3, 8
1118cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  4,  5, 8
1119cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  6,  7, 8
1120cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  0,  2, 8
1121cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  1,  3, 8
1122cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  4,  6, 8
1123cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  5,  7, 8
1124cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  0,  4, 8
1125cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  1,  5, 8
1126cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  2,  6, 8
1127cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  3,  7, 8
1128cabdff1aSopenharmony_ci%else
1129cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  0,  1, 6
1130cabdff1aSopenharmony_ci    mova [rsp+mmsize*4], m1
1131cabdff1aSopenharmony_ci    mova        m6, [rsp+mmsize*6]
1132cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  2,  3, 1
1133cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  4,  5, 1
1134cabdff1aSopenharmony_ci    SBUTTERFLY  bw,  6,  7, 1
1135cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  0,  2, 1
1136cabdff1aSopenharmony_ci    mova [rsp+mmsize*6], m2
1137cabdff1aSopenharmony_ci    mova        m1, [rsp+mmsize*4]
1138cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  1,  3, 2
1139cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  4,  6, 2
1140cabdff1aSopenharmony_ci    SBUTTERFLY  wd,  5,  7, 2
1141cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  0,  4, 2
1142cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  1,  5, 2
1143cabdff1aSopenharmony_ci%if mmsize == 16
1144cabdff1aSopenharmony_ci    movh      [Q0], m1
1145cabdff1aSopenharmony_ci    movhps    [Q1], m1
1146cabdff1aSopenharmony_ci%else
1147cabdff1aSopenharmony_ci    mova      [P3], m1
1148cabdff1aSopenharmony_ci%endif
1149cabdff1aSopenharmony_ci    mova        m2, [rsp+mmsize*6]
1150cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  2,  6, 1
1151cabdff1aSopenharmony_ci    SBUTTERFLY  dq,  3,  7, 1
1152cabdff1aSopenharmony_ci%endif
1153cabdff1aSopenharmony_ci    SWAP         3, 6
1154cabdff1aSopenharmony_ci    SWAP         1, 4
1155cabdff1aSopenharmony_ci%if mmsize == 16
1156cabdff1aSopenharmony_ci    movh      [P7], m0
1157cabdff1aSopenharmony_ci    movhps    [P6], m0
1158cabdff1aSopenharmony_ci    movh      [P5], m1
1159cabdff1aSopenharmony_ci    movhps    [P4], m1
1160cabdff1aSopenharmony_ci    movh      [P3], m2
1161cabdff1aSopenharmony_ci    movhps    [P2], m2
1162cabdff1aSopenharmony_ci    movh      [P1], m3
1163cabdff1aSopenharmony_ci    movhps    [P0], m3
1164cabdff1aSopenharmony_ci%ifdef m8
1165cabdff1aSopenharmony_ci    movh      [Q0], m4
1166cabdff1aSopenharmony_ci    movhps    [Q1], m4
1167cabdff1aSopenharmony_ci%endif
1168cabdff1aSopenharmony_ci    movh      [Q2], m5
1169cabdff1aSopenharmony_ci    movhps    [Q3], m5
1170cabdff1aSopenharmony_ci    movh      [Q4], m6
1171cabdff1aSopenharmony_ci    movhps    [Q5], m6
1172cabdff1aSopenharmony_ci    movh      [Q6], m7
1173cabdff1aSopenharmony_ci    movhps    [Q7], m7
1174cabdff1aSopenharmony_ci%else
1175cabdff1aSopenharmony_ci    mova      [P7], m0
1176cabdff1aSopenharmony_ci    mova      [P6], m1
1177cabdff1aSopenharmony_ci    mova      [P5], m2
1178cabdff1aSopenharmony_ci    mova      [P4], m3
1179cabdff1aSopenharmony_ci    mova      [P2], m5
1180cabdff1aSopenharmony_ci    mova      [P1], m6
1181cabdff1aSopenharmony_ci    mova      [P0], m7
1182cabdff1aSopenharmony_ci%endif
1183cabdff1aSopenharmony_ci%endif
1184cabdff1aSopenharmony_ci%endif
1185cabdff1aSopenharmony_ci
1186cabdff1aSopenharmony_ci    RET
1187cabdff1aSopenharmony_ci%endmacro
1188cabdff1aSopenharmony_ci
1189cabdff1aSopenharmony_ci%macro LPF_16_VH 5
1190cabdff1aSopenharmony_ciINIT_XMM %5
1191cabdff1aSopenharmony_ciLOOPFILTER v, %1, %2,  0, %4
1192cabdff1aSopenharmony_ciLOOPFILTER h, %1, %2, %3, %4
1193cabdff1aSopenharmony_ci%endmacro
1194cabdff1aSopenharmony_ci
1195cabdff1aSopenharmony_ci%macro LPF_16_VH_ALL_OPTS 4
1196cabdff1aSopenharmony_ciLPF_16_VH %1, %2, %3, %4, sse2
1197cabdff1aSopenharmony_ciLPF_16_VH %1, %2, %3, %4, ssse3
1198cabdff1aSopenharmony_ciLPF_16_VH %1, %2, %3, %4, avx
1199cabdff1aSopenharmony_ci%endmacro
1200cabdff1aSopenharmony_ci
1201cabdff1aSopenharmony_ciLPF_16_VH_ALL_OPTS 16, 512, 256, 32
1202cabdff1aSopenharmony_ciLPF_16_VH_ALL_OPTS 44,   0, 128,  0
1203cabdff1aSopenharmony_ciLPF_16_VH_ALL_OPTS 48, 256, 128, 16
1204cabdff1aSopenharmony_ciLPF_16_VH_ALL_OPTS 84, 256, 128, 16
1205cabdff1aSopenharmony_ciLPF_16_VH_ALL_OPTS 88, 256, 128, 16
1206cabdff1aSopenharmony_ci
1207cabdff1aSopenharmony_ciINIT_MMX mmxext
1208cabdff1aSopenharmony_ciLOOPFILTER v, 4,   0,  0, 0
1209cabdff1aSopenharmony_ciLOOPFILTER h, 4,   0, 64, 0
1210cabdff1aSopenharmony_ciLOOPFILTER v, 8, 128,  0, 8
1211cabdff1aSopenharmony_ciLOOPFILTER h, 8, 128, 64, 8
1212