1//******************************************************************************
2//*
3//* Copyright (C) 2015 The Android Open Source Project
4//*
5//* Licensed under the Apache License, Version 2.0 (the "License");
6//* you may not use this file except in compliance with the License.
7//* You may obtain a copy of the License at:
8//*
9//* http://www.apache.org/licenses/LICENSE-2.0
10//*
11//* Unless required by applicable law or agreed to in writing, software
12//* distributed under the License is distributed on an "AS IS" BASIS,
13//* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14//* See the License for the specific language governing permissions and
15//* limitations under the License.
16//*
17//*****************************************************************************
18//* Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19//*/
20///**
21// *******************************************************************************
22// * @file
23// *  impeg2_idct.s
24// *
25// * @brief
26// *  contains function definitions for single stage  inverse transform
27// *
28// * @author
29// *  anand s
30// *
31// * @par list of functions:
32// *  - impeg2_idct_recon_dc_av8()
33// *
34// * @remarks
35// *  none
36// *
37// *******************************************************************************
38//*/
39
40///**
41// *******************************************************************************
42// *
43// * @brief
44// *  this function performs inverse transform  and reconstruction for 8x8
45// * input block
46// *
47// * @par description:
48// *  performs inverse transform and adds the prediction  data and clips output
49// * to 8 bit
50// *
51// * @param[in] pi2_src
52// *  input 8x8 coefficients
53// *
54// * @param[in] pi2_tmp
55// *  temporary 8x8 buffer for storing inverse
56// *
57// *  transform
58// *  1st stage output
59// *
60// * @param[in] pu1_pred
61// *  prediction 8x8 block
62// *
63// * @param[out] pu1_dst
64// *  output 8x8 block
65// *
66// * @param[in] src_strd
67// *  input stride
68// *
69// * @param[in] pred_strd
70// *  prediction stride
71// *
72// * @param[in] dst_strd
73// *  output stride
74// *
75// * @param[in] shift
76// *  output shift
77// *
78// * @param[in] zero_cols
79// *  zero columns in pi2_src
80// *
81// * @returns  void
82// *
83// * @remarks
84// *  none
85// *
86// *******************************************************************************
87// */
88
89//void impeg2_itrans_recon_8x8(word16 *pi2_src,
90//                            word16 *pi2_tmp,
91//                            uword8 *pu1_pred,
92//                            uword8 *pu1_dst,
93//                            word32 src_strd,
94//                            word32 pred_strd,
95//                            word32 dst_strd,
96//                            word32 zero_cols
97//                             word32    zero_rows                )
98
99//**************variables vs registers*************************
100//    x0 => *pi2_src
101//    x1 => *pi2_tmp
102//    x2 => *pu1_pred
103//    x3 => *pu1_dst
104//    src_strd
105//    pred_strd
106//    dst_strd
107//    zero_cols
108
109
110
111.text
112.align 4
113.include "impeg2_neon_macros.s"
114
115.set idct_stg1_shift       ,            12
116.set idct_stg2_shift       ,            16
117.set idct_stg1_round        ,           (1 << (idct_stg1_shift - 1))
118.set idct_stg2_round        ,           (1 << (idct_stg2_shift - 1))
119
120.extern gai2_impeg2_idct_q15
121.extern gai2_impeg2_idct_q11
122.extern gai2_impeg2_idct_first_col_q15
123.extern gai2_impeg2_idct_first_col_q11
124.extern gai2_impeg2_mismatch_stg2_additive
125
126.global impeg2_idct_recon_dc_av8
127impeg2_idct_recon_dc_av8:
128    // STMFD sp!,{x4,x6,x12,x14}
129    push_v_regs
130    ////x0: pi2_src
131    ////x1: pi2_tmp - not used, used as pred_strd
132    ////x2: pu1_pred
133    ////x3: pu1_dst
134    ////x4: used as scratch
135    ////x5: pred_strd
136    ////x6: dst_strd
137
138    ldrsh           x4, [x0]
139    adrp            x14, :got:gai2_impeg2_idct_q15
140    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_q15]
141    ldrsh           x12, [x14]
142
143    ld1             {v0.8b}, [x2], x5
144    mul             x4, x4, x12
145
146    ld1             {v1.8b}, [x2], x5
147    add             x4, x4, #idct_stg1_round
148
149    ld1             {v2.8b}, [x2], x5
150    asr             x4, x4, #idct_stg1_shift
151
152    adrp            x14, :got:gai2_impeg2_idct_q11
153    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_q11]
154    ldrsh           x12, [x14]
155
156    ld1             {v3.8b}, [x2], x5
157    mul             x4, x4, x12
158
159    ld1             {v4.8b}, [x2], x5
160    add             x4, x4, #idct_stg2_round
161
162    ld1             {v5.8b}, [x2], x5
163    asr             x4, x4, #idct_stg2_shift
164
165    ld1             {v6.8b}, [x2], x5
166    dup             v30.8h, w4
167
168
169    ld1             {v7.8b}, [x2], x5
170
171    uaddw           v8.8h, v30.8h , v0.8b
172
173    uaddw           v10.8h, v30.8h , v1.8b
174    sqxtun          v0.8b, v8.8h
175
176    uaddw           v12.8h, v30.8h , v2.8b
177    sqxtun          v1.8b, v10.8h
178    st1             {v0.8b}, [x3], x6
179
180    uaddw           v14.8h, v30.8h , v3.8b
181    sqxtun          v2.8b, v12.8h
182    st1             {v1.8b}, [x3], x6
183
184    uaddw           v16.8h, v30.8h , v4.8b
185    sqxtun          v3.8b, v14.8h
186    st1             {v2.8b}, [x3], x6
187
188    uaddw           v18.8h, v30.8h , v5.8b
189    sqxtun          v4.8b, v16.8h
190    st1             {v3.8b}, [x3], x6
191
192    uaddw           v20.8h, v30.8h , v6.8b
193    sqxtun          v5.8b, v18.8h
194    st1             {v4.8b}, [x3], x6
195
196    uaddw           v22.8h, v30.8h , v7.8b
197    sqxtun          v6.8b, v20.8h
198    st1             {v5.8b}, [x3], x6
199
200    sqxtun          v7.8b, v22.8h
201    st1             {v6.8b}, [x3], x6
202
203
204    st1             {v7.8b}, [x3], x6
205
206    // LDMFD sp!,{x4,x6,x12,pc}
207    pop_v_regs
208    ret
209
210
211
212.global impeg2_idct_recon_dc_mismatch_av8
213.extern gai2_impeg2_idct_last_row_q11
214.extern gai2_impeg2_mismatch_stg1_outp
215impeg2_idct_recon_dc_mismatch_av8:
216    // STMFD sp!,{x4-x12,x14}
217    push_v_regs
218
219    ldrsh           x4, [x0]
220    adrp            x14, :got:gai2_impeg2_idct_q15
221    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_q15]
222    ldrsh           x12, [x14]
223
224    mul             x4, x4, x12
225    add             x4, x4, #idct_stg1_round
226    asr             x4, x4, #idct_stg1_shift
227
228    adrp            x14, :got:gai2_impeg2_idct_q11
229    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_q11]
230    ldrsh           x12, [x14]
231    mul             x4, x4, x12
232    dup             v0.4s, w4
233
234    mov             x14, #16            ////Increment for table read
235    adrp            x4, :got:gai2_impeg2_mismatch_stg2_additive
236    ldr             x4, [x4, #:got_lo12:gai2_impeg2_mismatch_stg2_additive]
237
238    ld1             {v2.4h, v3.4h}, [x4], x14
239    ld1             {v30.8b}, [x2], x5
240    sxtl            v8.4s, v2.4h
241    sxtl            v10.4s, v3.4h
242    raddhn          v12.4h, v0.4s, v8.4s
243    raddhn2         v12.8h, v0.4s, v10.4s
244    uaddw           v14.8h, v12.8h , v30.8b
245    sqxtun          v30.8b, v14.8h
246    st1             {v30.8b}, [x3], x6
247
248    ld1             {v2.4h, v3.4h}, [x4], x14
249    ld1             {v30.8b}, [x2], x5
250    sxtl            v8.4s, v2.4h
251    sxtl            v10.4s, v3.4h
252    raddhn          v12.4h, v0.4s, v8.4s
253    raddhn2         v12.8h, v0.4s, v10.4s
254    uaddw           v14.8h, v12.8h , v30.8b
255    sqxtun          v30.8b, v14.8h
256    st1             {v30.8b}, [x3], x6
257
258    ld1             {v2.4h, v3.4h}, [x4], x14
259    ld1             {v30.8b}, [x2], x5
260    sxtl            v8.4s, v2.4h
261    sxtl            v10.4s, v3.4h
262    raddhn          v12.4h, v0.4s, v8.4s
263    raddhn2         v12.8h, v0.4s, v10.4s
264    uaddw           v14.8h, v12.8h , v30.8b
265    sqxtun          v30.8b, v14.8h
266    st1             {v30.8b}, [x3], x6
267
268    ld1             {v2.4h, v3.4h}, [x4], x14
269    ld1             {v30.8b}, [x2], x5
270    sxtl            v8.4s, v2.4h
271    sxtl            v10.4s, v3.4h
272    raddhn          v12.4h, v0.4s, v8.4s
273    raddhn2         v12.8h, v0.4s, v10.4s
274    uaddw           v14.8h, v12.8h , v30.8b
275    sqxtun          v30.8b, v14.8h
276    st1             {v30.8b}, [x3], x6
277
278    ld1             {v2.4h, v3.4h}, [x4], x14
279    ld1             {v30.8b}, [x2], x5
280    sxtl            v8.4s, v2.4h
281    sxtl            v10.4s, v3.4h
282    raddhn          v12.4h, v0.4s, v8.4s
283    raddhn2         v12.8h, v0.4s, v10.4s
284    uaddw           v14.8h, v12.8h , v30.8b
285    sqxtun          v30.8b, v14.8h
286    st1             {v30.8b}, [x3], x6
287
288    ld1             {v2.4h, v3.4h}, [x4], x14
289    ld1             {v30.8b}, [x2], x5
290    sxtl            v8.4s, v2.4h
291    sxtl            v10.4s, v3.4h
292    raddhn          v12.4h, v0.4s, v8.4s
293    raddhn2         v12.8h, v0.4s, v10.4s
294    uaddw           v14.8h, v12.8h , v30.8b
295    sqxtun          v30.8b, v14.8h
296    st1             {v30.8b}, [x3], x6
297
298    ld1             {v2.4h, v3.4h}, [x4], x14
299    ld1             {v30.8b}, [x2], x5
300    sxtl            v8.4s, v2.4h
301    sxtl            v10.4s, v3.4h
302    raddhn          v12.4h, v0.4s, v8.4s
303    raddhn2         v12.8h, v0.4s, v10.4s
304    uaddw           v14.8h, v12.8h , v30.8b
305    sqxtun          v30.8b, v14.8h
306    st1             {v30.8b}, [x3], x6
307
308    ld1             {v2.4h, v3.4h}, [x4], x14
309    ld1             {v30.8b}, [x2], x5
310    sxtl            v8.4s, v2.4h
311    sxtl            v10.4s, v3.4h
312    raddhn          v12.4h, v0.4s, v8.4s
313    raddhn2         v12.8h, v0.4s, v10.4s
314    uaddw           v14.8h, v12.8h , v30.8b
315    sqxtun          v30.8b, v14.8h
316    st1             {v30.8b}, [x3], x6
317
318
319    // LDMFD sp!,{x4-x12,pc}
320    pop_v_regs
321    ret
322
323.globl impeg2_idct_recon_av8
324
325.type impeg2_idct_recon_av8, %function
326
327impeg2_idct_recon_av8:
328////register usage.extern        - loading and until idct of columns
329////    cosine constants     -     d0
330////    sine constants         -     d1
331////    row 0 first half     -     d2        -    y0
332////    row 1 first half     -     d6        -    y1
333////    row 2 first half     -     d3        -    y2
334////    row 3 first half     -     d7        -    y3
335////    row 4 first half     -     d10        -    y4
336////    row 5 first half     -     d14        -    y5
337////    row 6 first half     -     d11        -    y6
338////    row 7 first half     -     d15        -    y7
339
340////    row 0 second half    -     d4        -    y0
341////    row 1 second half    -     d8      -    y1
342////    row 2 second half    -     d5      -    y2
343////    row 3 second half    -     d9      -    y3
344////    row 4 second half    -     d12     -    y4
345////    row 5 second half    -     d16     -    y5
346////    row 6 second half    -     d13     -    y6
347////    row 7 second half    -     d17     -    y7
348
349    //// copy the input pointer to another register
350    //// step 1 : load all constants
351    // stmfd sp!,{x4-x12,x14}
352
353    ldr             w11, [sp]           // zero rows
354
355    push_v_regs
356    stp             x19, x20, [sp, #-16]!
357
358    mov             x12, x7             // zero columns
359    mov             x8, x5              // prediction stride
360    mov             x7, x6              // destination stride
361    mov             x6, x4              // src stride
362    lsl             x6, x6, #1          // x sizeof(word16)
363    add             x9, x0, x6, lsl #1  // 2 rows
364
365    add             x10, x6, x6, lsl #1 // 3 rows
366
367    sub             x10, x10, #8        // - 4 cols * sizeof(word16)
368    sub             x5, x6, #8          // src_strd - 4 cols * sizeof(word16)
369
370    adrp            x14, :got:gai2_impeg2_idct_first_col_q15
371    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_first_col_q15]
372    ld1             {v0.4h, v1.4h}, [x14] ////d0,d1 are used for storing the constant data
373
374    ////step 2 load all the input data
375    ////step 3 operate first 4 colums at a time
376
377    and             x11, x11, #0xff
378    and             x12, x12, #0xff
379
380    cmp             x11, #0xf0
381    bge             skip_last4_rows
382
383
384    ld1             {v2.4h}, [x0], #8
385    ld1             {v3.4h}, [x9], #8
386    ld1             {v4.4h}, [x0], x5
387    smull           v20.4s, v2.4h, v0.h[0] //// y0 * cos4(part of c0 and c1)
388    ld1             {v5.4h}, [x9], x5
389    smull           v18.4s, v3.4h, v1.h[2] //// y2 * sin2 (q3 is freed by this time)(part of d1)
390    ld1             {v6.4h}, [x0], #8
391    ld1             {v7.4h}, [x9], #8
392    smull           v24.4s, v6.4h, v0.h[1] //// y1 * cos1(part of b0)
393    ld1             {v8.4h}, [x0], x10
394    smull           v26.4s, v6.4h, v0.h[3] //// y1 * cos3(part of b1)
395    ld1             {v9.4h}, [x9], x10
396    smull           v28.4s, v6.4h, v1.h[1] //// y1 * sin3(part of b2)
397    ld1             {v10.4h}, [x0], #8
398    smull           v30.4s, v6.4h, v1.h[3] //// y1 * sin1(part of b3)
399    ld1             {v11.4h}, [x9], #8
400    smlal           v24.4s, v7.4h, v0.h[3] //// y1 * cos1 + y3 * cos3(part of b0)
401    ld1             {v12.4h}, [x0], x5
402    smlsl           v26.4s, v7.4h, v1.h[3] //// y1 * cos3 - y3 * sin1(part of b1)
403    ld1             {v13.4h}, [x9], x5
404    smlsl           v28.4s, v7.4h, v0.h[1] //// y1 * sin3 - y3 * cos1(part of b2)
405    ld1             {v14.4h}, [x0], #8
406    smlsl           v30.4s, v7.4h, v1.h[1] //// y1 * sin1 - y3 * sin3(part of b3)
407    ld1             {v15.4h}, [x9], #8
408    smull           v22.4s, v10.4h, v0.h[0] //// y4 * cos4(part of c0 and c1)
409    ld1             {v16.4h}, [x0], x10
410    smull           v6.4s, v3.4h, v0.h[2] //// y2 * cos2(part of d0)
411    ld1             {v17.4h}, [x9], x10
412
413    ///* this following was activated when alignment is not there */
414////    vld1.16        d2,[x0]!
415////    vld1.16        d3,[x2]!
416////    vld1.16        d4,[x0]!
417////    vld1.16        d5,[x2]!
418////    vld1.16        d6,[x0]!
419////    vld1.16        d7,[x2]!
420////    vld1.16        d8,[x0],x3
421////    vld1.16        d9,[x2],x3
422////    vld1.16        d10,[x0]!
423////    vld1.16        d11,[x2]!
424////    vld1.16        d12,[x0]!
425////    vld1.16        d13,[x2]!
426////    vld1.16        d14,[x0]!
427////    vld1.16        d15,[x2]!
428////    vld1.16        d16,[x0],x3
429////    vld1.16        d17,[x2],x3
430
431
432
433
434    smlal           v24.4s, v14.4h, v1.h[1] //// y1 * cos1 + y3 * cos3 + y5 * sin3(part of b0)
435    smlsl           v26.4s, v14.4h, v0.h[1] //// y1 * cos3 - y3 * sin1 - y5 * cos1(part of b1)
436    smlal           v28.4s, v14.4h, v1.h[3] //// y1 * sin3 - y3 * cos1 + y5 * sin1(part of b2)
437    smlal           v30.4s, v14.4h, v0.h[3] //// y1 * sin1 - y3 * sin3 + y5 * cos3(part of b3)
438
439    smlsl           v18.4s, v11.4h, v0.h[2] //// d1 = y2 * sin2 - y6 * cos2(part of a0 and a1)
440    smlal           v6.4s, v11.4h, v1.h[2] //// d0 = y2 * cos2 + y6 * sin2(part of a0 and a1)
441
442    add             v10.4s, v20.4s , v22.4s //// c0 = y0 * cos4 + y4 * cos4(part of a0 and a1)
443    sub             v20.4s, v20.4s , v22.4s //// c1 = y0 * cos4 - y4 * cos4(part of a0 and a1)
444
445    smlal           v24.4s, v15.4h, v1.h[3] //// b0 = y1 * cos1 + y3 * cos3 + y5 * sin3 + y7 * sin1(part of x0,x7)
446    smlsl           v26.4s, v15.4h, v1.h[1] //// b1 = y1 * cos3 - y3 * sin1 - y5 * cos1 - y7 * sin3(part of x1,x6)
447    smlal           v28.4s, v15.4h, v0.h[3] //// b2 = y1 * sin3 - y3 * cos1 + y5 * sin1 + y7 * cos3(part of x2,x5)
448    smlsl           v30.4s, v15.4h, v0.h[1] //// b3 = y1 * sin1 - y3 * sin3 + y5 * cos3 - y7 * cos1(part of x3,x4)
449
450    add             v14.4s, v10.4s , v6.4s ////    a0 = c0 + d0(part of x0,x7)
451    sub             v10.4s, v10.4s , v6.4s //// a3 = c0 - d0(part of x3,x4)
452    sub             v22.4s, v20.4s , v18.4s //// a2 = c1 - d1(part of x2,x5)
453    add             v18.4s, v20.4s , v18.4s //// a1 = c1 + d1(part of x1,x6)
454
455    add             v20.4s, v14.4s , v24.4s //// a0 + b0(part of x0)
456    sub             v6.4s, v14.4s , v24.4s //// a0 - b0(part of x7)
457
458    add             v24.4s, v22.4s , v28.4s //// a2 + b2(part of x2)
459    sub             v22.4s, v22.4s , v28.4s //// a2 - b2(part of x5)
460
461    add             v28.4s, v18.4s , v26.4s //// a1 + b1(part of x1)
462    sub             v18.4s, v18.4s , v26.4s //// a1 - b1(part of x6)
463
464    add             v26.4s, v10.4s , v30.4s //// a3 + b3(part of x3)
465    sub             v30.4s, v10.4s , v30.4s //// a3 - b3(part of x4)
466
467    sqrshrn         v2.4h, v20.4s, #idct_stg1_shift //// x0 = (a0 + b0 + rnd) >> 7(IDCT_STG1_SHIFT)
468    sqrshrn         v15.4h, v6.4s, #idct_stg1_shift //// x7 = (a0 - b0 + rnd) >> 7(IDCT_STG1_SHIFT)
469    sqrshrn         v3.4h, v24.4s, #idct_stg1_shift //// x2 = (a2 + b2 + rnd) >> 7(IDCT_STG1_SHIFT)
470    sqrshrn         v14.4h, v22.4s, #idct_stg1_shift //// x5 = (a2 - b2 + rnd) >> 7(IDCT_STG1_SHIFT)
471    sqrshrn         v6.4h, v28.4s, #idct_stg1_shift //// x1 = (a1 + b1 + rnd) >> 7(IDCT_STG1_SHIFT)
472    sqrshrn         v11.4h, v18.4s, #idct_stg1_shift //// x6 = (a1 - b1 + rnd) >> 7(IDCT_STG1_SHIFT)
473    sqrshrn         v7.4h, v26.4s, #idct_stg1_shift //// x3 = (a3 + b3 + rnd) >> 7(IDCT_STG1_SHIFT)
474    sqrshrn         v10.4h, v30.4s, #idct_stg1_shift //// x4 = (a3 - b3 + rnd) >> 7(IDCT_STG1_SHIFT)
475
476
477    b               last4_cols
478
479
480
481skip_last4_rows:
482    adrp            x14, :got:gai2_impeg2_idct_first_col_q15
483    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_first_col_q15]
484    ld1             {v0.4h, v1.4h}, [x14]
485
486    ld1             {v2.4h}, [x0], #8
487    ld1             {v3.4h}, [x9], #8
488    ld1             {v4.4h}, [x0], x5
489    ld1             {v5.4h}, [x9], x5
490    ld1             {v6.4h}, [x0], #8
491    ld1             {v7.4h}, [x9], #8
492    ld1             {v8.4h}, [x0], x10
493    ld1             {v9.4h}, [x9], x10
494
495
496
497    movi            v12.4h, #0
498    movi            v13.4h, #0
499    movi            v16.4h, #0
500    movi            v17.4h, #0
501
502
503
504
505    smull           v24.4s, v6.4h, v0.h[1] //// y1 * cos1(part of b0)
506    smull           v26.4s, v6.4h, v0.h[3] //// y1 * cos3(part of b1)
507    smull           v28.4s, v6.4h, v1.h[1] //// y1 * sin3(part of b2)
508    smull           v30.4s, v6.4h, v1.h[3] //// y1 * sin1(part of b3)
509
510    smlal           v24.4s, v7.4h, v0.h[3] //// y1 * cos1 + y3 * cos3(part of b0)
511    smlsl           v26.4s, v7.4h, v1.h[3] //// y1 * cos3 - y3 * sin1(part of b1)
512    smlsl           v28.4s, v7.4h, v0.h[1] //// y1 * sin3 - y3 * cos1(part of b2)
513    smlsl           v30.4s, v7.4h, v1.h[1] //// y1 * sin1 - y3 * sin3(part of b3)
514
515    smull           v18.4s, v3.4h, v1.h[2] //// y2 * sin2 (q3 is freed by this time)(part of d1)
516    smull           v6.4s, v3.4h, v0.h[2] //// y2 * cos2(part of d0)
517
518    smull           v20.4s, v2.4h, v0.h[0] //// y0 * cos4(part of c0 and c1)
519
520
521    add             v14.4s, v20.4s , v6.4s ////    a0 = c0 + d0(part of x0,x7)
522    sub             v10.4s, v20.4s , v6.4s //// a3 = c0 - d0(part of x3,x4)
523    sub             v22.4s, v20.4s , v18.4s //// a2 = c1 - d1(part of x2,x5)
524    add             v18.4s, v20.4s , v18.4s //// a1 = c1 + d1(part of x1,x6)
525
526    add             v20.4s, v14.4s , v24.4s //// a0 + b0(part of x0)
527    sub             v6.4s, v14.4s , v24.4s //// a0 - b0(part of x7)
528
529    add             v24.4s, v22.4s , v28.4s //// a2 + b2(part of x2)
530    sub             v22.4s, v22.4s , v28.4s //// a2 - b2(part of x5)
531
532    add             v28.4s, v18.4s , v26.4s //// a1 + b1(part of x1)
533    sub             v18.4s, v18.4s , v26.4s //// a1 - b1(part of x6)
534
535    add             v26.4s, v10.4s , v30.4s //// a3 + b3(part of x3)
536    sub             v30.4s, v10.4s , v30.4s //// a3 - b3(part of x4)
537
538    sqrshrn         v2.4h, v20.4s, #idct_stg1_shift //// x0 = (a0 + b0 + rnd) >> 7(IDCT_STG1_SHIFT)
539    sqrshrn         v15.4h, v6.4s, #idct_stg1_shift //// x7 = (a0 - b0 + rnd) >> 7(IDCT_STG1_SHIFT)
540    sqrshrn         v3.4h, v24.4s, #idct_stg1_shift //// x2 = (a2 + b2 + rnd) >> 7(IDCT_STG1_SHIFT)
541    sqrshrn         v14.4h, v22.4s, #idct_stg1_shift //// x5 = (a2 - b2 + rnd) >> 7(IDCT_STG1_SHIFT)
542    sqrshrn         v6.4h, v28.4s, #idct_stg1_shift //// x1 = (a1 + b1 + rnd) >> 7(IDCT_STG1_SHIFT)
543    sqrshrn         v11.4h, v18.4s, #idct_stg1_shift //// x6 = (a1 - b1 + rnd) >> 7(IDCT_STG1_SHIFT)
544    sqrshrn         v7.4h, v26.4s, #idct_stg1_shift //// x3 = (a3 + b3 + rnd) >> 7(IDCT_STG1_SHIFT)
545    sqrshrn         v10.4h, v30.4s, #idct_stg1_shift //// x4 = (a3 - b3 + rnd) >> 7(IDCT_STG1_SHIFT)
546
547
548last4_cols:
549    adrp            x14, :got:gai2_impeg2_idct_first_col_q15
550    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_first_col_q15]
551    ld1             {v0.4h, v1.4h}, [x14]
552
553
554    cmp             x12, #0xf0
555    bge             skip_last4cols
556
557    smull           v24.4s, v8.4h, v0.h[1] //// y1 * cos1(part of b0)
558    smull           v26.4s, v8.4h, v0.h[3] //// y1 * cos3(part of b1)
559    smull           v28.4s, v8.4h, v1.h[1] //// y1 * sin3(part of b2)
560    smull           v30.4s, v8.4h, v1.h[3] //// y1 * sin1(part of b3)
561
562    smlal           v24.4s, v9.4h, v0.h[3] //// y1 * cos1 + y3 * cos3(part of b0)
563    smlsl           v26.4s, v9.4h, v1.h[3] //// y1 * cos3 - y3 * sin1(part of b1)
564    smlsl           v28.4s, v9.4h, v0.h[1] //// y1 * sin3 - y3 * cos1(part of b2)
565    smlsl           v30.4s, v9.4h, v1.h[1] //// y1 * sin1 - y3 * sin3(part of b3)
566
567    smull           v18.4s, v5.4h, v1.h[2] //// y2 * sin2 (q4 is freed by this time)(part of d1)
568    smull           v8.4s, v5.4h, v0.h[2] //// y2 * cos2(part of d0)
569
570    smull           v20.4s, v4.4h, v0.h[0] //// y0 * cos4(part of c0 and c1)
571    smull           v22.4s, v12.4h, v0.h[0] //// y4 * cos4(part of c0 and c1)
572
573    smlal           v24.4s, v16.4h, v1.h[1] //// y1 * cos1 + y3 * cos3 + y5 * sin3(part of b0)
574    smlsl           v26.4s, v16.4h, v0.h[1] //// y1 * cos3 - y3 * sin1 - y5 * cos1(part of b1)
575    smlal           v28.4s, v16.4h, v1.h[3] //// y1 * sin3 - y3 * cos1 + y5 * sin1(part of b2)
576    smlal           v30.4s, v16.4h, v0.h[3] //// y1 * sin1 - y3 * sin3 + y5 * cos3(part of b3)
577
578    smlsl           v18.4s, v13.4h, v0.h[2] //// d1 = y2 * sin2 - y6 * cos2(part of a0 and a1)
579    smlal           v8.4s, v13.4h, v1.h[2] //// d0 = y2 * cos2 + y6 * sin2(part of a0 and a1)
580
581    add             v12.4s, v20.4s , v22.4s //// c0 = y0 * cos4 + y4 * cos4(part of a0 and a1)
582    sub             v20.4s, v20.4s , v22.4s //// c1 = y0 * cos4 - y4 * cos4(part of a0 and a1)
583
584    smlal           v24.4s, v17.4h, v1.h[3] //// b0 = y1 * cos1 + y3 * cos3 + y5 * sin3 + y7 * sin1(part of e0,e7)
585    smlsl           v26.4s, v17.4h, v1.h[1] //// b1 = y1 * cos3 - y3 * sin1 - y5 * cos1 - y7 * sin3(part of e1,e6)
586    smlal           v28.4s, v17.4h, v0.h[3] //// b2 = y1 * sin3 - y3 * cos1 + y5 * sin1 + y7 * cos3(part of e2,e5)
587    smlsl           v30.4s, v17.4h, v0.h[1] //// b3 = y1 * sin1 - y3 * sin3 + y5 * cos3 - y7 * cos1(part of e3,e4)
588
589    add             v16.4s, v12.4s , v8.4s ////    a0 = c0 + d0(part of e0,e7)
590    sub             v12.4s, v12.4s , v8.4s //// a3 = c0 - d0(part of e3,e4)
591    sub             v22.4s, v20.4s , v18.4s //// a2 = c1 - d1(part of e2,e5)
592    add             v18.4s, v20.4s , v18.4s //// a1 = c1 + d1(part of e1,e6)
593
594    add             v20.4s, v16.4s , v24.4s //// a0 + b0(part of e0)
595    sub             v8.4s, v16.4s , v24.4s //// a0 - b0(part of e7)
596
597    add             v24.4s, v22.4s , v28.4s //// a2 + b2(part of e2)
598    sub             v22.4s, v22.4s , v28.4s //// a2 - b2(part of e5)
599
600    add             v28.4s, v18.4s , v26.4s //// a1 + b1(part of e1)
601    sub             v18.4s, v18.4s , v26.4s //// a1 - b1(part of e6)
602
603    add             v26.4s, v12.4s , v30.4s //// a3 + b3(part of e3)
604    sub             v30.4s, v12.4s , v30.4s //// a3 - b3(part of x4)
605
606    sqrshrn         v4.4h, v20.4s, #idct_stg1_shift //// x0 = (a0 + b0 + rnd) >> 7(IDCT_STG1_SHIFT)
607    sqrshrn         v17.4h, v8.4s, #idct_stg1_shift //// x7 = (a0 - b0 + rnd) >> 7(IDCT_STG1_SHIFT)
608    sqrshrn         v5.4h, v24.4s, #idct_stg1_shift //// x2 = (a2 + b2 + rnd) >> 7(IDCT_STG1_SHIFT)
609    sqrshrn         v16.4h, v22.4s, #idct_stg1_shift //// x5 = (a2 - b2 + rnd) >> 7(IDCT_STG1_SHIFT)
610    sqrshrn         v8.4h, v28.4s, #idct_stg1_shift //// x1 = (a1 + b1 + rnd) >> 7(IDCT_STG1_SHIFT)
611    sqrshrn         v13.4h, v18.4s, #idct_stg1_shift //// x6 = (a1 - b1 + rnd) >> 7(IDCT_STG1_SHIFT)
612    sqrshrn         v9.4h, v26.4s, #idct_stg1_shift //// x3 = (a3 + b3 + rnd) >> 7(IDCT_STG1_SHIFT)
613    sqrshrn         v12.4h, v30.4s, #idct_stg1_shift //// x4 = (a3 - b3 + rnd) >> 7(IDCT_STG1_SHIFT)
614    b               end_skip_last4cols
615
616
617
618skip_last4cols:
619    adrp            x14, :got:gai2_impeg2_idct_first_col_q11
620    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_first_col_q11]
621    ld1             {v0.4h, v1.4h}, [x14]
622
623    umov            x15, v25.d[0]
624
625    trn1            v25.4h, v2.4h, v6.4h
626    trn2            v29.4h, v2.4h, v6.4h ////[x3,x1],[x2,x0] first qudrant transposing
627
628    trn1            v27.4h, v3.4h, v7.4h
629    trn2            v31.4h, v3.4h, v7.4h ////[x3,x1],[x2,x0] first qudrant transposing
630
631    trn1            v6.2s, v29.2s, v31.2s
632    trn2            v7.2s, v29.2s, v31.2s ////x0,x1,x2,x3 first qudrant transposing continued.....
633    trn1            v2.2s, v25.2s, v27.2s
634    trn2            v3.2s, v25.2s, v27.2s ////x0,x1,x2,x3 first qudrant transposing continued.....
635
636
637    trn1            v25.4h, v10.4h, v14.4h
638    trn2            v29.4h, v10.4h, v14.4h ////[x7,x5],[x6,x4] third qudrant transposing
639
640    trn1            v27.4h, v11.4h, v15.4h
641    trn2            v31.4h, v11.4h, v15.4h ////[x7,x5],[x6,x4] third qudrant transposing
642
643    trn1            v10.2s, v25.2s, v27.2s
644    trn2            v11.2s, v25.2s, v27.2s ////x4,x5,x6,x7 third qudrant transposing continued.....
645    trn1            v14.2s, v29.2s, v31.2s
646    trn2            v15.2s, v29.2s, v31.2s ////x4,x5,x6,x7 third qudrant transposing continued.....
647
648    mov             v25.d[0], x15
649
650    smull           v24.4s, v6.4h, v0.h[1] //// y1 * cos1(part of b0)
651    smull           v26.4s, v6.4h, v0.h[3] //// y1 * cos3(part of b1)
652    smull           v28.4s, v6.4h, v1.h[1] //// y1 * sin3(part of b2)
653    smull           v30.4s, v6.4h, v1.h[3] //// y1 * sin1(part of b3)
654
655    smlal           v24.4s, v7.4h, v0.h[3] //// y1 * cos1 + y3 * cos3(part of b0)
656    smlsl           v26.4s, v7.4h, v1.h[3] //// y1 * cos3 - y3 * sin1(part of b1)
657    smlsl           v28.4s, v7.4h, v0.h[1] //// y1 * sin3 - y3 * cos1(part of b2)
658    smlsl           v30.4s, v7.4h, v1.h[1] //// y1 * sin1 - y3 * sin3(part of b3)
659
660    smull           v20.4s, v2.4h, v0.h[0] //// y0 * cos4(part of c0 and c1)
661//    vmull.s16    q11,d4,d0[0]                    @// y4 * cos4(part of c0 and c1)
662
663    smull           v18.4s, v3.4h, v1.h[2] //// y2 * sin2 (q3 is freed by this time)(part of d1)
664    smull           v6.4s, v3.4h, v0.h[2] //// y2 * cos2(part of d0)
665
666
667
668
669    sub             v22.4s, v20.4s , v6.4s //// a3 = c0 - d0(part of x3,x4)
670    add             v4.4s, v20.4s , v6.4s ////    a0 = c0 + d0(part of x0,x7)
671
672
673    add             v2.4s, v4.4s , v24.4s
674
675    sub             v6.4s, v4.4s , v24.4s
676
677    add             v8.4s, v22.4s , v30.4s
678
679    sub             v24.4s, v22.4s , v30.4s
680
681    sqrshrn         v5.4h, v8.4s, #idct_stg2_shift
682    sqrshrn         v2.4h, v2.4s, #idct_stg2_shift
683    sqrshrn         v9.4h, v6.4s, #idct_stg2_shift
684    sqrshrn         v6.4h, v24.4s, #idct_stg2_shift
685
686    sub             v22.4s, v20.4s , v18.4s //// a2 = c1 - d1(part of x2,x5)
687    add             v18.4s, v20.4s , v18.4s //// a1 = c1 + d1(part of x1,x6)
688
689
690    add             v30.4s, v22.4s , v28.4s
691
692    sub             v24.4s, v22.4s , v28.4s
693
694    add             v28.4s, v18.4s , v26.4s
695
696    sub             v22.4s, v18.4s , v26.4s
697    sqrshrn         v4.4h, v30.4s, #idct_stg2_shift
698    sqrshrn         v7.4h, v24.4s, #idct_stg2_shift
699    sqrshrn         v3.4h, v28.4s, #idct_stg2_shift
700    sqrshrn         v8.4h, v22.4s, #idct_stg2_shift
701
702
703
704    umov            x19, v25.d[0]
705    umov            x20, v25.d[1]
706
707    trn1            v27.4h, v2.4h, v3.4h
708    trn2            v29.4h, v2.4h, v3.4h
709    trn1            v25.4h, v4.4h, v5.4h
710    trn2            v31.4h, v4.4h, v5.4h
711
712    trn1            v2.2s, v27.2s, v25.2s
713    trn2            v4.2s, v27.2s, v25.2s
714    trn1            v3.2s, v29.2s, v31.2s
715    trn2            v5.2s, v29.2s, v31.2s
716
717    trn1            v27.4h, v6.4h, v7.4h
718    trn2            v29.4h, v6.4h, v7.4h
719    trn1            v25.4h, v8.4h, v9.4h
720    trn2            v31.4h, v8.4h, v9.4h
721
722    trn1            v6.2s, v27.2s, v25.2s
723    trn2            v8.2s, v27.2s, v25.2s
724    trn1            v7.2s, v29.2s, v31.2s
725    trn2            v9.2s, v29.2s, v31.2s
726
727    mov             v25.d[0], x19
728    mov             v25.d[1], x20
729
730    smull           v24.4s, v14.4h, v0.h[1] //// y1 * cos1(part of b0)
731
732    smull           v26.4s, v14.4h, v0.h[3] //// y1 * cos3(part of b1)
733    smull           v28.4s, v14.4h, v1.h[1] //// y1 * sin3(part of b2)
734    smull           v30.4s, v14.4h, v1.h[3] //// y1 * sin1(part of b3)
735
736    smlal           v24.4s, v15.4h, v0.h[3] //// y1 * cos1 + y3 * cos3(part of b0)
737    smlsl           v26.4s, v15.4h, v1.h[3] //// y1 * cos3 - y3 * sin1(part of b1)
738    smlsl           v28.4s, v15.4h, v0.h[1] //// y1 * sin3 - y3 * cos1(part of b2)
739    smlsl           v30.4s, v15.4h, v1.h[1] //// y1 * sin1 - y3 * sin3(part of b3)
740    smull           v20.4s, v10.4h, v0.h[0] //// y0 * cos4(part of c0 and c1)
741    smull           v18.4s, v11.4h, v1.h[2] //// y2 * sin2 (q7 is freed by this time)(part of d1)
742    smull           v14.4s, v11.4h, v0.h[2] //// y2 * cos2(part of d0)
743
744
745    add             x4, x2, x8, lsl #1  // x4 = x2 + pred_strd * 2    => x4 points to 3rd row of pred data
746
747
748    add             x5, x8, x8, lsl #1  //
749
750
751    add             x0, x3, x7, lsl #1  // x0 points to 3rd row of dest data
752
753
754    add             x10, x7, x7, lsl #1 //
755
756    // swapping v3 and v6
757    mov             v31.d[0], v3.d[0]
758    mov             v3.d[0], v6.d[0]
759    mov             v6.d[0], v31.d[0]
760
761    // swapping v5 and v8
762    mov             v31.d[0], v5.d[0]
763    mov             v5.d[0], v8.d[0]
764    mov             v8.d[0], v31.d[0]
765
766
767    sub             v22.4s, v20.4s , v14.4s //// a3 = c0 - d0(part of x3,x4)
768    add             v12.4s, v20.4s , v14.4s ////    a0 = c0 + d0(part of x0,x7)
769
770
771    add             v0.4s, v12.4s , v24.4s
772
773
774    sub             v24.4s, v12.4s , v24.4s
775
776
777    add             v12.4s, v22.4s , v30.4s
778
779
780    sub             v14.4s, v22.4s , v30.4s
781
782    sqrshrn         v10.4h, v0.4s, #idct_stg2_shift
783    sqrshrn         v17.4h, v24.4s, #idct_stg2_shift
784    sqrshrn         v13.4h, v12.4s, #idct_stg2_shift
785    sqrshrn         v14.4h, v14.4s, #idct_stg2_shift
786
787    sub             v22.4s, v20.4s , v18.4s //// a2 = c1 - d1(part of x2,x5)
788    add             v18.4s, v20.4s , v18.4s //// a1 = c1 + d1(part of x1,x6)
789
790
791    add             v0.4s, v22.4s , v28.4s
792
793
794    sub             v24.4s, v22.4s , v28.4s
795
796
797    add             v28.4s, v18.4s , v26.4s
798
799
800    sub             v26.4s, v18.4s , v26.4s
801    ld1             {v18.8b}, [x2], x8
802
803    sqrshrn         v12.4h, v0.4s, #idct_stg2_shift
804    ld1             {v20.8b}, [x2], x5
805
806
807    sqrshrn         v15.4h, v24.4s, #idct_stg2_shift
808    ld1             {v19.8b}, [x2], x8
809
810
811
812
813    sqrshrn         v11.4h, v28.4s, #idct_stg2_shift
814    ld1             {v22.8b}, [x4], x8
815
816
817
818
819    sqrshrn         v16.4h, v26.4s, #idct_stg2_shift
820    ld1             {v21.8b}, [x2], x5
821
822
823    b               pred_buff_addition
824end_skip_last4cols:
825    adrp            x14, :got:gai2_impeg2_idct_first_col_q11
826    ldr             x14, [x14, #:got_lo12:gai2_impeg2_idct_first_col_q11]
827    ld1             {v0.4h, v1.4h}, [x14]
828
829
830    umov            x19, v25.d[0]
831    umov            x20, v25.d[1]
832
833///* now the idct of columns is done, transpose so that row idct done efficiently(step5) */
834    trn1            v27.4h, v2.4h, v6.4h
835    trn2            v29.4h, v2.4h, v6.4h ////[x3,x1],[x2,x0] first qudrant transposing
836    trn1            v25.4h, v3.4h, v7.4h
837    trn2            v31.4h, v3.4h, v7.4h ////[x3,x1],[x2,x0] first qudrant transposing
838
839    trn1            v2.2s, v27.2s, v25.2s
840    trn2            v3.2s, v27.2s, v25.2s ////x0,x1,x2,x3 first qudrant transposing continued.....
841    trn1            v6.2s, v29.2s, v31.2s
842    trn2            v7.2s, v29.2s, v31.2s ////x0,x1,x2,x3 first qudrant transposing continued.....
843
844    trn1            v27.4h, v4.4h, v8.4h
845    trn2            v29.4h, v4.4h, v8.4h ////[x3,x1],[x2,x0] second qudrant transposing
846    trn1            v25.4h, v5.4h, v9.4h
847    trn2            v31.4h, v5.4h, v9.4h ////[x3,x1],[x2,x0] second qudrant transposing
848
849    trn1            v4.2s, v27.2s, v25.2s
850    trn2            v5.2s, v27.2s, v25.2s ////x0,x1,x2,x3 second qudrant transposing continued.....
851    trn1            v8.2s, v29.2s, v31.2s
852    trn2            v9.2s, v29.2s, v31.2s ////x0,x1,x2,x3 second qudrant transposing continued.....
853
854    trn1            v27.4h, v10.4h, v14.4h
855    trn2            v29.4h, v10.4h, v14.4h ////[x7,x5],[x6,x4] third qudrant transposing
856    trn1            v25.4h, v11.4h, v15.4h
857    trn2            v31.4h, v11.4h, v15.4h ////[x7,x5],[x6,x4] third qudrant transposing
858
859    trn1            v10.2s, v27.2s, v25.2s
860    trn2            v11.2s, v27.2s, v25.2s ////x4,x5,x6,x7 third qudrant transposing continued.....
861    trn1            v14.2s, v29.2s, v31.2s
862    trn2            v15.2s, v29.2s, v31.2s ////x4,x5,x6,x7 third qudrant transposing continued.....
863
864    trn1            v27.4h, v12.4h, v16.4h
865    trn2            v29.4h, v12.4h, v16.4h ////[x7,x5],[x6,x4] fourth qudrant transposing
866    trn1            v25.4h, v13.4h, v17.4h
867    trn2            v31.4h, v13.4h, v17.4h ////[x7,x5],[x6,x4] fourth qudrant transposing
868
869    trn1            v12.2s, v27.2s, v25.2s
870    trn2            v13.2s, v27.2s, v25.2s ////x4,x5,x6,x7 fourth qudrant transposing continued.....
871    trn1            v16.2s, v29.2s, v31.2s
872    trn2            v17.2s, v29.2s, v31.2s ////x4,x5,x6,x7 fourth qudrant transposing continued.....
873
874    mov             v25.d[0], x19
875    mov             v25.d[1], x20
876
877    ////step6 operate on first four rows and find their idct
878    ////register usage.extern        - storing and idct of rows
879////    cosine constants     -     d0
880////    sine constants         -     d1
881////    element 0 first four     -     d2        -    y0
882////    element 1 first four     -     d6        -    y1
883////    element 2 first four     -     d3        -    y2
884////    element 3 first four     -     d7        -    y3
885////    element 4 first four     -     d4        -    y4
886////    element 5 first four     -     d8        -    y5
887////    element 6 first four     -     d5        -    y6
888////    element 7 first four     -     d9        -    y7
889////    element 0 second four    -     d10        -    y0
890////    element 1 second four    -     d14     -    y1
891////    element 2 second four    -     d11     -    y2
892////    element 3 second four    -     d15     -    y3
893////    element 4 second four    -     d12     -    y4
894////    element 5 second four    -     d16     -    y5
895////    element 6 second four    -     d13     -    y6
896////    element 7 second four    -     d17     -    y7
897
898    //// map between first kernel code seq and current
899////        d2    ->    d2
900////        d6    ->    d6
901////        d3    ->    d3
902////        d7    ->    d7
903////        d10    ->    d4
904////        d14    ->    d8
905////        d11    ->    d5
906////        d15    ->    d9
907////        q3    ->    q3
908////        q5    ->    q2
909////        q7    ->    q4
910
911    smull           v24.4s, v6.4h, v0.h[1] //// y1 * cos1(part of b0)
912    smull           v26.4s, v6.4h, v0.h[3] //// y1 * cos3(part of b1)
913    smull           v28.4s, v6.4h, v1.h[1] //// y1 * sin3(part of b2)
914    smull           v30.4s, v6.4h, v1.h[3] //// y1 * sin1(part of b3)
915
916    smlal           v24.4s, v7.4h, v0.h[3] //// y1 * cos1 + y3 * cos3(part of b0)
917    smlsl           v26.4s, v7.4h, v1.h[3] //// y1 * cos3 - y3 * sin1(part of b1)
918    smlsl           v28.4s, v7.4h, v0.h[1] //// y1 * sin3 - y3 * cos1(part of b2)
919    smlsl           v30.4s, v7.4h, v1.h[1] //// y1 * sin1 - y3 * sin3(part of b3)
920
921    smull           v20.4s, v2.4h, v0.h[0] //// y0 * cos4(part of c0 and c1)
922    smull           v22.4s, v4.4h, v0.h[0] //// y4 * cos4(part of c0 and c1)
923
924    smull           v18.4s, v3.4h, v1.h[2] //// y2 * sin2 (q3 is freed by this time)(part of d1)
925    smull           v6.4s, v3.4h, v0.h[2] //// y2 * cos2(part of d0)
926
927
928    smlal           v24.4s, v8.4h, v1.h[1] //// y1 * cos1 + y3 * cos3 + y5 * sin3(part of b0)
929    smlsl           v26.4s, v8.4h, v0.h[1] //// y1 * cos3 - y3 * sin1 - y5 * cos1(part of b1)
930    smlal           v28.4s, v8.4h, v1.h[3] //// y1 * sin3 - y3 * cos1 + y5 * sin1(part of b2)
931    smlal           v30.4s, v8.4h, v0.h[3] //// y1 * sin1 - y3 * sin3 + y5 * cos3(part of b3)
932
933    smlsl           v18.4s, v5.4h, v0.h[2] //// d1 = y2 * sin2 - y6 * cos2(part of a0 and a1)
934    smlal           v6.4s, v5.4h, v1.h[2] //// d0 = y2 * cos2 + y6 * sin2(part of a0 and a1)
935
936    add             v2.4s, v20.4s , v22.4s //// c0 = y0 * cos4 + y4 * cos4(part of a0 and a1)
937    sub             v20.4s, v20.4s , v22.4s //// c1 = y0 * cos4 - y4 * cos4(part of a0 and a1)
938
939    smlal           v24.4s, v9.4h, v1.h[3] //// b0 = y1 * cos1 + y3 * cos3 + y5 * sin3 + y7 * sin1(part of x0,x7)
940    smlsl           v26.4s, v9.4h, v1.h[1] //// b1 = y1 * cos3 - y3 * sin1 - y5 * cos1 - y7 * sin3(part of x1,x6)
941    smlal           v28.4s, v9.4h, v0.h[3] //// b2 = y1 * sin3 - y3 * cos1 + y5 * sin1 + y7 * cos3(part of x2,x5)
942    smlsl           v30.4s, v9.4h, v0.h[1] //// b3 = y1 * sin1 - y3 * sin3 + y5 * cos3 - y7 * cos1(part of x3,x4)
943
944    sub             v22.4s, v2.4s , v6.4s //// a3 = c0 - d0(part of x3,x4)
945    add             v4.4s, v2.4s , v6.4s ////    a0 = c0 + d0(part of x0,x7)
946
947
948    add             v2.4s, v4.4s , v24.4s
949
950    sub             v6.4s, v4.4s , v24.4s
951
952    add             v8.4s, v22.4s , v30.4s
953
954    sub             v24.4s, v22.4s , v30.4s
955
956    sqrshrn         v5.4h, v8.4s, #idct_stg2_shift
957    sqrshrn         v2.4h, v2.4s, #idct_stg2_shift
958    sqrshrn         v9.4h, v6.4s, #idct_stg2_shift
959    sqrshrn         v6.4h, v24.4s, #idct_stg2_shift
960
961    sub             v22.4s, v20.4s , v18.4s //// a2 = c1 - d1(part of x2,x5)
962    add             v18.4s, v20.4s , v18.4s //// a1 = c1 + d1(part of x1,x6)
963
964
965    add             v30.4s, v22.4s , v28.4s
966
967    sub             v24.4s, v22.4s , v28.4s
968
969    add             v28.4s, v18.4s , v26.4s
970
971    sub             v22.4s, v18.4s , v26.4s
972    sqrshrn         v4.4h, v30.4s, #idct_stg2_shift
973    sqrshrn         v7.4h, v24.4s, #idct_stg2_shift
974    sqrshrn         v3.4h, v28.4s, #idct_stg2_shift
975    sqrshrn         v8.4h, v22.4s, #idct_stg2_shift
976
977
978
979    umov            x19, v25.d[0]
980    umov            x20, v25.d[1]
981
982    trn1            v27.4h, v2.4h, v3.4h
983    trn2            v29.4h, v2.4h, v3.4h
984    trn1            v25.4h, v4.4h, v5.4h
985    trn2            v31.4h, v4.4h, v5.4h
986
987    trn1            v2.2s, v27.2s, v25.2s
988    trn2            v4.2s, v27.2s, v25.2s
989    trn1            v3.2s, v29.2s, v31.2s
990    trn2            v5.2s, v29.2s, v31.2s
991
992    trn1            v27.4h, v6.4h, v7.4h
993    trn2            v29.4h, v6.4h, v7.4h
994    trn1            v25.4h, v8.4h, v9.4h
995    trn2            v31.4h, v8.4h, v9.4h
996
997    trn1            v6.2s, v27.2s, v25.2s
998    trn2            v8.2s, v27.2s, v25.2s
999    trn1            v7.2s, v29.2s, v31.2s
1000    trn2            v9.2s, v29.2s, v31.2s
1001
1002    mov             v25.d[0], x19
1003    mov             v25.d[1], x20
1004
1005
1006
1007    smull           v24.4s, v14.4h, v0.h[1] //// y1 * cos1(part of b0)
1008    smull           v26.4s, v14.4h, v0.h[3] //// y1 * cos3(part of b1)
1009    smull           v28.4s, v14.4h, v1.h[1] //// y1 * sin3(part of b2)
1010    smull           v30.4s, v14.4h, v1.h[3] //// y1 * sin1(part of b3)
1011    smlal           v24.4s, v15.4h, v0.h[3] //// y1 * cos1 + y3 * cos3(part of b0)
1012    smlsl           v26.4s, v15.4h, v1.h[3] //// y1 * cos3 - y3 * sin1(part of b1)
1013    smlsl           v28.4s, v15.4h, v0.h[1] //// y1 * sin3 - y3 * cos1(part of b2)
1014    smlsl           v30.4s, v15.4h, v1.h[1] //// y1 * sin1 - y3 * sin3(part of b3)
1015    smull           v20.4s, v10.4h, v0.h[0] //// y0 * cos4(part of c0 and c1)
1016    smull           v22.4s, v12.4h, v0.h[0] //// y4 * cos4(part of c0 and c1)
1017    smull           v18.4s, v11.4h, v1.h[2] //// y2 * sin2 (q7 is freed by this time)(part of d1)
1018    smull           v14.4s, v11.4h, v0.h[2] //// y2 * cos2(part of d0)
1019    smlal           v24.4s, v16.4h, v1.h[1] //// y1 * cos1 + y3 * cos3 + y5 * sin3(part of b0)
1020
1021    add             x4, x2, x8, lsl #1  // x4 = x2 + pred_strd * 2    => x4 points to 3rd row of pred data
1022    smlsl           v26.4s, v16.4h, v0.h[1] //// y1 * cos3 - y3 * sin1 - y5 * cos1(part of b1)
1023
1024    add             x5, x8, x8, lsl #1  //
1025    smlal           v28.4s, v16.4h, v1.h[3] //// y1 * sin3 - y3 * cos1 + y5 * sin1(part of b2)
1026
1027    add             x0, x3, x7, lsl #1  // x0 points to 3rd row of dest data
1028    smlal           v30.4s, v16.4h, v0.h[3] //// y1 * sin1 - y3 * sin3 + y5 * cos3(part of b3)
1029
1030    add             x10, x7, x7, lsl #1 //
1031    smlsl           v18.4s, v13.4h, v0.h[2] //// d1 = y2 * sin2 - y6 * cos2(part of a0 and a1)
1032
1033
1034    smlal           v14.4s, v13.4h, v1.h[2] //// d0 = y2 * cos2 + y6 * sin2(part of a0 and a1)
1035
1036    add             v12.4s, v20.4s , v22.4s //// c0 = y0 * cos4 + y4 * cos4(part of a0 and a1)
1037    sub             v20.4s, v20.4s , v22.4s //// c1 = y0 * cos4 - y4 * cos4(part of a0 and a1)
1038
1039    smlal           v24.4s, v17.4h, v1.h[3] //// b0 = y1 * cos1 + y3 * cos3 + y5 * sin3 + y7 * sin1(part of x0,x7)
1040
1041    // swapping v3 and v6
1042    mov             v31.d[0], v3.d[0]
1043    mov             v3.d[0], v6.d[0]
1044    mov             v6.d[0], v31.d[0]
1045
1046    smlsl           v26.4s, v17.4h, v1.h[1] //// b1 = y1 * cos3 - y3 * sin1 - y5 * cos1 - y7 * sin3(part of x1,x6)
1047    // swapping v5 and v8
1048    mov             v31.d[0], v5.d[0]
1049    mov             v5.d[0], v8.d[0]
1050    mov             v8.d[0], v31.d[0]
1051
1052    smlal           v28.4s, v17.4h, v0.h[3] //// b2 = y1 * sin3 - y3 * cos1 + y5 * sin1 + y7 * cos3(part of x2,x5)
1053    smlsl           v30.4s, v17.4h, v0.h[1] //// b3 = y1 * sin1 - y3 * sin3 + y5 * cos3 - y7 * cos1(part of x3,x4)
1054
1055    sub             v22.4s, v12.4s , v14.4s //// a3 = c0 - d0(part of x3,x4)
1056    add             v12.4s, v12.4s , v14.4s ////    a0 = c0 + d0(part of x0,x7)
1057
1058
1059    add             v0.4s, v12.4s , v24.4s
1060
1061
1062    sub             v24.4s, v12.4s , v24.4s
1063
1064
1065    add             v12.4s, v22.4s , v30.4s
1066
1067
1068    sub             v14.4s, v22.4s , v30.4s
1069
1070    sqrshrn         v10.4h, v0.4s, #idct_stg2_shift
1071    sqrshrn         v17.4h, v24.4s, #idct_stg2_shift
1072    sqrshrn         v13.4h, v12.4s, #idct_stg2_shift
1073    sqrshrn         v14.4h, v14.4s, #idct_stg2_shift
1074
1075    sub             v22.4s, v20.4s , v18.4s //// a2 = c1 - d1(part of x2,x5)
1076    add             v18.4s, v20.4s , v18.4s //// a1 = c1 + d1(part of x1,x6)
1077
1078
1079    add             v0.4s, v22.4s , v28.4s
1080
1081
1082    sub             v24.4s, v22.4s , v28.4s
1083
1084
1085    add             v28.4s, v18.4s , v26.4s
1086
1087
1088    sub             v26.4s, v18.4s , v26.4s
1089    ld1             {v18.8b}, [x2], x8
1090
1091    sqrshrn         v12.4h, v0.4s, #idct_stg2_shift
1092    ld1             {v20.8b}, [x2], x5
1093
1094
1095    sqrshrn         v15.4h, v24.4s, #idct_stg2_shift
1096    ld1             {v19.8b}, [x2], x8
1097
1098
1099
1100
1101    sqrshrn         v11.4h, v28.4s, #idct_stg2_shift
1102    ld1             {v22.8b}, [x4], x8
1103
1104
1105
1106
1107    sqrshrn         v16.4h, v26.4s, #idct_stg2_shift
1108    ld1             {v21.8b}, [x2], x5
1109
1110
1111
1112
1113pred_buff_addition:
1114
1115    umov            x19, v25.d[0]
1116    umov            x20, v25.d[1]
1117
1118    trn1            v27.4h, v10.4h, v11.4h
1119    trn2            v29.4h, v10.4h, v11.4h
1120    trn1            v25.4h, v12.4h, v13.4h
1121    trn2            v31.4h, v12.4h, v13.4h
1122
1123    trn1            v10.2s, v27.2s, v25.2s
1124    trn2            v12.2s, v27.2s, v25.2s
1125    trn1            v11.2s, v29.2s, v31.2s
1126    trn2            v13.2s, v29.2s, v31.2s
1127
1128    trn1            v27.4h, v14.4h, v15.4h
1129    trn2            v29.4h, v14.4h, v15.4h
1130    trn1            v25.4h, v16.4h, v17.4h
1131    trn2            v31.4h, v16.4h, v17.4h
1132
1133    trn1            v14.2s, v27.2s, v25.2s
1134    trn2            v16.2s, v27.2s, v25.2s
1135    trn1            v15.2s, v29.2s, v31.2s
1136    trn2            v17.2s, v29.2s, v31.2s
1137
1138
1139    mov             v25.d[0], x19
1140    mov             v25.d[1], x20
1141
1142
1143    ld1             {v24.8b}, [x4], x5
1144    ld1             {v23.8b}, [x4], x8
1145    ld1             {v25.8b}, [x4], x5
1146    mov             v2.d[1], v3.d[0]
1147    mov             v4.d[1], v5.d[0]
1148    mov             v6.d[1], v7.d[0]
1149    mov             v8.d[1], v9.d[0]
1150    uaddw           v2.8h, v2.8h , v18.8b
1151    uaddw           v4.8h, v4.8h , v22.8b
1152    uaddw           v6.8h, v6.8h , v20.8b
1153    uaddw           v8.8h, v8.8h , v24.8b
1154
1155    // swapping v11 and v14
1156    mov             v31.d[0], v11.d[0]
1157    mov             v11.d[0], v14.d[0]
1158    mov             v14.d[0], v31.d[0]
1159
1160    // swapping v13 and v16
1161    mov             v31.d[0], v13.d[0]
1162    mov             v13.d[0], v16.d[0]
1163    mov             v16.d[0], v31.d[0]
1164// row values stored in the q register.
1165
1166//q1 :x0
1167//q3: x1
1168//q2: x2
1169//q4: x3
1170//q5: x4
1171//q7: x5
1172//q6: x6
1173//q8: x7
1174
1175
1176
1177///// adding the prediction buffer
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187    // load prediction data
1188
1189
1190
1191
1192
1193    //adding recon with prediction
1194
1195
1196
1197
1198    mov             v10.d[1], v11.d[0]
1199    mov             v12.d[1], v13.d[0]
1200    mov             v14.d[1], v15.d[0]
1201    mov             v16.d[1], v17.d[0]
1202    uaddw           v10.8h, v10.8h , v19.8b
1203    sqxtun          v2.8b, v2.8h
1204    uaddw           v14.8h, v14.8h , v21.8b
1205    sqxtun          v4.8b, v4.8h
1206    uaddw           v12.8h, v12.8h , v23.8b
1207    sqxtun          v6.8b, v6.8h
1208    uaddw           v16.8h, v16.8h , v25.8b
1209    sqxtun          v8.8b, v8.8h
1210
1211
1212
1213
1214
1215
1216
1217    st1             {v2.8b}, [x3], x7
1218    sqxtun          v10.8b, v10.8h
1219    st1             {v6.8b}, [x3], x10
1220    sqxtun          v14.8b, v14.8h
1221    st1             {v4.8b}, [x0], x7
1222    sqxtun          v12.8b, v12.8h
1223    st1             {v8.8b}, [x0], x10
1224    sqxtun          v16.8b, v16.8h
1225
1226
1227
1228
1229
1230
1231
1232    st1             {v10.8b}, [x3], x7
1233    st1             {v14.8b}, [x3], x10
1234    st1             {v12.8b}, [x0], x7
1235    st1             {v16.8b}, [x0], x10
1236
1237
1238
1239
1240    // ldmfd sp!,{x4-x12,pc}
1241    ldp             x19, x20, [sp], #16
1242    pop_v_regs
1243    ret
1244
1245
1246
1247
1248