[MPlayer-cvslog] r21800 - in branches/1.0rc1/stream/realrtsp: asmrp.c asmrp.h real.c

rtogni subversion at mplayerhq.hu
Sun Dec 31 14:46:17 CET 2006


Author: rtogni
Date: Sun Dec 31 14:46:17 2006
New Revision: 21800

Modified:
   branches/1.0rc1/stream/realrtsp/asmrp.c
   branches/1.0rc1/stream/realrtsp/asmrp.h
   branches/1.0rc1/stream/realrtsp/real.c

Log:
Fix potential buffer overflow in asm rules matching code


Modified: branches/1.0rc1/stream/realrtsp/asmrp.c
==============================================================================
--- branches/1.0rc1/stream/realrtsp/asmrp.c	(original)
+++ branches/1.0rc1/stream/realrtsp/asmrp.c	Sun Dec 31 14:46:17 2006
@@ -40,6 +40,7 @@
 #include <stdlib.h>
 #include <stdio.h>
 #include <string.h>
+#include "asmrp.h"
 
 /*
 #define LOG
@@ -645,8 +646,10 @@
 #ifdef LOG
       printf ("rule #%d is true\n", rule_num);
 #endif
-      matches[num_matches] = rule_num;
-      num_matches++;
+      if(num_matches < MAX_RULEMATCHES - 1)
+        matches[num_matches++] = rule_num;
+      else
+        printf("Ignoring matched asm rule %d, too many matched rules.\n", rule_num);
     }
 
     rule_num++;

Modified: branches/1.0rc1/stream/realrtsp/asmrp.h
==============================================================================
--- branches/1.0rc1/stream/realrtsp/asmrp.h	(original)
+++ branches/1.0rc1/stream/realrtsp/asmrp.h	Sun Dec 31 14:46:17 2006
@@ -40,6 +40,8 @@
 #ifndef HAVE_ASMRP_H
 #define HAVE_ASMRP_H
 
+#define MAX_RULEMATCHES 16
+
 int asmrp_match (const char *rules, int bandwidth, int *matches) ;
 
 #endif

Modified: branches/1.0rc1/stream/realrtsp/real.c
==============================================================================
--- branches/1.0rc1/stream/realrtsp/real.c	(original)
+++ branches/1.0rc1/stream/realrtsp/real.c	Sun Dec 31 14:46:17 2006
@@ -271,7 +271,7 @@
     int j=0;
     int n;
     char b[64];
-    int rulematches[16];
+    int rulematches[MAX_RULEMATCHES];
 
 #ifdef LOG
     printf("calling asmrp_match with:\n%s\n%u\n", desc->stream[i]->asm_rule_book, bandwidth);



More information about the MPlayer-cvslog mailing list