diff options
| author | Klaus Schmidinger <vdr@tvdr.de> | 2004-10-23 13:40:56 +0200 | 
|---|---|---|
| committer | Klaus Schmidinger <vdr@tvdr.de> | 2004-10-23 13:40:56 +0200 | 
| commit | f0a7e75d8ecee71469ca6b8aa21b22bde909f599 (patch) | |
| tree | 94221ad077e2cb2cbb8c14a4fa7b53d666dd7b97 | |
| parent | af6b8ff5330851bd12bb1b011fdbd29fead5bf3c (diff) | |
| download | vdr-f0a7e75d8ecee71469ca6b8aa21b22bde909f599.tar.gz vdr-f0a7e75d8ecee71469ca6b8aa21b22bde909f599.tar.bz2 | |
Taking the complete size of available data into account when deciding whether to clear the transfer buffer to avoid overflows
| -rw-r--r-- | CONTRIBUTORS | 2 | ||||
| -rw-r--r-- | HISTORY | 2 | ||||
| -rw-r--r-- | transfer.c | 4 | 
3 files changed, 6 insertions, 2 deletions
| diff --git a/CONTRIBUTORS b/CONTRIBUTORS index ca19f561..585c4052 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -873,6 +873,8 @@ Reinhard Nissl <rnissl@gmx.de>   for suggesting to make sure the OSD reports oeWrongAlignment errors before any   oeAreasOverlap error   for reporting a a crash in the time search mechanism + for taking the complete size of available data into account when deciding whether + to clear the transfer buffer to avoid overflows  Richard Robson <richard_robson@beeb.net>   for reporting freezing replay if a timer starts while in Transfer Mode from the @@ -3052,3 +3052,5 @@ Video Disk Recorder Revision History  - Removed the usleep() call from cDvbPlayer::Action() to make VDR run on NPTL    systems (thanks to Alfred Zastrow). The NPTL check at startup has also been    removed. +- Taking the complete size of available data into account when deciding whether +  to clear the transfer buffer to avoid overflows (thanks to Reinhard Nissl). @@ -4,7 +4,7 @@   * See the main source file 'vdr.c' for copyright information and   * how to reach the author.   * - * $Id: transfer.c 1.17 2004/10/16 09:22:58 kls Exp $ + * $Id: transfer.c 1.18 2004/10/23 13:35:08 kls Exp $   */  #include "transfer.h" @@ -65,7 +65,7 @@ void cTransfer::Action(void)          int Count;          uchar *b = ringBuffer->Get(Count);          if (b) { -           if (Count > TRANSFERBUFSIZE * 2 / 3) { +           if (ringBuffer->Available() > TRANSFERBUFSIZE * 9 / 10) {                // If the buffer runs full, we have no chance of ever catching up                // since the data comes in at the same rate as it goes out (it's "live").                // So let's clear the buffer instead of suffering from permanent | 
