[cvs] / xvidcore / src / decoder.c Repository:
ViewVC logotype

Diff of /xvidcore/src/decoder.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.49.2.19, Thu Nov 13 22:35:30 2003 UTC revision 1.49.2.28, Sun Dec 21 19:41:53 2003 UTC
# Line 41  Line 41 
41  #include "bitstream/mbcoding.h"  #include "bitstream/mbcoding.h"
42    
43  #include "quant/quant.h"  #include "quant/quant.h"
44    #include "quant/quant_matrix.h"
45  #include "dct/idct.h"  #include "dct/idct.h"
46  #include "dct/fdct.h"  #include "dct/fdct.h"
47  #include "utils/mem_transfer.h"  #include "utils/mem_transfer.h"
# Line 57  Line 58 
58    
59  #include "image/image.h"  #include "image/image.h"
60  #include "image/colorspace.h"  #include "image/colorspace.h"
61    #include "image/postprocessing.h"
62  #include "utils/mem_align.h"  #include "utils/mem_align.h"
63    
64  static int  static int
# Line 175  Line 177 
177          if (dec == NULL) {          if (dec == NULL) {
178                  return XVID_ERR_MEMORY;                  return XVID_ERR_MEMORY;
179          }          }
180    
181          memset(dec, 0, sizeof(DECODER));          memset(dec, 0, sizeof(DECODER));
182    
183            dec->mpeg_quant_matrices = xvid_malloc(sizeof(uint16_t) * 64 * 8, CACHE_LINE);
184            if (dec->mpeg_quant_matrices == NULL) {
185                    xvid_free(dec);
186                    return XVID_ERR_MEMORY;
187            }
188    
189          create->handle = dec;          create->handle = dec;
190    
191          dec->width = create->width;          dec->width = create->width;
# Line 196  Line 205 
205          dec->last_mbs = NULL;          dec->last_mbs = NULL;
206    
207          init_timer();          init_timer();
208            init_postproc(&dec->postproc);
209            init_mpeg_matrix(dec->mpeg_quant_matrices);
210    
211          /* For B-frame support (used to save reference frame's time */          /* For B-frame support (used to save reference frame's time */
212          dec->frames = 0;          dec->frames = 0;
# Line 226  Line 237 
237          image_destroy(&dec->tmp, dec->edged_width, dec->edged_height);          image_destroy(&dec->tmp, dec->edged_width, dec->edged_height);
238          image_destroy(&dec->qtmp, dec->edged_width, dec->edged_height);          image_destroy(&dec->qtmp, dec->edged_width, dec->edged_height);
239          image_destroy(&dec->cur, dec->edged_width, dec->edged_height);          image_destroy(&dec->cur, dec->edged_width, dec->edged_height);
240            xvid_free(dec->mpeg_quant_matrices);
241          xvid_free(dec);          xvid_free(dec);
242    
243          write_timer();          write_timer();
# Line 321  Line 333 
333    
334                  start_timer();                  start_timer();
335                  if (dec->quant_type == 0) {                  if (dec->quant_type == 0) {
336                          dequant_h263_intra(&data[i * 64], &block[i * 64], iQuant, iDcScaler);                          dequant_h263_intra(&data[i * 64], &block[i * 64], iQuant, iDcScaler, dec->mpeg_quant_matrices);
337                  } else {                  } else {
338                          dequant_mpeg_intra(&data[i * 64], &block[i * 64], iQuant, iDcScaler);                          dequant_mpeg_intra(&data[i * 64], &block[i * 64], iQuant, iDcScaler, dec->mpeg_quant_matrices);
339                  }                  }
340                  stop_iquant_timer();                  stop_iquant_timer();
341    
# Line 392  Line 404 
404                          stop_coding_timer();                          stop_coding_timer();
405    
406                          start_timer();                          start_timer();
407                          dequant(&data[i * 64], block, iQuant);                          dequant(&data[i * 64], block, iQuant, dec->mpeg_quant_matrices);
408                          stop_iquant_timer();                          stop_iquant_timer();
409    
410                          start_timer();                          start_timer();
# Line 1304  Line 1316 
1316    
1317  /* perform post processing if necessary, and output the image */  /* perform post processing if necessary, and output the image */
1318  void decoder_output(DECODER * dec, IMAGE * img, MACROBLOCK * mbs,  void decoder_output(DECODER * dec, IMAGE * img, MACROBLOCK * mbs,
1319                                          xvid_dec_frame_t * frame, xvid_dec_stats_t * stats, int coding_type)                                          xvid_dec_frame_t * frame, xvid_dec_stats_t * stats,
1320                                            int coding_type, int quant)
1321  {  {
1322            if (dec->cartoon_mode)
1323                    frame->general &= ~XVID_FILMEFFECT;
1324    
1325            if (frame->general & (XVID_DEBLOCKY|XVID_DEBLOCKUV|XVID_FILMEFFECT) && mbs != NULL)     /* post process */
1326            {
1327                    /* note: image is stored to tmp */
1328                    image_copy(&dec->tmp, img, dec->edged_width, dec->height);
1329                    image_postproc(&dec->postproc, &dec->tmp, dec->edged_width,
1330                                               mbs, dec->mb_width, dec->mb_height, dec->mb_width,
1331                                               frame->general, dec->frames, (coding_type == B_VOP));
1332                    img = &dec->tmp;
1333            }
1334    
1335          image_output(img, dec->width, dec->height,          image_output(img, dec->width, dec->height,
1336                                   dec->edged_width, (uint8_t**)frame->output.plane, frame->output.stride,                                   dec->edged_width, (uint8_t**)frame->output.plane, frame->output.stride,
1337                                   frame->output.csp, dec->interlacing);                                   frame->output.csp, dec->interlacing);
# Line 1349  Line 1375 
1375                  /* if not decoding "low_delay/packed", and this isn't low_delay and                  /* if not decoding "low_delay/packed", and this isn't low_delay and
1376                          we have a reference frame, then outout the reference frame */                          we have a reference frame, then outout the reference frame */
1377                  if (!(dec->low_delay_default && dec->packed_mode) && !dec->low_delay && dec->frames>0) {                  if (!(dec->low_delay_default && dec->packed_mode) && !dec->low_delay && dec->frames>0) {
1378                          decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type);                          decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type, quant);
1379                          dec->frames = 0;                          dec->frames = 0;
1380                          ret = 0;                          ret = 0;
1381                  } else {                  } else {
# Line 1419  Line 1445 
1445          /* packed_mode: special-N_VOP treament */          /* packed_mode: special-N_VOP treament */
1446          if (dec->packed_mode && coding_type == N_VOP) {          if (dec->packed_mode && coding_type == N_VOP) {
1447                  if (dec->low_delay_default && dec->frames > 0) {                  if (dec->low_delay_default && dec->frames > 0) {
1448                          decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type);                          decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type, quant);
1449                          output = 1;                          output = 1;
1450                  }                  }
1451                  /* ignore otherwise */                  /* ignore otherwise */
# Line 1440  Line 1466 
1466                          /* XXX: not_coded vops are not used for forward prediction */                          /* XXX: not_coded vops are not used for forward prediction */
1467                          /* we should not swap(last_mbs,mbs) */                          /* we should not swap(last_mbs,mbs) */
1468                          image_copy(&dec->cur, &dec->refn[0], dec->edged_width, dec->height);                          image_copy(&dec->cur, &dec->refn[0], dec->edged_width, dec->height);
1469                            SWAP(MACROBLOCK *, dec->mbs, dec->last_mbs); /* it will be swapped back */
1470                          break;                          break;
1471                  }                  }
1472    
# Line 1452  Line 1479 
1479                  /* note: for packed_mode, output is performed when the special-N_VOP is decoded */                  /* note: for packed_mode, output is performed when the special-N_VOP is decoded */
1480                  if (!(dec->low_delay_default && dec->packed_mode)) {                  if (!(dec->low_delay_default && dec->packed_mode)) {
1481                          if (dec->low_delay) {                          if (dec->low_delay) {
1482                                  decoder_output(dec, &dec->cur, dec->mbs, frame, stats, coding_type);                                  decoder_output(dec, &dec->cur, dec->mbs, frame, stats, coding_type, quant);
1483                                  output = 1;                                  output = 1;
1484                          } else if (dec->frames > 0)     { /* is the reference frame valid? */                          } else if (dec->frames > 0)     { /* is the reference frame valid? */
1485                                  /* output the reference frame */                                  /* output the reference frame */
1486                                  decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type);                                  decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type, quant);
1487                                  output = 1;                                  output = 1;
1488                          }                          }
1489                  }                  }
# Line 1481  Line 1508 
1508                          /* attemping to decode a bvop without atleast 2 reference frames */                          /* attemping to decode a bvop without atleast 2 reference frames */
1509                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 16,                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 16,
1510                                                  "broken b-frame, mising ref frames");                                                  "broken b-frame, mising ref frames");
1511                            stats->type = XVID_TYPE_NOTHING;
1512                  } else if (dec->time_pp <= dec->time_bp) {                  } else if (dec->time_pp <= dec->time_bp) {
1513                          /* this occurs when dx50_bvop_compatibility==0 sequences are                          /* this occurs when dx50_bvop_compatibility==0 sequences are
1514                          decoded in vfw. */                          decoded in vfw. */
1515                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 16,                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 16,
1516                                                  "broken b-frame, tpp=%i tbp=%i", dec->time_pp, dec->time_bp);                                                  "broken b-frame, tpp=%i tbp=%i", dec->time_pp, dec->time_bp);
1517                            stats->type = XVID_TYPE_NOTHING;
1518                  } else {                  } else {
1519                          decoder_bframe(dec, &bs, quant, fcode_forward, fcode_backward);                          decoder_bframe(dec, &bs, quant, fcode_forward, fcode_backward);
1520                            decoder_output(dec, &dec->cur, dec->mbs, frame, stats, coding_type, quant);
1521                  }                  }
1522    
                 decoder_output(dec, &dec->cur, dec->mbs, frame, stats, coding_type);  
1523                  output = 1;                  output = 1;
1524                  dec->frames++;                  dec->frames++;
1525          }          }
# Line 1510  Line 1539 
1539          if (dec->low_delay_default && output == 0) {          if (dec->low_delay_default && output == 0) {
1540                  if (dec->packed_mode && seen_something) {                  if (dec->packed_mode && seen_something) {
1541                          /* output the recently decoded frame */                          /* output the recently decoded frame */
1542                          decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type);                          decoder_output(dec, &dec->refn[0], dec->last_mbs, frame, stats, dec->last_coding_type, quant);
1543                  } else {                  } else {
1544                          image_clear(&dec->cur, dec->width, dec->height, dec->edged_width, 0, 128, 128);                          image_clear(&dec->cur, dec->width, dec->height, dec->edged_width, 0, 128, 128);
1545                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 16,                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 16,
# Line 1518  Line 1547 
1547                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 64,                          image_printf(&dec->cur, dec->edged_width, dec->height, 16, 64,
1548                                  "bframe decoder lag");                                  "bframe decoder lag");
1549    
1550                          decoder_output(dec, &dec->cur, NULL, frame, stats, P_VOP);                          decoder_output(dec, &dec->cur, NULL, frame, stats, P_VOP, quant);
1551                          if (stats) stats->type = XVID_TYPE_NOTHING;                          if (stats) stats->type = XVID_TYPE_NOTHING;
1552                  }                  }
1553          }          }

Legend:
Removed from v.1.49.2.19  
changed lines
  Added in v.1.49.2.28

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4