]> git.sesse.net Git - vlc/commitdiff
Fix stack overflow in debug code: use heap for large allocations.
authorRémi Denis-Courmont <rem@videolan.org>
Fri, 28 Dec 2007 16:16:55 +0000 (16:16 +0000)
committerRémi Denis-Courmont <rem@videolan.org>
Fri, 28 Dec 2007 16:16:55 +0000 (16:16 +0000)
modules/access/file.c

index f7e46c3dd54662fc22bff051f52fc31f4d736be2..eceb4cc542d2b5d21d3156c7c7c7c93ec9efca25 100644 (file)
@@ -203,7 +203,6 @@ static int Open( vlc_object_t *p_this )
         p_sys->b_seekable = VLC_FALSE;
 
 # ifdef HAVE_MMAP
-# ifndef __APPLE__
     p_sys->pagemask = sysconf (_SC_PAGE_SIZE) - 1;
 
     /* Autodetect mmap() support */
@@ -224,7 +223,6 @@ static int Open( vlc_object_t *p_this )
     else
         msg_Dbg (p_this, "mmap disabled (non regular file)");
 # endif
-# endif
 #else
     p_sys->b_seekable = !b_stdin;
 # warning File size not known!
@@ -440,7 +438,7 @@ static block_t *mmapBlock (access_t *p_access)
 
 #ifndef NDEBUG
     /* Compare normal I/O with memory mapping */
-    char buf[block->self.i_buffer];
+    char *buf = malloc (block->self.i_buffer);
     ssize_t i_read = read (p_sys->fd, buf, block->self.i_buffer);
 
     if (i_read != (ssize_t)block->self.i_buffer)
@@ -448,6 +446,7 @@ static block_t *mmapBlock (access_t *p_access)
                  (unsigned)block->self.i_buffer);
     if (memcmp (buf, block->self.p_buffer, block->self.i_buffer))
         msg_Err (p_access, "inconsistent data buffer");
+    free (buf);
 #endif
 
     return &block->self;