(commit by michael)
draw_edges_mmx() Originally committed as revision 266 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
4973971e37
commit
3d9fccbf0f
@ -24,6 +24,7 @@
|
|||||||
#include "../mpegvideo.h"
|
#include "../mpegvideo.h"
|
||||||
|
|
||||||
extern UINT8 zigzag_end[64];
|
extern UINT8 zigzag_end[64];
|
||||||
|
extern void (*draw_edges)(UINT8 *buf, int wrap, int width, int height, int w);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
|
||||||
@ -322,6 +323,95 @@ asm volatile(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* draw the edges of width 'w' of an image of size width, height
|
||||||
|
this mmx version can only handle w==8 || w==16 */
|
||||||
|
static void draw_edges_mmx(UINT8 *buf, int wrap, int width, int height, int w)
|
||||||
|
{
|
||||||
|
UINT8 *ptr, *last_line;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
last_line = buf + (height - 1) * wrap;
|
||||||
|
/* left and right */
|
||||||
|
ptr = buf;
|
||||||
|
if(w==8)
|
||||||
|
{
|
||||||
|
asm volatile(
|
||||||
|
"1: \n\t"
|
||||||
|
"movd (%0), %%mm0 \n\t"
|
||||||
|
"punpcklbw %%mm0, %%mm0 \n\t"
|
||||||
|
"punpcklwd %%mm0, %%mm0 \n\t"
|
||||||
|
"punpckldq %%mm0, %%mm0 \n\t"
|
||||||
|
"movq %%mm0, -8(%0) \n\t"
|
||||||
|
"movq -8(%0, %2), %%mm1 \n\t"
|
||||||
|
"punpckhbw %%mm1, %%mm1 \n\t"
|
||||||
|
"punpckhwd %%mm1, %%mm1 \n\t"
|
||||||
|
"punpckhdq %%mm1, %%mm1 \n\t"
|
||||||
|
"movq %%mm1, (%0, %2) \n\t"
|
||||||
|
"addl %1, %0 \n\t"
|
||||||
|
"cmpl %3, %0 \n\t"
|
||||||
|
" jb 1b \n\t"
|
||||||
|
: "+r" (ptr)
|
||||||
|
: "r" (wrap), "r" (width), "r" (ptr + wrap*height)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
asm volatile(
|
||||||
|
"1: \n\t"
|
||||||
|
"movd (%0), %%mm0 \n\t"
|
||||||
|
"punpcklbw %%mm0, %%mm0 \n\t"
|
||||||
|
"punpcklwd %%mm0, %%mm0 \n\t"
|
||||||
|
"punpckldq %%mm0, %%mm0 \n\t"
|
||||||
|
"movq %%mm0, -8(%0) \n\t"
|
||||||
|
"movq %%mm0, -16(%0) \n\t"
|
||||||
|
"movq -8(%0, %2), %%mm1 \n\t"
|
||||||
|
"punpckhbw %%mm1, %%mm1 \n\t"
|
||||||
|
"punpckhwd %%mm1, %%mm1 \n\t"
|
||||||
|
"punpckhdq %%mm1, %%mm1 \n\t"
|
||||||
|
"movq %%mm1, (%0, %2) \n\t"
|
||||||
|
"movq %%mm1, 8(%0, %2) \n\t"
|
||||||
|
"addl %1, %0 \n\t"
|
||||||
|
"cmpl %3, %0 \n\t"
|
||||||
|
" jb 1b \n\t"
|
||||||
|
: "+r" (ptr)
|
||||||
|
: "r" (wrap), "r" (width), "r" (ptr + wrap*height)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i=0;i<w;i+=4) {
|
||||||
|
/* top and bottom (and hopefully also the corners) */
|
||||||
|
ptr= buf - (i + 1) * wrap - w;
|
||||||
|
asm volatile(
|
||||||
|
"1: \n\t"
|
||||||
|
"movq (%1, %0), %%mm0 \n\t"
|
||||||
|
"movq %%mm0, (%0) \n\t"
|
||||||
|
"movq %%mm0, (%0, %2) \n\t"
|
||||||
|
"movq %%mm0, (%0, %2, 2) \n\t"
|
||||||
|
"movq %%mm0, (%0, %3) \n\t"
|
||||||
|
"addl $8, %0 \n\t"
|
||||||
|
"cmpl %4, %0 \n\t"
|
||||||
|
" jb 1b \n\t"
|
||||||
|
: "+r" (ptr)
|
||||||
|
: "r" ((int)buf - (int)ptr - w), "r" (-wrap), "r" (-wrap*3), "r" (ptr+width+2*w)
|
||||||
|
);
|
||||||
|
ptr= last_line + (i + 1) * wrap - w;
|
||||||
|
asm volatile(
|
||||||
|
"1: \n\t"
|
||||||
|
"movq (%1, %0), %%mm0 \n\t"
|
||||||
|
"movq %%mm0, (%0) \n\t"
|
||||||
|
"movq %%mm0, (%0, %2) \n\t"
|
||||||
|
"movq %%mm0, (%0, %2, 2) \n\t"
|
||||||
|
"movq %%mm0, (%0, %3) \n\t"
|
||||||
|
"addl $8, %0 \n\t"
|
||||||
|
"cmpl %4, %0 \n\t"
|
||||||
|
" jb 1b \n\t"
|
||||||
|
: "+r" (ptr)
|
||||||
|
: "r" ((int)last_line - (int)ptr - w), "r" (wrap), "r" (wrap*3), "r" (ptr+width+2*w)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void MPV_common_init_mmx(MpegEncContext *s)
|
void MPV_common_init_mmx(MpegEncContext *s)
|
||||||
{
|
{
|
||||||
if (mm_flags & MM_MMX) {
|
if (mm_flags & MM_MMX) {
|
||||||
@ -329,5 +419,7 @@ void MPV_common_init_mmx(MpegEncContext *s)
|
|||||||
s->dct_unquantize = dct_unquantize_h263_mmx;
|
s->dct_unquantize = dct_unquantize_h263_mmx;
|
||||||
else
|
else
|
||||||
s->dct_unquantize = dct_unquantize_mpeg1_mmx;
|
s->dct_unquantize = dct_unquantize_mpeg1_mmx;
|
||||||
|
|
||||||
|
draw_edges = draw_edges_mmx;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,6 +39,10 @@ static int dct_quantize(MpegEncContext *s, DCTELEM *block, int n, int qscale);
|
|||||||
static int dct_quantize_mmx(MpegEncContext *s,
|
static int dct_quantize_mmx(MpegEncContext *s,
|
||||||
DCTELEM *block, int n,
|
DCTELEM *block, int n,
|
||||||
int qscale);
|
int qscale);
|
||||||
|
static void draw_edges_c(UINT8 *buf, int wrap, int width, int height, int w);
|
||||||
|
|
||||||
|
void (*draw_edges)(UINT8 *buf, int wrap, int width, int height, int w)= draw_edges_c;
|
||||||
|
|
||||||
#define EDGE_WIDTH 16
|
#define EDGE_WIDTH 16
|
||||||
|
|
||||||
/* enable all paranoid tests for rounding, overflows, etc... */
|
/* enable all paranoid tests for rounding, overflows, etc... */
|
||||||
@ -361,7 +365,7 @@ int MPV_encode_end(AVCodecContext *avctx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* draw the edges of width 'w' of an image of size width, height */
|
/* draw the edges of width 'w' of an image of size width, height */
|
||||||
static void draw_edges(UINT8 *buf, int wrap, int width, int height, int w)
|
static void draw_edges_c(UINT8 *buf, int wrap, int width, int height, int w)
|
||||||
{
|
{
|
||||||
UINT8 *ptr, *last_line;
|
UINT8 *ptr, *last_line;
|
||||||
int i;
|
int i;
|
||||||
@ -676,7 +680,7 @@ static inline void add_dct(MpegEncContext *s,
|
|||||||
{
|
{
|
||||||
if (s->block_last_index[i] >= 0) {
|
if (s->block_last_index[i] >= 0) {
|
||||||
if (!s->mpeg2)
|
if (!s->mpeg2)
|
||||||
if(s->encoding || s->avctx==NULL || s->avctx->codec->id!=CODEC_ID_MSMPEG4)
|
if(s->encoding || (!s->h263_msmpeg4))
|
||||||
s->dct_unquantize(s, block, i, s->qscale);
|
s->dct_unquantize(s, block, i, s->qscale);
|
||||||
ff_idct (block);
|
ff_idct (block);
|
||||||
add_pixels_clamped(block, dest, line_size);
|
add_pixels_clamped(block, dest, line_size);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user