mpeg2/mpeg4 dequantizer support (c & mmx)

mpeg1 dequantizer optimizations

Originally committed as revision 404 to svn://svn.ffmpeg.org/ffmpeg/trunk
pull/126/head
Michael Niedermayer 23 years ago
parent 9dbcbd92e8
commit 9dbf1dddbd
  1. 2
      libavcodec/h263.c
  2. 288
      libavcodec/i386/mpegvideo_mmx.c
  3. 72
      libavcodec/mpegvideo.c
  4. 4
      libavcodec/mpegvideo.h

@ -2669,7 +2669,7 @@ int mpeg4_decode_picture_header(MpegEncContext * s)
} }
} }
s->dct_unquantize= s->dct_unquantize_mpeg; s->dct_unquantize= s->dct_unquantize_mpeg2;
// FIXME a bunch of grayscale shape things // FIXME a bunch of grayscale shape things
}else }else

@ -17,7 +17,7 @@
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
* *
* Optimized for ia32 cpus by Nick Kurshev <nickols_k@mail.ru> * Optimized for ia32 cpus by Nick Kurshev <nickols_k@mail.ru>
* h263 dequantizer by Michael Niedermayer <michaelni@gmx.at> * h263, mpeg1, mpeg2 dequantizer & draw_edges by Michael Niedermayer <michaelni@gmx.at>
*/ */
#include "../dsputil.h" #include "../dsputil.h"
@ -194,103 +194,86 @@ asm volatile(
static void dct_unquantize_mpeg1_mmx(MpegEncContext *s, static void dct_unquantize_mpeg1_mmx(MpegEncContext *s,
DCTELEM *block, int n, int qscale) DCTELEM *block, int n, int qscale)
{ {
int i, level, nCoeffs; int nCoeffs;
const UINT16 *quant_matrix; const UINT16 *quant_matrix;
if(s->alternate_scan) nCoeffs= 64; if(s->alternate_scan) nCoeffs= 64;
else nCoeffs= nCoeffs= zigzag_end[ s->block_last_index[n] ]; else nCoeffs= nCoeffs= zigzag_end[ s->block_last_index[n] ];
if (s->mb_intra) { if (s->mb_intra) {
int block0;
if (n < 4) if (n < 4)
block[0] = block[0] * s->y_dc_scale; block0 = block[0] * s->y_dc_scale;
else else
block[0] = block[0] * s->c_dc_scale; block0 = block[0] * s->c_dc_scale;
/* isnt used anymore (we have a h263 unquantizer since some time)
if (s->out_format == FMT_H263) {
i = 1;
goto unquant_even;
}*/
/* XXX: only mpeg1 */ /* XXX: only mpeg1 */
quant_matrix = s->intra_matrix; quant_matrix = s->intra_matrix;
i=1; asm volatile(
/* Align on 4 elements boundary */ "pcmpeqw %%mm7, %%mm7 \n\t"
while(i&3) "psrlw $15, %%mm7 \n\t"
{ "movd %2, %%mm6 \n\t"
level = block[i]; "packssdw %%mm6, %%mm6 \n\t"
if (level) { "packssdw %%mm6, %%mm6 \n\t"
if (level < 0) level = -level; "movl %3, %%eax \n\t"
level = (int)(level * qscale * quant_matrix[i]) >> 3; ".balign 16\n\t"
level = (level - 1) | 1; "1: \n\t"
if (block[i] < 0) level = -level; "movq (%0, %%eax), %%mm0 \n\t"
block[i] = level; "movq 8(%0, %%eax), %%mm1 \n\t"
} "movq (%1, %%eax), %%mm4 \n\t"
i++; "movq 8(%1, %%eax), %%mm5 \n\t"
} "pmullw %%mm6, %%mm4 \n\t" // q=qscale*quant_matrix[i]
__asm __volatile( "pmullw %%mm6, %%mm5 \n\t" // q=qscale*quant_matrix[i]
"movd %0, %%mm6\n\t" /* mm6 = qscale | 0 */ "pxor %%mm2, %%mm2 \n\t"
"punpckldq %%mm6, %%mm6\n\t" /* mm6 = qscale | qscale */ "pxor %%mm3, %%mm3 \n\t"
"movq %2, %%mm4\n\t" "pcmpgtw %%mm0, %%mm2 \n\t" // block[i] < 0 ? -1 : 0
"movq %%mm6, %%mm7\n\t" "pcmpgtw %%mm1, %%mm3 \n\t" // block[i] < 0 ? -1 : 0
"movq %1, %%mm5\n\t" "pxor %%mm2, %%mm0 \n\t"
"packssdw %%mm6, %%mm7\n\t" /* mm7 = qscale | qscale | qscale | qscale */ "pxor %%mm3, %%mm1 \n\t"
"pxor %%mm6, %%mm6\n\t" "psubw %%mm2, %%mm0 \n\t" // abs(block[i])
::"g"(qscale),"m"(mm_wone),"m"(mm_wabs):"memory"); "psubw %%mm3, %%mm1 \n\t" // abs(block[i])
for(;i<nCoeffs;i+=4) { "pmullw %%mm4, %%mm0 \n\t" // abs(block[i])*q
__asm __volatile( "pmullw %%mm5, %%mm1 \n\t" // abs(block[i])*q
"movq %1, %%mm0\n\t" "pxor %%mm4, %%mm4 \n\t"
"movq %%mm7, %%mm1\n\t" "pxor %%mm5, %%mm5 \n\t" // FIXME slow
"movq %%mm0, %%mm2\n\t" "pcmpeqw (%0, %%eax), %%mm4 \n\t" // block[i] == 0 ? -1 : 0
"movq %%mm0, %%mm3\n\t" "pcmpeqw 8(%0, %%eax), %%mm5 \n\t" // block[i] == 0 ? -1 : 0
"pcmpgtw %%mm6, %%mm2\n\t" "psraw $3, %%mm0 \n\t"
"pmullw %2, %%mm1\n\t" "psraw $3, %%mm1 \n\t"
"pandn %%mm4, %%mm2\n\t" "psubw %%mm7, %%mm0 \n\t"
"por %%mm5, %%mm2\n\t" "psubw %%mm7, %%mm1 \n\t"
"pmullw %%mm2, %%mm0\n\t" /* mm0 = abs(block[i]). */ "por %%mm7, %%mm0 \n\t"
"por %%mm7, %%mm1 \n\t"
"pcmpeqw %%mm6, %%mm3\n\t" "pxor %%mm2, %%mm0 \n\t"
"pmullw %%mm0, %%mm1\n\t" "pxor %%mm3, %%mm1 \n\t"
"psraw $3, %%mm1\n\t" "psubw %%mm2, %%mm0 \n\t"
"psubw %%mm5, %%mm1\n\t" /* block[i] --; */ "psubw %%mm3, %%mm1 \n\t"
"pandn %%mm4, %%mm3\n\t" /* fake of pcmpneqw : mm0 != 0 then mm1 = -1 */ "pandn %%mm0, %%mm4 \n\t"
"por %%mm5, %%mm1\n\t" /* block[i] |= 1 */ "pandn %%mm1, %%mm5 \n\t"
"pmullw %%mm2, %%mm1\n\t" /* change signs again */ "movq %%mm4, (%0, %%eax) \n\t"
"movq %%mm5, 8(%0, %%eax) \n\t"
"pand %%mm3, %%mm1\n\t" /* nullify if was zero */
"movq %%mm1, %0" "addl $16, %%eax \n\t"
:"=m"(block[i]) "js 1b \n\t"
:"m"(block[i]), "m"(quant_matrix[i]) ::"r" (block+nCoeffs), "r"(quant_matrix+nCoeffs), "g" (qscale), "g" (-2*nCoeffs)
:"memory"); : "%eax", "memory"
} );
block[0]= block0;
} else { } else {
i = 0;
// unquant_even:
quant_matrix = s->non_intra_matrix; quant_matrix = s->non_intra_matrix;
/* Align on 4 elements boundary */
while(i&7)
{
level = block[i];
if (level) {
if (level < 0) level = -level;
level = (((level << 1) + 1) * qscale *
((int) quant_matrix[i])) >> 4;
level = (level - 1) | 1;
if(block[i] < 0) level = -level;
block[i] = level;
}
i++;
}
asm volatile( asm volatile(
"pcmpeqw %%mm7, %%mm7 \n\t" "pcmpeqw %%mm7, %%mm7 \n\t"
"psrlw $15, %%mm7 \n\t" "psrlw $15, %%mm7 \n\t"
"movd %2, %%mm6 \n\t" "movd %2, %%mm6 \n\t"
"packssdw %%mm6, %%mm6 \n\t" "packssdw %%mm6, %%mm6 \n\t"
"packssdw %%mm6, %%mm6 \n\t" "packssdw %%mm6, %%mm6 \n\t"
"movl %3, %%eax \n\t"
".balign 16\n\t" ".balign 16\n\t"
"1: \n\t" "1: \n\t"
"movq (%0, %3), %%mm0 \n\t" "movq (%0, %%eax), %%mm0 \n\t"
"movq 8(%0, %3), %%mm1 \n\t" "movq 8(%0, %%eax), %%mm1 \n\t"
"movq (%1, %3), %%mm4 \n\t" "movq (%1, %%eax), %%mm4 \n\t"
"movq 8(%1, %3), %%mm5 \n\t" "movq 8(%1, %%eax), %%mm5 \n\t"
"pmullw %%mm6, %%mm4 \n\t" // q=qscale*quant_matrix[i] "pmullw %%mm6, %%mm4 \n\t" // q=qscale*quant_matrix[i]
"pmullw %%mm6, %%mm5 \n\t" // q=qscale*quant_matrix[i] "pmullw %%mm6, %%mm5 \n\t" // q=qscale*quant_matrix[i]
"pxor %%mm2, %%mm2 \n\t" "pxor %%mm2, %%mm2 \n\t"
@ -309,8 +292,8 @@ asm volatile(
"pmullw %%mm5, %%mm1 \n\t" // (abs(block[i])*2 + 1)*q "pmullw %%mm5, %%mm1 \n\t" // (abs(block[i])*2 + 1)*q
"pxor %%mm4, %%mm4 \n\t" "pxor %%mm4, %%mm4 \n\t"
"pxor %%mm5, %%mm5 \n\t" // FIXME slow "pxor %%mm5, %%mm5 \n\t" // FIXME slow
"pcmpeqw (%0, %3), %%mm4 \n\t" // block[i] == 0 ? -1 : 0 "pcmpeqw (%0, %%eax), %%mm4 \n\t" // block[i] == 0 ? -1 : 0
"pcmpeqw 8(%0, %3), %%mm5 \n\t" // block[i] == 0 ? -1 : 0 "pcmpeqw 8(%0, %%eax), %%mm5 \n\t" // block[i] == 0 ? -1 : 0
"psraw $4, %%mm0 \n\t" "psraw $4, %%mm0 \n\t"
"psraw $4, %%mm1 \n\t" "psraw $4, %%mm1 \n\t"
"psubw %%mm7, %%mm0 \n\t" "psubw %%mm7, %%mm0 \n\t"
@ -323,13 +306,145 @@ asm volatile(
"psubw %%mm3, %%mm1 \n\t" "psubw %%mm3, %%mm1 \n\t"
"pandn %%mm0, %%mm4 \n\t" "pandn %%mm0, %%mm4 \n\t"
"pandn %%mm1, %%mm5 \n\t" "pandn %%mm1, %%mm5 \n\t"
"movq %%mm4, (%0, %3) \n\t" "movq %%mm4, (%0, %%eax) \n\t"
"movq %%mm5, 8(%0, %3) \n\t" "movq %%mm5, 8(%0, %%eax) \n\t"
"addl $16, %3 \n\t" "addl $16, %%eax \n\t"
"js 1b \n\t" "js 1b \n\t"
::"r" (block+nCoeffs), "r"(quant_matrix+nCoeffs), "g" (qscale), "r" (2*(i-nCoeffs)) ::"r" (block+nCoeffs), "r"(quant_matrix+nCoeffs), "g" (qscale), "g" (-2*nCoeffs)
: "memory" : "%eax", "memory"
);
}
}
static void dct_unquantize_mpeg2_mmx(MpegEncContext *s,
DCTELEM *block, int n, int qscale)
{
int nCoeffs;
const UINT16 *quant_matrix;
if(s->alternate_scan) nCoeffs= 64;
else nCoeffs= nCoeffs= zigzag_end[ s->block_last_index[n] ];
if (s->mb_intra) {
int block0;
if (n < 4)
block0 = block[0] * s->y_dc_scale;
else
block0 = block[0] * s->c_dc_scale;
quant_matrix = s->intra_matrix;
asm volatile(
"pcmpeqw %%mm7, %%mm7 \n\t"
"psrlw $15, %%mm7 \n\t"
"movd %2, %%mm6 \n\t"
"packssdw %%mm6, %%mm6 \n\t"
"packssdw %%mm6, %%mm6 \n\t"
"movl %3, %%eax \n\t"
".balign 16\n\t"
"1: \n\t"
"movq (%0, %%eax), %%mm0 \n\t"
"movq 8(%0, %%eax), %%mm1 \n\t"
"movq (%1, %%eax), %%mm4 \n\t"
"movq 8(%1, %%eax), %%mm5 \n\t"
"pmullw %%mm6, %%mm4 \n\t" // q=qscale*quant_matrix[i]
"pmullw %%mm6, %%mm5 \n\t" // q=qscale*quant_matrix[i]
"pxor %%mm2, %%mm2 \n\t"
"pxor %%mm3, %%mm3 \n\t"
"pcmpgtw %%mm0, %%mm2 \n\t" // block[i] < 0 ? -1 : 0
"pcmpgtw %%mm1, %%mm3 \n\t" // block[i] < 0 ? -1 : 0
"pxor %%mm2, %%mm0 \n\t"
"pxor %%mm3, %%mm1 \n\t"
"psubw %%mm2, %%mm0 \n\t" // abs(block[i])
"psubw %%mm3, %%mm1 \n\t" // abs(block[i])
"pmullw %%mm4, %%mm0 \n\t" // abs(block[i])*q
"pmullw %%mm5, %%mm1 \n\t" // abs(block[i])*q
"pxor %%mm4, %%mm4 \n\t"
"pxor %%mm5, %%mm5 \n\t" // FIXME slow
"pcmpeqw (%0, %%eax), %%mm4 \n\t" // block[i] == 0 ? -1 : 0
"pcmpeqw 8(%0, %%eax), %%mm5 \n\t" // block[i] == 0 ? -1 : 0
"psraw $3, %%mm0 \n\t"
"psraw $3, %%mm1 \n\t"
"pxor %%mm2, %%mm0 \n\t"
"pxor %%mm3, %%mm1 \n\t"
"psubw %%mm2, %%mm0 \n\t"
"psubw %%mm3, %%mm1 \n\t"
"pandn %%mm0, %%mm4 \n\t"
"pandn %%mm1, %%mm5 \n\t"
"movq %%mm4, (%0, %%eax) \n\t"
"movq %%mm5, 8(%0, %%eax) \n\t"
"addl $16, %%eax \n\t"
"js 1b \n\t"
::"r" (block+nCoeffs), "r"(quant_matrix+nCoeffs), "g" (qscale), "g" (-2*nCoeffs)
: "%eax", "memory"
);
block[0]= block0;
//Note, we dont do mismatch control for intra as errors cannot accumulate
} else {
quant_matrix = s->non_intra_matrix;
asm volatile(
"pcmpeqw %%mm7, %%mm7 \n\t"
"psrlq $48, %%mm7 \n\t"
"movd %2, %%mm6 \n\t"
"packssdw %%mm6, %%mm6 \n\t"
"packssdw %%mm6, %%mm6 \n\t"
"movl %3, %%eax \n\t"
".balign 16\n\t"
"1: \n\t"
"movq (%0, %%eax), %%mm0 \n\t"
"movq 8(%0, %%eax), %%mm1 \n\t"
"movq (%1, %%eax), %%mm4 \n\t"
"movq 8(%1, %%eax), %%mm5 \n\t"
"pmullw %%mm6, %%mm4 \n\t" // q=qscale*quant_matrix[i]
"pmullw %%mm6, %%mm5 \n\t" // q=qscale*quant_matrix[i]
"pxor %%mm2, %%mm2 \n\t"
"pxor %%mm3, %%mm3 \n\t"
"pcmpgtw %%mm0, %%mm2 \n\t" // block[i] < 0 ? -1 : 0
"pcmpgtw %%mm1, %%mm3 \n\t" // block[i] < 0 ? -1 : 0
"pxor %%mm2, %%mm0 \n\t"
"pxor %%mm3, %%mm1 \n\t"
"psubw %%mm2, %%mm0 \n\t" // abs(block[i])
"psubw %%mm3, %%mm1 \n\t" // abs(block[i])
"paddw %%mm0, %%mm0 \n\t" // abs(block[i])*2
"paddw %%mm1, %%mm1 \n\t" // abs(block[i])*2
"pmullw %%mm4, %%mm0 \n\t" // abs(block[i])*2*q
"pmullw %%mm5, %%mm1 \n\t" // abs(block[i])*2*q
"paddw %%mm4, %%mm0 \n\t" // (abs(block[i])*2 + 1)*q
"paddw %%mm5, %%mm1 \n\t" // (abs(block[i])*2 + 1)*q
"pxor %%mm4, %%mm4 \n\t"
"pxor %%mm5, %%mm5 \n\t" // FIXME slow
"pcmpeqw (%0, %%eax), %%mm4 \n\t" // block[i] == 0 ? -1 : 0
"pcmpeqw 8(%0, %%eax), %%mm5 \n\t" // block[i] == 0 ? -1 : 0
"psrlw $4, %%mm0 \n\t"
"psrlw $4, %%mm1 \n\t"
"pxor %%mm2, %%mm0 \n\t"
"pxor %%mm3, %%mm1 \n\t"
"psubw %%mm2, %%mm0 \n\t"
"psubw %%mm3, %%mm1 \n\t"
"pandn %%mm0, %%mm4 \n\t"
"pandn %%mm1, %%mm5 \n\t"
"pxor %%mm4, %%mm7 \n\t"
"pxor %%mm5, %%mm7 \n\t"
"movq %%mm4, (%0, %%eax) \n\t"
"movq %%mm5, 8(%0, %%eax) \n\t"
"addl $16, %%eax \n\t"
"js 1b \n\t"
"movd 124(%0, %3), %%mm0 \n\t"
"movq %%mm7, %%mm6 \n\t"
"psrlq $32, %%mm7 \n\t"
"pxor %%mm6, %%mm7 \n\t"
"movq %%mm7, %%mm6 \n\t"
"psrlq $16, %%mm7 \n\t"
"pxor %%mm6, %%mm7 \n\t"
"pslld $31, %%mm7 \n\t"
"psrlq $15, %%mm7 \n\t"
"pxor %%mm7, %%mm0 \n\t"
"movd %%mm0, 124(%0, %3) \n\t"
::"r" (block+nCoeffs), "r"(quant_matrix+nCoeffs), "g" (qscale), "r" (-2*nCoeffs)
: "%eax", "memory"
); );
} }
} }
@ -441,7 +556,8 @@ void MPV_common_init_mmx(MpegEncContext *s)
{ {
if (mm_flags & MM_MMX) { if (mm_flags & MM_MMX) {
s->dct_unquantize_h263 = dct_unquantize_h263_mmx; s->dct_unquantize_h263 = dct_unquantize_h263_mmx;
s->dct_unquantize_mpeg = dct_unquantize_mpeg1_mmx; s->dct_unquantize_mpeg1 = dct_unquantize_mpeg1_mmx;
s->dct_unquantize_mpeg2 = dct_unquantize_mpeg2_mmx;
draw_edges = draw_edges_mmx; draw_edges = draw_edges_mmx;

@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
* *
* 4MV & hq encoding stuff by Michael Niedermayer <michaelni@gmx.at> * 4MV & hq & b-frame encoding stuff by Michael Niedermayer <michaelni@gmx.at>
*/ */
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
@ -35,6 +35,8 @@ static void rate_control_init(MpegEncContext *s);
static int rate_estimate_qscale(MpegEncContext *s); static int rate_estimate_qscale(MpegEncContext *s);
static void dct_unquantize_mpeg1_c(MpegEncContext *s, static void dct_unquantize_mpeg1_c(MpegEncContext *s,
DCTELEM *block, int n, int qscale); DCTELEM *block, int n, int qscale);
static void dct_unquantize_mpeg2_c(MpegEncContext *s,
DCTELEM *block, int n, int qscale);
static void dct_unquantize_h263_c(MpegEncContext *s, static void dct_unquantize_h263_c(MpegEncContext *s,
DCTELEM *block, int n, int qscale); DCTELEM *block, int n, int qscale);
static void draw_edges_c(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);
@ -112,7 +114,8 @@ int MPV_common_init(MpegEncContext *s)
UINT8 *pict; UINT8 *pict;
s->dct_unquantize_h263 = dct_unquantize_h263_c; s->dct_unquantize_h263 = dct_unquantize_h263_c;
s->dct_unquantize_mpeg = dct_unquantize_mpeg1_c; s->dct_unquantize_mpeg1 = dct_unquantize_mpeg1_c;
s->dct_unquantize_mpeg2 = dct_unquantize_mpeg2_c;
#ifdef HAVE_MMX #ifdef HAVE_MMX
MPV_common_init_mmx(s); MPV_common_init_mmx(s);
@ -121,7 +124,7 @@ int MPV_common_init(MpegEncContext *s)
if(s->out_format == FMT_H263) if(s->out_format == FMT_H263)
s->dct_unquantize = s->dct_unquantize_h263; s->dct_unquantize = s->dct_unquantize_h263;
else else
s->dct_unquantize = s->dct_unquantize_mpeg; s->dct_unquantize = s->dct_unquantize_mpeg1;
s->mb_width = (s->width + 15) / 16; s->mb_width = (s->width + 15) / 16;
s->mb_height = (s->height + 15) / 16; s->mb_height = (s->height + 15) / 16;
@ -1944,6 +1947,69 @@ static void dct_unquantize_mpeg1_c(MpegEncContext *s,
} }
} }
static void dct_unquantize_mpeg2_c(MpegEncContext *s,
DCTELEM *block, int n, int qscale)
{
int i, level, nCoeffs;
const UINT16 *quant_matrix;
if(s->alternate_scan) nCoeffs= 64;
else nCoeffs= s->block_last_index[n]+1;
if (s->mb_intra) {
if (n < 4)
block[0] = block[0] * s->y_dc_scale;
else
block[0] = block[0] * s->c_dc_scale;
quant_matrix = s->intra_matrix;
for(i=1;i<nCoeffs;i++) {
int j= zigzag_direct[i];
level = block[j];
if (level) {
if (level < 0) {
level = -level;
level = (int)(level * qscale * quant_matrix[j]) >> 3;
level = -level;
} else {
level = (int)(level * qscale * quant_matrix[j]) >> 3;
}
#ifdef PARANOID
if (level < -2048 || level > 2047)
fprintf(stderr, "unquant error %d %d\n", i, level);
#endif
block[j] = level;
}
}
} else {
int sum=-1;
i = 0;
quant_matrix = s->non_intra_matrix;
for(;i<nCoeffs;i++) {
int j= zigzag_direct[i];
level = block[j];
if (level) {
if (level < 0) {
level = -level;
level = (((level << 1) + 1) * qscale *
((int) (quant_matrix[j]))) >> 4;
level = -level;
} else {
level = (((level << 1) + 1) * qscale *
((int) (quant_matrix[j]))) >> 4;
}
#ifdef PARANOID
if (level < -2048 || level > 2047)
fprintf(stderr, "unquant error %d %d\n", i, level);
#endif
block[j] = level;
sum+=level;
}
}
block[63]^=sum&1;
}
}
static void dct_unquantize_h263_c(MpegEncContext *s, static void dct_unquantize_h263_c(MpegEncContext *s,
DCTELEM *block, int n, int qscale) DCTELEM *block, int n, int qscale)
{ {

@ -338,7 +338,9 @@ typedef struct MpegEncContext {
DCTELEM intra_block[6][64] __align8; DCTELEM intra_block[6][64] __align8;
DCTELEM inter_block[6][64] __align8; DCTELEM inter_block[6][64] __align8;
DCTELEM inter4v_block[6][64] __align8; DCTELEM inter4v_block[6][64] __align8;
void (*dct_unquantize_mpeg)(struct MpegEncContext *s, void (*dct_unquantize_mpeg1)(struct MpegEncContext *s,
DCTELEM *block, int n, int qscale);
void (*dct_unquantize_mpeg2)(struct MpegEncContext *s,
DCTELEM *block, int n, int qscale); DCTELEM *block, int n, int qscale);
void (*dct_unquantize_h263)(struct MpegEncContext *s, void (*dct_unquantize_h263)(struct MpegEncContext *s,
DCTELEM *block, int n, int qscale); DCTELEM *block, int n, int qscale);

Loading…
Cancel
Save