Fix a couple 'inlining failed' warning messages.
authorErik de Castro Lopo <erikd@mega-nerd.com>
Sun, 26 Feb 2012 09:00:36 +0000 (20:00 +1100)
committerErik de Castro Lopo <erikd@mega-nerd.com>
Sun, 26 Feb 2012 09:00:36 +0000 (20:00 +1100)
include/share/alloc.h
src/libFLAC/include/private/memory.h
src/libFLAC/memory.c
src/share/grabbag/Makefile.am
src/share/grabbag/alloc.c [new file with mode: 0644]

index a74d070..8a53bbe 100644 (file)
@@ -110,14 +110,7 @@ static inline void *safe_malloc_add_4op_(size_t size1, size_t size2, size_t size
        return safe_malloc_(size4);
 }
 
-static inline void *safe_malloc_mul_2op_(size_t size1, size_t size2)
-{
-       if(!size1 || !size2)
-               return malloc(1); /* malloc(0) is undefined; FLAC src convention is to always allocate */
-       if(size1 > SIZE_MAX / size2)
-               return 0;
-       return malloc(size1*size2);
-}
+void *safe_malloc_mul_2op_(size_t size1, size_t size2) ;
 
 static inline void *safe_malloc_mul_3op_(size_t size1, size_t size2, size_t size3)
 {
index f37e516..fecba6f 100644 (file)
@@ -52,5 +52,6 @@ FLAC__bool FLAC__memory_alloc_aligned_unsigned_array(size_t elements, unsigned *
 #ifndef FLAC__INTEGER_ONLY_LIBRARY
 FLAC__bool FLAC__memory_alloc_aligned_real_array(size_t elements, FLAC__real **unaligned_pointer, FLAC__real **aligned_pointer);
 #endif
+void *safe_malloc_mul_2op_(size_t size1, size_t size2);
 
 #endif
index eb26279..8870efe 100644 (file)
@@ -219,3 +219,12 @@ FLAC__bool FLAC__memory_alloc_aligned_real_array(size_t elements, FLAC__real **u
 }
 
 #endif
+
+void *safe_malloc_mul_2op_(size_t size1, size_t size2)
+{
+       if(!size1 || !size2)
+               return malloc(1); /* malloc(0) is undefined; FLAC src convention is to always allocate */
+       if(size1 > SIZE_MAX / size2)
+               return 0;
+       return malloc(size1*size2);
+}
index 879b155..c59ddca 100644 (file)
@@ -7,6 +7,7 @@ INCLUDES = -I$(top_srcdir)/include
 noinst_LTLIBRARIES = libgrabbag.la
 
 libgrabbag_la_SOURCES = \
+       alloc.c \
        cuesheet.c \
        file.c \
        picture.c \
diff --git a/src/share/grabbag/alloc.c b/src/share/grabbag/alloc.c
new file mode 100644 (file)
index 0000000..53381b8
--- /dev/null
@@ -0,0 +1,43 @@
+/* alloc - Convenience routines for safely allocating memory
+ * Copyright (C) 2007,2008,2009  Josh Coalson
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * - Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * - Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * - Neither the name of the Xiph.org Foundation nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+ * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+ * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <stdlib.h>
+
+#include "share/alloc.h"
+
+void *safe_malloc_mul_2op_(size_t size1, size_t size2)
+{
+       if(!size1 || !size2)
+               return malloc(1); /* malloc(0) is undefined; FLAC src convention is to always allocate */
+       if(size1 > SIZE_MAX / size2)
+               return 0;
+       return malloc(size1*size2);
+}