diff options
| author | phintuka <phintuka> | 2009-05-06 15:16:31 +0000 | 
|---|---|---|
| committer | phintuka <phintuka> | 2009-05-06 15:16:31 +0000 | 
| commit | c692418dbe7d663a1bf1a8079aeaa3e21621175b (patch) | |
| tree | b2c7c0ec676ca645b1b9bf64e80286d39daef696 | |
| parent | de2b5b684e94c2e15ee43e291c1ba0a3c2baae53 (diff) | |
| download | xineliboutput-c692418dbe7d663a1bf1a8079aeaa3e21621175b.tar.gz xineliboutput-c692418dbe7d663a1bf1a8079aeaa3e21621175b.tar.bz2 | |
Improved mpeg-ts caching
| -rw-r--r-- | device.c | 72 | ||||
| -rw-r--r-- | device.h | 6 | 
2 files changed, 48 insertions, 30 deletions
| @@ -4,7 +4,7 @@   * See the main source file 'xineliboutput.c' for copyright information and   * how to reach the author.   * - * $Id: device.c,v 1.79 2009-05-06 15:08:45 phintuka Exp $ + * $Id: device.c,v 1.80 2009-05-06 15:16:31 phintuka Exp $   *   */ @@ -1033,25 +1033,6 @@ int cXinelibDevice::PlayAny(const uchar *buf, int length)      return length;  #endif -#if VDRVERSNUM >= 10701 -  if (!buf) { -    /* flush cache */ -    buf = m_TsBuf; -    length = m_TsBufSize; -    m_TsBufSize = 0; -  } -  else if (DATA_IS_TS(buf) && length == TS_SIZE) { -    memcpy(m_TsBuf + m_TsBufSize, buf, length); -    m_TsBufSize += length; -    if (m_TsBufSize < 2048-TS_SIZE+1) -      return TS_SIZE; -    buf = m_TsBuf; -    length = m_TsBufSize; -    m_TsBufSize = 0; -  } else if (m_TsBufSize) { -    LOGMSG("PlayAny: TS cache error !"); -  } -#endif    if (!buf || length <= 0)      return length; @@ -1126,7 +1107,7 @@ int cXinelibDevice::PlayTs(const uchar *Data, int Length, bool VideoOnly)          LOGMSG("Got PAT: PMT pid = %d", m_PatPmtParser.PmtPid());          if (m_server)            m_server->SetHeader(Data, Length, true); -        PlayAny(Data, Length); +        PlayTsAny(Data, Length);        } else if (Pid == m_PatPmtParser.PmtPid()) {  #if VDRVERSNUM >= 10704          m_PatPmtParser.ParsePmt(Data, Length); @@ -1137,7 +1118,7 @@ int cXinelibDevice::PlayTs(const uchar *Data, int Length, bool VideoOnly)          LOGMSG("Got PMT packet, h264 = %d", m_h264?1:0);          if (m_server)            m_server->SetHeader(Data, Length); -        PlayAny(Data, Length); +        PlayTsAny(Data, Length);          TsBufferFlush();        }      } @@ -1148,25 +1129,60 @@ int cXinelibDevice::PlayTs(const uchar *Data, int Length, bool VideoOnly)    return cDevice::PlayTs(Data, Length, VideoOnly);  } +int cXinelibDevice::TsBufferFlush(void) +{ +  if (m_TsBufSize) { +    int n; +    if ((n = PlayAny(m_TsBuf, m_TsBufSize)) == m_TsBufSize) { +      m_TsBufSize = 0; +      return n; +    } +    if (n) +      LOGMSG("cXinelibDevice::TsBufferFlush: error: cache not flushed (%d %d)", n, m_TsBufSize); +    errno = EAGAIN; +  } +  return 0; +} + +int cXinelibDevice::PlayTsAny(const uchar *buf, int length) +{ +  if (!DATA_IS_TS(buf)) +    LOGMSG("PlayTsAny(): TS SYNC byte missing !"); +  if (length != TS_SIZE) +    LOGMSG("PlayTsAny(): length == %d !", length); + +  // cache full ? try to flush it +  if (m_TsBufSize >= 2048) +    if (!TsBufferFlush()) +      return 0; + +  // add packet to cache +  memcpy(m_TsBuf + m_TsBufSize, buf, length); +  m_TsBufSize += length; + +  // time to flush ? +  if (m_TsBufSize >= 2048-TS_SIZE-1) +    TsBufferFlush(); + +  return length; +} +  int cXinelibDevice::PlayTsSubtitle(const uchar *Data, int Length)  {    if (!xc.dvb_subtitles)      return cDevice::PlayTsSubtitle(Data, Length); -  int r = PlayAny(Data, Length); -  return r > 0 ? TS_SIZE : r; +  return PlayTsAny(Data, Length);  }  int cXinelibDevice::PlayTsAudio(const uchar *Data, int Length)  { -  int r = PlayAny(Data, Length); -  return r > 0 ? TS_SIZE : r; +  return PlayTsAny(Data, Length);  }  int cXinelibDevice::PlayTsVideo(const uchar *Data, int Length)  { -  int r = PlayAny(Data, Length); -  return r > 0 ? TS_SIZE : r; +  return PlayTsAny(Data, Length);  }  #endif // VDRVERSNUM >= 10701 @@ -4,7 +4,7 @@   * See the main source file 'xineliboutput.c' for copyright information and   * how to reach the author.   * - * $Id: device.h,v 1.46 2009-05-03 20:33:08 phintuka Exp $ + * $Id: device.h,v 1.47 2009-05-06 15:16:31 phintuka Exp $   *   */ @@ -245,9 +245,11 @@ class cXinelibDevice : public cDevice      /* join multiple TS packets to xineliboutput transport packet */      uint8_t       m_TsBuf[4096];      uint          m_TsBufSize; -    void          TsBufferFlush(void) { if (m_TsBufSize) PlayAny(NULL, 0); }; +    int           TsBufferFlush(void);      void          TsBufferClear(void) { m_TsBufSize = 0; }; +    int           PlayTsAny(const uchar *Data, int Length); +      virtual int PlayTsVideo(const uchar *Data, int Length);      virtual int PlayTsAudio(const uchar *Data, int Length);      virtual int PlayTsSubtitle(const uchar *Data, int Length); | 
