Skip to content
This repository has been archived by the owner on Aug 4, 2022. It is now read-only.

Commit

Permalink
Bug 677653 - part 1 - indirect libogg memory allocations through vari…
Browse files Browse the repository at this point in the history
…ables; r=glandium,rillian
  • Loading branch information
froydnj committed Mar 5, 2014
1 parent 0874c5a commit dbffe27
Show file tree
Hide file tree
Showing 8 changed files with 171 additions and 9 deletions.
1 change: 1 addition & 0 deletions layout/media/symbols.def.in
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ vpx_codec_encode
ogg_page_bos
ogg_page_granulepos
ogg_page_serialno
ogg_set_mem_functions
ogg_stream_check
ogg_stream_clear
ogg_stream_eos
Expand Down
4 changes: 1 addition & 3 deletions media/libogg/README_MOZILLA
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
The source from this directory was copied from the libogg subversion
repository using the update.sh script. The only changes made were
those applied by update.sh and the addition/update of moz.build and
Makefile.in files for the Mozilla build system.
repository using the update.sh script.

The svn revision number used was r17287.

Expand Down
4 changes: 4 additions & 0 deletions media/libogg/include/ogg/ogg.h
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,10 @@ extern int ogg_page_packets(const ogg_page *og);

extern void ogg_packet_clear(ogg_packet *op);

extern void ogg_set_mem_functions(ogg_malloc_function_type *malloc_func,
ogg_calloc_function_type *calloc_func,
ogg_realloc_function_type *realloc_func,
ogg_free_function_type *free_func);

#ifdef __cplusplus
}
Expand Down
33 changes: 27 additions & 6 deletions media/libogg/include/ogg/os_types.h
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,33 @@
#ifndef _OS_TYPES_H
#define _OS_TYPES_H

/* make it easy on the folks that want to compile the libs with a
different malloc than stdlib */
#define _ogg_malloc malloc
#define _ogg_calloc calloc
#define _ogg_realloc realloc
#define _ogg_free free
#include <stddef.h>

/* We indirect mallocs through settable-at-runtime functions to accommodate
memory reporting in the browser. */

#ifdef __cplusplus
extern "C" {
#endif

typedef void* (ogg_malloc_function_type)(size_t);
typedef void* (ogg_calloc_function_type)(size_t, size_t);
typedef void* (ogg_realloc_function_type)(void*, size_t);
typedef void (ogg_free_function_type)(void*);

extern ogg_malloc_function_type *ogg_malloc_func;
extern ogg_calloc_function_type *ogg_calloc_func;
extern ogg_realloc_function_type *ogg_realloc_func;
extern ogg_free_function_type *ogg_free_func;

#ifdef __cplusplus
}
#endif

#define _ogg_malloc ogg_malloc_func
#define _ogg_calloc ogg_calloc_func
#define _ogg_realloc ogg_realloc_func
#define _ogg_free ogg_free_func

#if defined(_WIN32)

Expand Down
102 changes: 102 additions & 0 deletions media/libogg/memory-reporting.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
commit 16362f7dc755d9a2cfb8df06db74a16fcc97e495
Author: Nathan Froyd <froydnj@mozilla.com>
Date: Wed Mar 5 10:58:29 2014 -0500

Bug 677653 - part 1 - indirect libogg memory allocations through variables

diff --git a/media/libogg/include/ogg/ogg.h b/media/libogg/include/ogg/ogg.h
index cea4ebe..cebe38e 100644
--- include/ogg/ogg.h
+++ include/ogg/ogg.h
@@ -202,6 +202,10 @@ extern int ogg_page_packets(const ogg_page *og);

extern void ogg_packet_clear(ogg_packet *op);

+extern void ogg_set_mem_functions(ogg_malloc_function_type *malloc_func,
+ ogg_calloc_function_type *calloc_func,
+ ogg_realloc_function_type *realloc_func,
+ ogg_free_function_type *free_func);

#ifdef __cplusplus
}
diff --git a/media/libogg/include/ogg/os_types.h b/media/libogg/include/ogg/os_types.h
index 2c75a20..83ed732 100644
--- include/ogg/os_types.h
+++ include/ogg/os_types.h
@@ -17,12 +17,33 @@
#ifndef _OS_TYPES_H
#define _OS_TYPES_H

