⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 deblock-a.asm

📁 从服务器上下的x264编码器C源码……希望对大家有帮助……这个是09年4月的
💻 ASM
📖 第 1 页 / 共 2 页
字号:
;*****************************************************************************;* deblock-a.asm: h264 encoder library;*****************************************************************************;* Copyright (C) 2005-2008 x264 project;*;* Authors: Loren Merritt <lorenm@u.washington.edu>;*;* This program is free software; you can redistribute it and/or modify;* it under the terms of the GNU General Public License as published by;* the Free Software Foundation; either version 2 of the License, or;* (at your option) any later version.;*;* This program is distributed in the hope that it will be useful,;* but WITHOUT ANY WARRANTY; without even the implied warranty of;* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the;* GNU General Public License for more details.;*;* You should have received a copy of the GNU General Public License;* along with this program; if not, write to the Free Software;* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111, USA.;*****************************************************************************%include "x86inc.asm"SECTION_RODATApb_00: times 16 db 0x00pb_01: times 16 db 0x01pb_03: times 16 db 0x03pb_a1: times 16 db 0xa1SECTION .text; expands to [base],...,[base+7*stride]%define PASS8ROWS(base, base3, stride, stride3) \    [base], [base+stride], [base+stride*2], [base3], \    [base3+stride], [base3+stride*2], [base3+stride3], [base3+stride*4]; in: 8 rows of 4 bytes in %1..%8; out: 4 rows of 8 bytes in m0..m3%macro TRANSPOSE4x8_LOAD 8    movd       m0, %1    movd       m2, %2    movd       m1, %3    movd       m3, %4    punpcklbw  m0, m2    punpcklbw  m1, m3    movq       m2, m0    punpcklwd  m0, m1    punpckhwd  m2, m1    movd       m4, %5    movd       m6, %6    movd       m5, %7    movd       m7, %8    punpcklbw  m4, m6    punpcklbw  m5, m7    movq       m6, m4    punpcklwd  m4, m5    punpckhwd  m6, m5    movq       m1, m0    movq       m3, m2    punpckldq  m0, m4    punpckhdq  m1, m4    punpckldq  m2, m6    punpckhdq  m3, m6%endmacro; in: 4 rows of 8 bytes in m0..m3; out: 8 rows of 4 bytes in %1..%8%macro TRANSPOSE8x4_STORE 8    movq       m4, m0    movq       m5, m1    movq       m6, m2    punpckhdq  m4, m4    punpckhdq  m5, m5    punpckhdq  m6, m6    punpcklbw  m0, m1    punpcklbw  m2, m3    movq       m1, m0    punpcklwd  m0, m2    punpckhwd  m1, m2    movd       %1, m0    punpckhdq  m0, m0    movd       %2, m0    movd       %3, m1    punpckhdq  m1, m1    movd       %4, m1    punpckhdq  m3, m3    punpcklbw  m4, m5    punpcklbw  m6, m3    movq       m5, m4    punpcklwd  m4, m6    punpckhwd  m5, m6    movd       %5, m4    punpckhdq  m4, m4    movd       %6, m4    movd       %7, m5    punpckhdq  m5, m5    movd       %8, m5%endmacro%macro SBUTTERFLY 4    movq       %4, %2    punpckl%1  %2, %3    punpckh%1  %4, %3%endmacro; in: 8 rows of 8 (only the middle 6 pels are used) in %1..%8; out: 6 rows of 8 in [%9+0*16] .. [%9+5*16]%macro TRANSPOSE6x8_MEM 9    movq  m0, %1    movq  m1, %2    movq  m2, %3    movq  m3, %4    movq  m4, %5    movq  m5, %6    movq  m6, %7    SBUTTERFLY bw, m0, m1, m7    SBUTTERFLY bw, m2, m3, m1    SBUTTERFLY bw, m4, m5, m3    movq  [%9+0x10], m1    SBUTTERFLY bw, m6, %8, m5    SBUTTERFLY wd, m0, m2, m1    SBUTTERFLY wd, m4, m6, m2    punpckhdq m0, m4    movq  [%9+0x00], m0    SBUTTERFLY wd, m7, [%9+0x10], m6    SBUTTERFLY wd, m3, m5, m4    SBUTTERFLY dq, m7, m3, m0    SBUTTERFLY dq, m1, m2, m5    punpckldq m6, m4    movq  [%9+0x10], m1    movq  [%9+0x20], m5    movq  [%9+0x30], m7    movq  [%9+0x40], m0    movq  [%9+0x50], m6%endmacro; in: 8 rows of 8 in %1..%8; out: 8 rows of 8 in %9..%16%macro TRANSPOSE8x8_MEM 16    movq  m0, %1    movq  m1, %2    movq  m2, %3    movq  m3, %4    movq  m4, %5    movq  m5, %6    movq  m6, %7    SBUTTERFLY bw, m0, m1, m7    SBUTTERFLY bw, m2, m3, m1    SBUTTERFLY bw, m4, m5, m3    SBUTTERFLY bw, m6, %8, m5    movq  %9,  m3    SBUTTERFLY wd, m0, m2, m3    SBUTTERFLY wd, m4, m6, m2    SBUTTERFLY wd, m7, m1, m6    movq  %11, m2    movq  m2,  %9    SBUTTERFLY wd, m2, m5, m1    SBUTTERFLY dq, m0, m4, m5    SBUTTERFLY dq, m7, m2, m4    movq  %9,  m0    movq  %10, m5    movq  %13, m7    movq  %14, m4    SBUTTERFLY dq, m3, %11, m0    SBUTTERFLY dq, m6, m1, m5    movq  %11, m3    movq  %12, m0    movq  %15, m6    movq  %16, m5%endmacro; out: %4 = |%1-%2|>%3; clobbers: %5%macro DIFF_GT 5    mova    %5, %2    mova    %4, %1    psubusb %5, %1    psubusb %4, %2    por     %4, %5    psubusb %4, %3%endmacro; out: %4 = |%1-%2|>%3; clobbers: %5%macro DIFF_GT2 5    mova    %5, %2    mova    %4, %1    psubusb %5, %1    psubusb %4, %2    psubusb %5, %3    psubusb %4, %3    pcmpeqb %4, %5%endmacro%macro SPLATW 1%ifidn m0, xmm0    pshuflw  %1, %1, 0    punpcklqdq %1, %1%else    pshufw   %1, %1, 0%endif%endmacro; in: m0=p1 m1=p0 m2=q0 m3=q1 %1=alpha-1 %2=beta-1; out: m5=beta-1, m7=mask, %3=alpha-1; clobbers: m4,m6%macro LOAD_MASK 2-3    movd     m4, %1    movd     m5, %2    SPLATW   m4    SPLATW   m5    packuswb m4, m4  ; 16x alpha-1    packuswb m5, m5  ; 16x beta-1%if %0>2    mova     %3, m4%endif    DIFF_GT  m1, m2, m4, m7, m6 ; |p0-q0| > alpha-1    DIFF_GT  m0, m1, m5, m4, m6 ; |p1-p0| > beta-1    por      m7, m4    DIFF_GT  m3, m2, m5, m4, m6 ; |q1-q0| > beta-1    por      m7, m4    pxor     m6, m6    pcmpeqb  m7, m6%endmacro; in: m0=p1 m1=p0 m2=q0 m3=q1 m7=(tc&mask); out: m1=p0' m2=q0'; clobbers: m0,3-6%macro DEBLOCK_P0_Q0 0    mova    m5, m1    pxor    m5, m2           ; p0^q0    pand    m5, [pb_01 GLOBAL] ; (p0^q0)&1    pcmpeqb m4, m4    pxor    m3, m4    pavgb   m3, m0           ; (p1 - q1 + 256)>>1    pavgb   m3, [pb_03 GLOBAL] ; (((p1 - q1 + 256)>>1)+4)>>1 = 64+2+(p1-q1)>>2    pxor    m4, m1    pavgb   m4, m2           ; (q0 - p0 + 256)>>1    pavgb   m3, m5    paddusb m3, m4           ; d+128+33    mova    m6, [pb_a1 GLOBAL]    psubusb m6, m3    psubusb m3, [pb_a1 GLOBAL]    pminub  m6, m7    pminub  m3, m7    psubusb m1, m6    psubusb m2, m3    paddusb m1, m3    paddusb m2, m6%endmacro; in: m1=p0 m2=q0;     %1=p1 %2=q2 %3=[q2] %4=[q1] %5=tc0 %6=tmp; out: [q1] = clip( (q2+((p0+q0+1)>>1))>>1, q1-tc0, q1+tc0 ); clobbers: q2, tmp, tc0%macro LUMA_Q1 6    mova    %6, m1    pavgb   %6, m2    pavgb   %2, %6             ; avg(p2,avg(p0,q0))    pxor    %6, %3    pand    %6, [pb_01 GLOBAL] ; (p2^avg(p0,q0))&1    psubusb %2, %6             ; (p2+((p0+q0+1)>>1))>>1    mova    %6, %1    psubusb %6, %5    paddusb %5, %1    pmaxub  %2, %6    pminub  %2, %5    mova    %4, %2%endmacro%ifdef ARCH_X86_64;-----------------------------------------------------------------------------; void x264_deblock_v_luma_sse2( uint8_t *pix, int stride, int alpha, int beta, int8_t *tc0 );-----------------------------------------------------------------------------INIT_XMMcglobal x264_deblock_v_luma_sse2, 5,5,10    movd    m8, [r4] ; tc0    lea     r4, [r1*3]    dec     r2d        ; alpha-1    neg     r4    dec     r3d        ; beta-1    add     r4, r0     ; pix-3*stride    mova    m0, [r4+r1]   ; p1    mova    m1, [r4+2*r1] ; p0    mova    m2, [r0]      ; q0    mova    m3, [r0+r1]   ; q1    LOAD_MASK r2d, r3d    punpcklbw m8, m8    punpcklbw m8, m8 ; tc = 4x tc0[3], 4x tc0[2], 4x tc0[1], 4x tc0[0]    pcmpeqb m9, m9    pcmpeqb m9, m8    pandn   m9, m7    pand    m8, m9    movdqa  m3, [r4] ; p2    DIFF_GT2 m1, m3, m5, m6, m7 ; |p2-p0| > beta-1    pand    m6, m9    mova    m7, m8    psubb   m7, m6    pand    m6, m8    LUMA_Q1 m0, m3, [r4], [r4+r1], m6, m4    movdqa  m4, [r0+2*r1] ; q2    DIFF_GT2 m2, m4, m5, m6, m3 ; |q2-q0| > beta-1    pand    m6, m9    pand    m8, m6    psubb   m7, m6    mova    m3, [r0+r1]    LUMA_Q1 m3, m4, [r0+2*r1], [r0+r1], m8, m6    DEBLOCK_P0_Q0    mova    [r4+2*r1], m1    mova    [r0], m2    RET;-----------------------------------------------------------------------------; void x264_deblock_h_luma_sse2( uint8_t *pix, int stride, int alpha, int beta, int8_t *tc0 );-----------------------------------------------------------------------------INIT_MMXcglobal x264_deblock_h_luma_sse2, 5,7    movsxd r10, r1d    lea    r11, [r10+r10*2]    lea    r6,  [r0-4]    lea    r5,  [r0-4+r11]%ifdef WIN64    sub    rsp, 0x98    %define pix_tmp rsp+0x30%else    sub    rsp, 0x68    %define pix_tmp rsp%endif    ; transpose 6x16 -> tmp space    TRANSPOSE6x8_MEM  PASS8ROWS(r6, r5, r10, r11), pix_tmp    lea    r6, [r6+r10*8]    lea    r5, [r5+r10*8]    TRANSPOSE6x8_MEM  PASS8ROWS(r6, r5, r10, r11), pix_tmp+8    ; vertical filter    ; alpha, beta, tc0 are still in r2d, r3d, r4    ; don't backup r6, r5, r10, r11 because x264_deblock_v_luma_sse2 doesn't use them    lea    r0, [pix_tmp+0x30]    mov    r1d, 0x10%ifdef WIN64    mov    [rsp+0x20], r4%endif    call   x264_deblock_v_luma_sse2    ; transpose 16x4 -> original space  (only the middle 4 rows were changed by the filter)    add    r6, 2    add    r5, 2    movq   m0, [pix_tmp+0x18]    movq   m1, [pix_tmp+0x28]    movq   m2, [pix_tmp+0x38]    movq   m3, [pix_tmp+0x48]    TRANSPOSE8x4_STORE  PASS8ROWS(r6, r5, r10, r11)    shl    r10, 3    sub    r6,  r10    sub    r5,  r10    shr    r10, 3    movq   m0, [pix_tmp+0x10]    movq   m1, [pix_tmp+0x20]    movq   m2, [pix_tmp+0x30]    movq   m3, [pix_tmp+0x40]    TRANSPOSE8x4_STORE  PASS8ROWS(r6, r5, r10, r11)%ifdef WIN64    add    rsp, 0x98%else    add    rsp, 0x68%endif    RET%else%macro DEBLOCK_LUMA 3;-----------------------------------------------------------------------------; void x264_deblock_v8_luma_mmxext( uint8_t *pix, int stride, int alpha, int beta, int8_t *tc0 );-----------------------------------------------------------------------------cglobal x264_deblock_%2_luma_%1, 5,5    lea     r4, [r1*3]    dec     r2     ; alpha-1    neg     r4    dec     r3     ; beta-1    add     r4, r0 ; pix-3*stride    %assign pad 2*%3+12-(stack_offset&15)    SUB     esp, pad    mova    m0, [r4+r1]   ; p1    mova    m1, [r4+2*r1] ; p0    mova    m2, [r0]      ; q0    mova    m3, [r0+r1]   ; q1    LOAD_MASK r2, r3    mov     r3, r4mp    movd    m4, [r3] ; tc0    punpcklbw m4, m4    punpcklbw m4, m4 ; tc = 4x tc0[3], 4x tc0[2], 4x tc0[1], 4x tc0[0]    mova   [esp+%3], m4 ; tc    pcmpeqb m3, m3    pcmpgtb m4, m3    pand    m4, m7    mova   [esp], m4 ; mask    mova    m3, [r4] ; p2    DIFF_GT2 m1, m3, m5, m6, m7 ; |p2-p0| > beta-1    pand    m6, m4    pand    m4, [esp+%3] ; tc    mova    m7, m4    psubb   m7, m6    pand    m6, m4    LUMA_Q1 m0, m3, [r4], [r4+r1], m6, m4    mova    m4, [r0+2*r1] ; q2    DIFF_GT2 m2, m4, m5, m6, m3 ; |q2-q0| > beta-1    mova    m5, [esp] ; mask    pand    m6, m5    mova    m5, [esp+%3] ; tc    pand    m5, m6    psubb   m7, m6    mova    m3, [r0+r1]    LUMA_Q1 m3, m4, [r0+2*r1], [r0+r1], m5, m6    DEBLOCK_P0_Q0    mova    [r4+2*r1], m1    mova    [r0], m2    ADD     esp, pad    RET;-----------------------------------------------------------------------------; void x264_deblock_h_luma_mmxext( uint8_t *pix, int stride, int alpha, int beta, int8_t *tc0 );-----------------------------------------------------------------------------INIT_MMXcglobal x264_deblock_h_luma_%1, 0,5    mov    r0, r0mp

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -