diff options
| author | Klaus Schmidinger <vdr@tvdr.de> | 2005-01-16 12:02:39 +0100 | 
|---|---|---|
| committer | Klaus Schmidinger <vdr@tvdr.de> | 2005-01-16 12:02:39 +0100 | 
| commit | 9423c636a25dcdc2531d51551aff33cf93abc095 (patch) | |
| tree | 522f898c6d68ce0153e23db1c1696a2c461a7623 | |
| parent | 62390837ff4e4fab3bb837ca745219fc70d4ef3e (diff) | |
| download | vdr-9423c636a25dcdc2531d51551aff33cf93abc095.tar.gz vdr-9423c636a25dcdc2531d51551aff33cf93abc095.tar.bz2 | |
Fixed playing files with PES packets longer than 2048 byte through the full featured DVB card
| -rw-r--r-- | CONTRIBUTORS | 4 | ||||
| -rw-r--r-- | HISTORY | 3 | ||||
| -rw-r--r-- | dvbdevice.c | 6 | ||||
| -rw-r--r-- | tools.c | 26 | ||||
| -rw-r--r-- | tools.h | 6 | 
5 files changed, 40 insertions, 5 deletions
| diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 5246315a..74487594 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -1214,3 +1214,7 @@ Achim Tuffentsammer <a.tuffentsammer@web.de>  Michael Heyse <mhk@designassembly.de>   for his help in keeping 'channels.conf.terr' up to date + +Marco Kremer <vdr.hgm.bg@gmx.net> + for reporting a problem with playing files with PES packets longer than 2048 byte + through the full featured DVB card @@ -3308,3 +3308,6 @@ Video Disk Recorder Revision History  - Added 'channels.conf.terr' entries for Mainz (thanks to Michael Heyse).  - Implemented cDolbyRepacker for better handling of Dolby Digital PES packets    (thanks to Reinhard Nissl). +- Fixed playing files with PES packets longer than 2048 byte through the full +  featured DVB card (thanks to Marco Kremer for reporting this one and providing +  a test sample). diff --git a/dvbdevice.c b/dvbdevice.c index d497aaff..3a7d3264 100644 --- a/dvbdevice.c +++ b/dvbdevice.c @@ -4,7 +4,7 @@   * See the main source file 'vdr.c' for copyright information and   * how to reach the author.   * - * $Id: dvbdevice.c 1.114 2005/01/14 14:00:44 kls Exp $ + * $Id: dvbdevice.c 1.115 2005/01/16 11:59:21 kls Exp $   */  #include "dvbdevice.h" @@ -1130,12 +1130,12 @@ bool cDvbDevice::Flush(int TimeoutMs)  int cDvbDevice::PlayVideo(const uchar *Data, int Length)  { -  return write(fd_video, Data, Length); +  return WriteAllOrNothing(fd_video, Data, Length, 1000, 10);  }  int cDvbDevice::PlayAudio(const uchar *Data, int Length)  { -  return write(fd_audio, Data, Length); +  return WriteAllOrNothing(fd_audio, Data, Length, 1000, 10);  }  bool cDvbDevice::OpenDvr(void) @@ -4,7 +4,7 @@   * See the main source file 'vdr.c' for copyright information and   * how to reach the author.   * - * $Id: tools.c 1.87 2005/01/04 11:06:45 kls Exp $ + * $Id: tools.c 1.88 2005/01/16 11:47:44 kls Exp $   */  #include "tools.h" @@ -65,6 +65,30 @@ void writechar(int filedes, char c)    safe_write(filedes, &c, sizeof(c));  } +int WriteAllOrNothing(int fd, const uchar *Data, int Length, int TimeoutMs, int RetryMs) +{ +  int written = 0; +  while (Length > 0) { +        int w = write(fd, Data + written, Length); +        if (w > 0) { +           Length -= w; +           written += w; +           } +        else if (written > 0 && !FATALERRNO) { +           // we've started writing, so we must finish it! +           cTimeMs t; +           cPoller Poller(fd, true); +           Poller.Poll(RetryMs); +           if (TimeoutMs > 0 && (TimeoutMs -= t.Elapsed()) <= 0) +              break; +           } +        else +           // nothing written yet (or fatal error), so we can just return the error code: +           return w; +        } +  return written; +} +  char *strcpyrealloc(char *dest, const char *src)  {    if (src) { @@ -4,7 +4,7 @@   * See the main source file 'vdr.c' for copyright information and   * how to reach the author.   * - * $Id: tools.h 1.64 2005/01/04 11:09:51 kls Exp $ + * $Id: tools.h 1.65 2005/01/16 11:39:58 kls Exp $   */  #ifndef __TOOLS_H @@ -71,6 +71,10 @@ public:  ssize_t safe_read(int filedes, void *buffer, size_t size);  ssize_t safe_write(int filedes, const void *buffer, size_t size);  void writechar(int filedes, char c); +int WriteAllOrNothing(int fd, const uchar *Data, int Length, int TimeoutMs = 0, int RetryMs = 0); +    ///< Writes either all Data to the given file descriptor, or nothing at all. +    ///< If TimeoutMs is greater than 0, it will only retry for that long, otherwise +    ///< it will retry forever. RetryMs defines the time between two retries.  char *strcpyrealloc(char *dest, const char *src);  char *strn0cpy(char *dest, const char *src, size_t n);  char *strreplace(char *s, char c1, char c2); | 