-/* make it easy on the folks that want to compile the libs with a
- different malloc than stdlib */
-#define _ogg_malloc malloc
-#define _ogg_calloc calloc
-#define _ogg_realloc realloc
-#define _ogg_free free
+#include <stddef.h>
+
+/* We indirect mallocs through settable-at-runtime functions to accommodate
+ memory reporting in the browser. */
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+typedef void* (ogg_malloc_function_type)(size_t);
+typedef void* (ogg_calloc_function_type)(size_t, size_t);
+typedef void* (ogg_realloc_function_type)(void*, size_t);
+typedef void (ogg_free_function_type)(void*);
+
+extern ogg_malloc_function_type *ogg_malloc_func;
+extern ogg_calloc_function_type *ogg_calloc_func;
+extern ogg_realloc_function_type *ogg_realloc_func;
+extern ogg_free_function_type *ogg_free_func;
+
+#ifdef __cplusplus
+}
+#endif
+
+#define _ogg_malloc ogg_malloc_func
+#define _ogg_calloc ogg_calloc_func
+#define _ogg_realloc ogg_realloc_func
+#define _ogg_free ogg_free_func

#if defined(_WIN32)

diff --git a/media/libogg/src/ogg_alloc.c b/media/libogg/src/ogg_alloc.c
new file mode 100644
index 0000000..4238d7b
--- /dev/null
+++ src/ogg_alloc.c
@@ -0,0 +1,31 @@
+/********************************************************************
+ * *
+ * THIS FILE IS PART OF THE OggVorbis SOFTWARE CODEC SOURCE CODE. *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
+ * *
+ * THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2002 *
+ * by the Xiph.Org Foundation http://www.xiph.org/ *
+ * *
+ *********************************************************************/
+
+#include <stdlib.h>
+#include "ogg/os_types.h"
+
+ogg_malloc_function_type *ogg_malloc_func = malloc;
+ogg_calloc_function_type *ogg_calloc_func = calloc;
+ogg_realloc_function_type *ogg_realloc_func = realloc;
+ogg_free_function_type *ogg_free_func = free;
+
+void
+ogg_set_mem_functions(ogg_malloc_function_type *malloc_func,
+ ogg_calloc_function_type *calloc_func,
+ ogg_realloc_function_type *realloc_func,
+ ogg_free_function_type *free_func)
+{
+ ogg_malloc_func = malloc_func;
+ ogg_calloc_func = calloc_func;
+ ogg_realloc_func = realloc_func;
+ ogg_free_func = free_func;
+}
1 change: 1 addition & 0 deletions media/libogg/moz.build
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ EXPORTS.ogg += [
]

UNIFIED_SOURCES += [
'src/ogg_alloc.c',
'src/ogg_bitwise.c',
'src/ogg_framing.c',
]
Expand Down
31 changes: 31 additions & 0 deletions media/libogg/src/ogg_alloc.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/********************************************************************
* *
* THIS FILE IS PART OF THE OggVorbis SOFTWARE CODEC SOURCE CODE. *
* USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
* GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
* IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
* *
* THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2002 *
* by the Xiph.Org Foundation http://www.xiph.org/ *
* *
*********************************************************************/

#include <stdlib.h>
#include "ogg/os_types.h"

ogg_malloc_function_type *ogg_malloc_func = malloc;
ogg_calloc_function_type *ogg_calloc_func = calloc;
ogg_realloc_function_type *ogg_realloc_func = realloc;
ogg_free_function_type *ogg_free_func = free;

void
ogg_set_mem_functions(ogg_malloc_function_type *malloc_func,
ogg_calloc_function_type *calloc_func,
ogg_realloc_function_type *realloc_func,
ogg_free_function_type *free_func)
{
ogg_malloc_func = malloc_func;
ogg_calloc_func = calloc_func;
ogg_realloc_func = realloc_func;
ogg_free_func = free_func;
}
4 changes: 4 additions & 0 deletions media/libogg/update.sh
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,7 @@ cp $1/src/bitwise.c ./src/ogg_bitwise.c
cp $1/src/framing.c ./src/ogg_framing.c
cp $1/AUTHORS ./AUTHORS
patch -p0 < solaris-types.patch
# memory-reporting.patch adds ogg_alloc.c, make sure it doesn't exist to avoid
# unpleasantries.
rm -f ./src/ogg_alloc.c
patch -p0 < memory-reporting.patch

0 comments on commit dbffe27

Please sign in to comment.