mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2024-12-22 15:23:11 +00:00
Make dct_unquantize_h263 work on systems without MVI extension.
Originally committed as revision 715 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
e0580f8c68
commit
2dbe7ec87c
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
extern UINT8 zigzag_end[64];
|
extern UINT8 zigzag_end[64];
|
||||||
|
|
||||||
static void dct_unquantize_h263_mvi(MpegEncContext *s, DCTELEM *block,
|
static void dct_unquantize_h263_axp(MpegEncContext *s, DCTELEM *block,
|
||||||
int n, int qscale)
|
int n, int qscale)
|
||||||
{
|
{
|
||||||
int i, n_coeffs;
|
int i, n_coeffs;
|
||||||
@ -32,8 +32,6 @@ static void dct_unquantize_h263_mvi(MpegEncContext *s, DCTELEM *block,
|
|||||||
DCTELEM *orig_block = block;
|
DCTELEM *orig_block = block;
|
||||||
DCTELEM block0;
|
DCTELEM block0;
|
||||||
|
|
||||||
ASM_ACCEPT_MVI;
|
|
||||||
|
|
||||||
if (s->mb_intra) {
|
if (s->mb_intra) {
|
||||||
if (!s->h263_aic) {
|
if (!s->h263_aic) {
|
||||||
if (n < 4)
|
if (n < 4)
|
||||||
@ -58,8 +56,17 @@ static void dct_unquantize_h263_mvi(MpegEncContext *s, DCTELEM *block,
|
|||||||
if (levels == 0)
|
if (levels == 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
#ifdef __alpha_max__
|
||||||
|
/* I don't think the speed difference justifies runtime
|
||||||
|
detection. */
|
||||||
|
ASM_ACCEPT_MVI;
|
||||||
negmask = maxsw4(levels, -1); /* negative -> ffff (-1) */
|
negmask = maxsw4(levels, -1); /* negative -> ffff (-1) */
|
||||||
negmask = minsw4(negmask, 0); /* positive -> 0000 (0) */
|
negmask = minsw4(negmask, 0); /* positive -> 0000 (0) */
|
||||||
|
#else
|
||||||
|
negmask = cmpbge(WORD_VEC(0x7fff), levels);
|
||||||
|
negmask &= (negmask >> 1) | (1 << 7);
|
||||||
|
negmask = zap(-1, negmask);
|
||||||
|
#endif
|
||||||
|
|
||||||
zeros = cmpbge(0, levels);
|
zeros = cmpbge(0, levels);
|
||||||
zeros &= zeros >> 1;
|
zeros &= zeros >> 1;
|
||||||
@ -86,7 +93,5 @@ static void dct_unquantize_h263_mvi(MpegEncContext *s, DCTELEM *block,
|
|||||||
|
|
||||||
void MPV_common_init_axp(MpegEncContext *s)
|
void MPV_common_init_axp(MpegEncContext *s)
|
||||||
{
|
{
|
||||||
if (amask(AMASK_MVI) == 0) {
|
s->dct_unquantize_h263 = dct_unquantize_h263_axp;
|
||||||
s->dct_unquantize_h263 = dct_unquantize_h263_mvi;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user