diff options
author | Klaus Schmidinger <vdr@tvdr.de> | 2015-09-10 13:20:21 +0200 |
---|---|---|
committer | Klaus Schmidinger <vdr@tvdr.de> | 2015-09-10 13:20:21 +0200 |
commit | 0f18bd0a6a9ce0e62fc9bcbc4339f63eee2855fc (patch) | |
tree | c9b41dae329b8caa5a7d01d069844d0cfc489685 | |
parent | 14f97d0f2a84aaca2b13638db406e629ceb4785f (diff) | |
download | vdr-0f18bd0a6a9ce0e62fc9bcbc4339f63eee2855fc.tar.gz vdr-0f18bd0a6a9ce0e62fc9bcbc4339f63eee2855fc.tar.bz2 |
Fixed a possible stack overflow in cListBase::Sort()
-rw-r--r-- | CONTRIBUTORS | 1 | ||||
-rw-r--r-- | HISTORY | 1 | ||||
-rw-r--r-- | tools.c | 7 |
3 files changed, 7 insertions, 2 deletions
diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 91eccfbc..b4ac3415 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -714,6 +714,7 @@ Oliver Endriss <o.endriss@gmx.de> to detect the frame type for suggesting to ignore channels with an RID that is not 0 when checking for obsolete channels + for fixing a possible stack overflow in cListBase::Sort() Reinhard Walter Buchner <rw.buchner@freenet.de> for adding some satellites to 'sources.conf' @@ -8813,3 +8813,4 @@ Video Disk Recorder Revision History to Thomas Reufer). - Skins can now implement cSkinDisplayMenu::MenuOrientation() to display horizontal menus (thanks to Stefan Braun). +- Fixed a possible stack overflow in cListBase::Sort() (thanks to Oliver Endriss). @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: tools.c 4.3 2015/09/06 10:47:05 kls Exp $ + * $Id: tools.c 4.4 2015/09/10 13:17:55 kls Exp $ */ #include "tools.h" @@ -2253,7 +2253,9 @@ static int CompareListObjects(const void *a, const void *b) void cListBase::Sort(void) { int n = Count(); - cListObject *a[n]; + cListObject **a = MALLOC(cListObject *, n); + if (a == NULL) + return; cListObject *object = objects; int i = 0; while (object && i < n) { @@ -2267,6 +2269,7 @@ void cListBase::Sort(void) count--; Add(a[i]); } + free(a); } // --- cHashBase ------------------------------------------------------------- |