1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * inline assembly helper macros 3cabdff1aSopenharmony_ci * 4cabdff1aSopenharmony_ci * This file is part of FFmpeg. 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 7cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 8cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 9cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 10cabdff1aSopenharmony_ci * 11cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 12cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 13cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14cabdff1aSopenharmony_ci * Lesser General Public License for more details. 15cabdff1aSopenharmony_ci * 16cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 17cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 18cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 19cabdff1aSopenharmony_ci */ 20cabdff1aSopenharmony_ci 21cabdff1aSopenharmony_ci#ifndef AVCODEC_X86_INLINE_ASM_H 22cabdff1aSopenharmony_ci#define AVCODEC_X86_INLINE_ASM_H 23cabdff1aSopenharmony_ci 24cabdff1aSopenharmony_ci#include "constants.h" 25cabdff1aSopenharmony_ci 26cabdff1aSopenharmony_ci#define MOVQ_WONE(regd) \ 27cabdff1aSopenharmony_ci __asm__ volatile ( \ 28cabdff1aSopenharmony_ci "pcmpeqd %%" #regd ", %%" #regd " \n\t" \ 29cabdff1aSopenharmony_ci "psrlw $15, %%" #regd ::) 30cabdff1aSopenharmony_ci 31cabdff1aSopenharmony_ci#define JUMPALIGN() __asm__ volatile (".p2align 3"::) 32cabdff1aSopenharmony_ci#define MOVQ_ZERO(regd) __asm__ volatile ("pxor %%"#regd", %%"#regd ::) 33cabdff1aSopenharmony_ci 34cabdff1aSopenharmony_ci#define MOVQ_BFE(regd) \ 35cabdff1aSopenharmony_ci __asm__ volatile ( \ 36cabdff1aSopenharmony_ci "pcmpeqd %%"#regd", %%"#regd" \n\t" \ 37cabdff1aSopenharmony_ci "paddb %%"#regd", %%"#regd" \n\t" ::) 38cabdff1aSopenharmony_ci 39cabdff1aSopenharmony_ci#ifndef PIC 40cabdff1aSopenharmony_ci#define MOVQ_WTWO(regd) __asm__ volatile ("movq %0, %%"#regd" \n\t" :: "m"(ff_pw_2)) 41cabdff1aSopenharmony_ci#else 42cabdff1aSopenharmony_ci// for shared library it's better to use this way for accessing constants 43cabdff1aSopenharmony_ci// pcmpeqd -> -1 44cabdff1aSopenharmony_ci#define MOVQ_WTWO(regd) \ 45cabdff1aSopenharmony_ci __asm__ volatile ( \ 46cabdff1aSopenharmony_ci "pcmpeqd %%"#regd", %%"#regd" \n\t" \ 47cabdff1aSopenharmony_ci "psrlw $15, %%"#regd" \n\t" \ 48cabdff1aSopenharmony_ci "psllw $1, %%"#regd" \n\t"::) 49cabdff1aSopenharmony_ci 50cabdff1aSopenharmony_ci#endif 51cabdff1aSopenharmony_ci 52cabdff1aSopenharmony_ci// using regr as temporary and for the output result 53cabdff1aSopenharmony_ci// first argument is unmodified and second is trashed 54cabdff1aSopenharmony_ci// regfe is supposed to contain 0xfefefefefefefefe 55cabdff1aSopenharmony_ci#define PAVGB_MMX_NO_RND(rega, regb, regr, regfe) \ 56cabdff1aSopenharmony_ci "movq "#rega", "#regr" \n\t" \ 57cabdff1aSopenharmony_ci "pand "#regb", "#regr" \n\t" \ 58cabdff1aSopenharmony_ci "pxor "#rega", "#regb" \n\t" \ 59cabdff1aSopenharmony_ci "pand "#regfe", "#regb" \n\t" \ 60cabdff1aSopenharmony_ci "psrlq $1, "#regb" \n\t" \ 61cabdff1aSopenharmony_ci "paddb "#regb", "#regr" \n\t" 62cabdff1aSopenharmony_ci 63cabdff1aSopenharmony_ci#define PAVGB_MMX(rega, regb, regr, regfe) \ 64cabdff1aSopenharmony_ci "movq "#rega", "#regr" \n\t" \ 65cabdff1aSopenharmony_ci "por "#regb", "#regr" \n\t" \ 66cabdff1aSopenharmony_ci "pxor "#rega", "#regb" \n\t" \ 67cabdff1aSopenharmony_ci "pand "#regfe", "#regb" \n\t" \ 68cabdff1aSopenharmony_ci "psrlq $1, "#regb" \n\t" \ 69cabdff1aSopenharmony_ci "psubb "#regb", "#regr" \n\t" 70cabdff1aSopenharmony_ci 71cabdff1aSopenharmony_ci// mm6 is supposed to contain 0xfefefefefefefefe 72cabdff1aSopenharmony_ci#define PAVGBP_MMX_NO_RND(rega, regb, regr, regc, regd, regp) \ 73cabdff1aSopenharmony_ci "movq "#rega", "#regr" \n\t" \ 74cabdff1aSopenharmony_ci "movq "#regc", "#regp" \n\t" \ 75cabdff1aSopenharmony_ci "pand "#regb", "#regr" \n\t" \ 76cabdff1aSopenharmony_ci "pand "#regd", "#regp" \n\t" \ 77cabdff1aSopenharmony_ci "pxor "#rega", "#regb" \n\t" \ 78cabdff1aSopenharmony_ci "pxor "#regc", "#regd" \n\t" \ 79cabdff1aSopenharmony_ci "pand %%mm6, "#regb" \n\t" \ 80cabdff1aSopenharmony_ci "pand %%mm6, "#regd" \n\t" \ 81cabdff1aSopenharmony_ci "psrlq $1, "#regb" \n\t" \ 82cabdff1aSopenharmony_ci "psrlq $1, "#regd" \n\t" \ 83cabdff1aSopenharmony_ci "paddb "#regb", "#regr" \n\t" \ 84cabdff1aSopenharmony_ci "paddb "#regd", "#regp" \n\t" 85cabdff1aSopenharmony_ci 86cabdff1aSopenharmony_ci#define PAVGBP_MMX(rega, regb, regr, regc, regd, regp) \ 87cabdff1aSopenharmony_ci "movq "#rega", "#regr" \n\t" \ 88cabdff1aSopenharmony_ci "movq "#regc", "#regp" \n\t" \ 89cabdff1aSopenharmony_ci "por "#regb", "#regr" \n\t" \ 90cabdff1aSopenharmony_ci "por "#regd", "#regp" \n\t" \ 91cabdff1aSopenharmony_ci "pxor "#rega", "#regb" \n\t" \ 92cabdff1aSopenharmony_ci "pxor "#regc", "#regd" \n\t" \ 93cabdff1aSopenharmony_ci "pand %%mm6, "#regb" \n\t" \ 94cabdff1aSopenharmony_ci "pand %%mm6, "#regd" \n\t" \ 95cabdff1aSopenharmony_ci "psrlq $1, "#regd" \n\t" \ 96cabdff1aSopenharmony_ci "psrlq $1, "#regb" \n\t" \ 97cabdff1aSopenharmony_ci "psubb "#regb", "#regr" \n\t" \ 98cabdff1aSopenharmony_ci "psubb "#regd", "#regp" \n\t" 99cabdff1aSopenharmony_ci 100cabdff1aSopenharmony_ci#endif /* AVCODEC_X86_INLINE_ASM_H */ 101