Commit 6548bd46 authored by michael's avatar michael

mpeg2 QP clamping fix


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@2663 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 84e3dc41
...@@ -943,10 +943,10 @@ for(y=0; y<mbHeight; y++){ ...@@ -943,10 +943,10 @@ for(y=0; y<mbHeight; y++){
int i; int i;
const int count= mbHeight * QPStride; const int count= mbHeight * QPStride;
for(i=0; i<(count>>2); i++){ for(i=0; i<(count>>2); i++){
((uint32_t*)c->nonBQPTable)[i] = ((uint32_t*)QP_store)[i] & 0x1F1F1F1F; ((uint32_t*)c->nonBQPTable)[i] = ((uint32_t*)QP_store)[i] & 0x3F3F3F3F;
} }
for(i<<=2; i<count; i++){ for(i<<=2; i<count; i++){
c->nonBQPTable[i] = QP_store[i] & 0x1F; c->nonBQPTable[i] = QP_store[i] & 0x3F;
} }
} }
......
...@@ -134,8 +134,8 @@ typedef struct PPContext{ ...@@ -134,8 +134,8 @@ typedef struct PPContext{
uint64_t __attribute__((aligned(8))) pQPb; uint64_t __attribute__((aligned(8))) pQPb;
uint64_t __attribute__((aligned(8))) pQPb2; uint64_t __attribute__((aligned(8))) pQPb2;
uint64_t __attribute__((aligned(8))) mmxDcOffset[32]; uint64_t __attribute__((aligned(8))) mmxDcOffset[64];
uint64_t __attribute__((aligned(8))) mmxDcThreshold[32]; uint64_t __attribute__((aligned(8))) mmxDcThreshold[64];
QP_STORE_T *stdQPTable; ///< used to fix MPEG2 style qscale QP_STORE_T *stdQPTable; ///< used to fix MPEG2 style qscale
QP_STORE_T *nonBQPTable; QP_STORE_T *nonBQPTable;
......
...@@ -2792,7 +2792,7 @@ static void RENAME(postProcess)(uint8_t src[], int srcStride, uint8_t dst[], int ...@@ -2792,7 +2792,7 @@ static void RENAME(postProcess)(uint8_t src[], int srcStride, uint8_t dst[], int
const int mbWidth= isColor ? (width+7)>>3 : (width+15)>>4; const int mbWidth= isColor ? (width+7)>>3 : (width+15)>>4;
#ifdef HAVE_MMX #ifdef HAVE_MMX
for(i=0; i<32; i++){ for(i=0; i<57; i++){
int offset= ((i*c.ppMode.baseDcDiff)>>8) + 1; int offset= ((i*c.ppMode.baseDcDiff)>>8) + 1;
int threshold= offset*2 + 1; int threshold= offset*2 + 1;
c.mmxDcOffset[i]= 0x7F - offset; c.mmxDcOffset[i]= 0x7F - offset;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment