diff options
| author | phintuka <phintuka> | 2008-07-30 14:59:36 +0000 | 
|---|---|---|
| committer | phintuka <phintuka> | 2008-07-30 14:59:36 +0000 | 
| commit | b704feb155793869f9fe063807cd290ac863dbfe (patch) | |
| tree | 62a3e94d7062e484d5d166ea549b05c8f2b6b03e /xine_input_vdr.c | |
| parent | cd403b4330aace187ac710d4ca21337110fda3cd (diff) | |
| download | xineliboutput-b704feb155793869f9fe063807cd290ac863dbfe.tar.gz xineliboutput-b704feb155793869f9fe063807cd290ac863dbfe.tar.bz2 | |
- Fixed queue_nosignal when using ffmpeg mpeg2 decoder:
  - Added BUF_FLAG_FRAME_END to last video packet
  - Added MPEG2 end of sequence code after video data
  (This enables OSD even if there is no video stream available)
- Use new defines from h264.h and pes.h
Diffstat (limited to 'xine_input_vdr.c')
| -rw-r--r-- | xine_input_vdr.c | 24 | 
1 files changed, 20 insertions, 4 deletions
| diff --git a/xine_input_vdr.c b/xine_input_vdr.c index 08f46bb3..2f338c2d 100644 --- a/xine_input_vdr.c +++ b/xine_input_vdr.c @@ -4,7 +4,7 @@   * See the main source file 'xineliboutput.c' for copyright information and   * how to reach the author.   * - * $Id: xine_input_vdr.c,v 1.165 2008-07-15 08:18:36 phintuka Exp $ + * $Id: xine_input_vdr.c,v 1.166 2008-07-30 14:59:36 phintuka Exp $   *   */ @@ -1236,6 +1236,8 @@ static void queue_nosignal(vdr_input_plugin_t *this)        buf->type = BUF_VIDEO_MPEG;        xine_fast_memcpy(buf->content, &data[pos], buf->size);        pos += buf->size; +      if(pos >= datalen) +        buf->decoder_flags |= BUF_FLAG_FRAME_END;        this->stream->video_fifo->put(this->stream->video_fifo, buf);      } else {        LOGMSG("Error: queue_nosignal: no buffers !"); @@ -1243,6 +1245,20 @@ static void queue_nosignal(vdr_input_plugin_t *this)      }    } +  /* sequence end */ +  buf = this->stream->video_fifo->buffer_pool_try_alloc(this->stream->video_fifo); +  if (buf) { +    static const uint8_t seq_end[] = {0x00, 0x00, 0x01, 0xb7}; /* mpeg2 */ +    buf->type = BUF_VIDEO_MPEG; +    buf->size = sizeof(seq_end); +    buf->decoder_flags = BUF_FLAG_FRAME_END; +    memcpy(buf->content, seq_end, sizeof(seq_end)); +    this->stream->video_fifo->put(this->stream->video_fifo, buf); + +    /*put_control_buf(this->stream->video_fifo, this->stream->video_fifo, BUF_CONTROL_FLUSH_DECODER);*/ +    /*put_control_buf(this->stream->video_fifo, this->stream->video_fifo, BUF_CONTROL_NOP);*/ +  } +    free(tmp);  } @@ -4980,7 +4996,7 @@ static int detect_h264(vdr_input_plugin_t *this, uint8_t *data, int len)    /* H.264 detection */    if (data[i] == 0 && data[i + 1] == 0 && data[i + 2] == 1) { -    if (data[i + 3] == 0x09) { +    if (data[i + 3] == NAL_AUD) {        LOGMSG("H.264 scanner: Possible H.264 NAL AUD");        return 1;      } @@ -5218,7 +5234,7 @@ static buf_element_t *preprocess_buf(vdr_input_plugin_t *this, buf_element_t *bu    }    /* ignore UDP/RTP "idle" padding */ -  if(buf->content[3] == PADDING_STREAM) { +  if (IS_PADDING_PACKET(buf->content)) {      pthread_mutex_unlock(&this->lock);      return buf;    } @@ -5498,7 +5514,7 @@ static buf_element_t *vdr_plugin_read_block (input_plugin_t *this_gen,      if ((buf->type & BUF_MAJOR_MASK) ==  BUF_CONTROL_BASE)        return buf;      /* ignore UDP/RTP "idle" padding */ -    if(buf->content[3] == PADDING_STREAM) +    if(IS_PADDING_PACKET(buf->content))        return buf;      buf = demux_buf(this, buf); | 
