110 lines
2.9 KiB
NASM
110 lines
2.9 KiB
NASM
|
;
|
||
|
; Copyright (c) 2015 The WebM project authors. All Rights Reserved.
|
||
|
;
|
||
|
; Use of this source code is governed by a BSD-style license
|
||
|
; that can be found in the LICENSE file in the root of the source
|
||
|
; tree. An additional intellectual property rights grant can be found
|
||
|
; in the file PATENTS. All contributing project authors may
|
||
|
; be found in the AUTHORS file in the root of the source tree.
|
||
|
;
|
||
|
|
||
|
%include "third_party/x86inc/x86inc.asm"
|
||
|
|
||
|
SECTION .text
|
||
|
|
||
|
%macro REORDER_INPUTS 0
|
||
|
; a c d b to a b c d
|
||
|
SWAP 1, 3, 2
|
||
|
%endmacro
|
||
|
|
||
|
%macro TRANSFORM_COLS 0
|
||
|
; input:
|
||
|
; m0 a
|
||
|
; m1 b
|
||
|
; m2 c
|
||
|
; m3 d
|
||
|
paddw m0, m2
|
||
|
psubw m3, m1
|
||
|
|
||
|
; wide subtract
|
||
|
punpcklwd m4, m0
|
||
|
punpcklwd m5, m3
|
||
|
psrad m4, 16
|
||
|
psrad m5, 16
|
||
|
psubd m4, m5
|
||
|
psrad m4, 1
|
||
|
packssdw m4, m4 ; e
|
||
|
|
||
|
psubw m5, m4, m1 ; b
|
||
|
psubw m4, m2 ; c
|
||
|
psubw m0, m5
|
||
|
paddw m3, m4
|
||
|
; m0 a
|
||
|
SWAP 1, 5 ; m1 b
|
||
|
SWAP 2, 4 ; m2 c
|
||
|
; m3 d
|
||
|
%endmacro
|
||
|
|
||
|
%macro TRANSPOSE_4X4 0
|
||
|
punpcklwd m0, m2
|
||
|
punpcklwd m1, m3
|
||
|
mova m2, m0
|
||
|
punpcklwd m0, m1
|
||
|
punpckhwd m2, m1
|
||
|
pshufd m1, m0, 0x0e
|
||
|
pshufd m3, m2, 0x0e
|
||
|
%endmacro
|
||
|
|
||
|
; transpose a 4x4 int16 matrix in xmm0 and xmm1 to the bottom half of xmm0-xmm3
|
||
|
%macro TRANSPOSE_4X4_WIDE 0
|
||
|
mova m3, m0
|
||
|
punpcklwd m0, m1
|
||
|
punpckhwd m3, m1
|
||
|
mova m2, m0
|
||
|
punpcklwd m0, m3
|
||
|
punpckhwd m2, m3
|
||
|
pshufd m1, m0, 0x0e
|
||
|
pshufd m3, m2, 0x0e
|
||
|
%endmacro
|
||
|
|
||
|
%macro ADD_STORE_4P_2X 5 ; src1, src2, tmp1, tmp2, zero
|
||
|
movd m%3, [outputq]
|
||
|
movd m%4, [outputq + strideq]
|
||
|
punpcklbw m%3, m%5
|
||
|
punpcklbw m%4, m%5
|
||
|
paddw m%1, m%3
|
||
|
paddw m%2, m%4
|
||
|
packuswb m%1, m%5
|
||
|
packuswb m%2, m%5
|
||
|
movd [outputq], m%1
|
||
|
movd [outputq + strideq], m%2
|
||
|
%endmacro
|
||
|
|
||
|
INIT_XMM sse2
|
||
|
cglobal iwht4x4_16_add, 3, 3, 7, input, output, stride
|
||
|
%if CONFIG_VP9_HIGHBITDEPTH
|
||
|
mova m0, [inputq + 0]
|
||
|
packssdw m0, [inputq + 16]
|
||
|
mova m1, [inputq + 32]
|
||
|
packssdw m1, [inputq + 48]
|
||
|
%else
|
||
|
mova m0, [inputq + 0]
|
||
|
mova m1, [inputq + 16]
|
||
|
%endif
|
||
|
psraw m0, 2
|
||
|
psraw m1, 2
|
||
|
|
||
|
TRANSPOSE_4X4_WIDE
|
||
|
REORDER_INPUTS
|
||
|
TRANSFORM_COLS
|
||
|
TRANSPOSE_4X4
|
||
|
REORDER_INPUTS
|
||
|
TRANSFORM_COLS
|
||
|
|
||
|
pxor m4, m4
|
||
|
ADD_STORE_4P_2X 0, 1, 5, 6, 4
|
||
|
lea outputq, [outputq + 2 * strideq]
|
||
|
ADD_STORE_4P_2X 2, 3, 5, 6, 4
|
||
|
|
||
|
RET
|