From 77e13af5e317d5950d647f7e7ce002d651ff947a Mon Sep 17 00:00:00 2001 From: Koen Kooi Date: Fri, 2 Oct 2009 16:50:18 +0200 Subject: glib-2.0: update to 2.22.1 --- conf/checksums.ini | 4 + recipes/glib-2.0/bug-556515.patch | 35 ++++++++ .../glib-2.0/glib-2.0-2.22.0/atomic-thumb.patch | 42 --------- recipes/glib-2.0/glib-2.0-2.22.0/bug-556515.patch | 34 -------- .../glib-2.0-2.22.0/configure-libtool.patch | 34 -------- recipes/glib-2.0/glib-2.0-2.22.0/gobject.patch | 99 ---------------------- .../glib-2.0/glib-2.0-2.22.1/atomic-thumb.patch | 42 +++++++++ recipes/glib-2.0/glib-2.0-2.22.1/bug-556515.patch | 34 ++++++++ .../glib-2.0-2.22.1/configure-libtool.patch | 34 ++++++++ recipes/glib-2.0/glib-2.0-2.22.1/gobject.patch | 99 ++++++++++++++++++++++ recipes/glib-2.0/glib-2.0-native_2.22.0.bb | 40 --------- recipes/glib-2.0/glib-2.0-native_2.22.1.bb | 40 +++++++++ recipes/glib-2.0/glib-2.0_2.22.0.bb | 15 ---- recipes/glib-2.0/glib-2.0_2.22.1.bb | 15 ++++ 14 files changed, 303 insertions(+), 264 deletions(-) create mode 100644 recipes/glib-2.0/bug-556515.patch delete mode 100644 recipes/glib-2.0/glib-2.0-2.22.0/atomic-thumb.patch delete mode 100644 recipes/glib-2.0/glib-2.0-2.22.0/bug-556515.patch delete mode 100644 recipes/glib-2.0/glib-2.0-2.22.0/configure-libtool.patch delete mode 100644 recipes/glib-2.0/glib-2.0-2.22.0/gobject.patch create mode 100644 recipes/glib-2.0/glib-2.0-2.22.1/atomic-thumb.patch create mode 100644 recipes/glib-2.0/glib-2.0-2.22.1/bug-556515.patch create mode 100644 recipes/glib-2.0/glib-2.0-2.22.1/configure-libtool.patch create mode 100644 recipes/glib-2.0/glib-2.0-2.22.1/gobject.patch delete mode 100644 recipes/glib-2.0/glib-2.0-native_2.22.0.bb create mode 100644 recipes/glib-2.0/glib-2.0-native_2.22.1.bb delete mode 100644 recipes/glib-2.0/glib-2.0_2.22.0.bb create mode 100644 recipes/glib-2.0/glib-2.0_2.22.1.bb diff --git a/conf/checksums.ini b/conf/checksums.ini index 949dbf2159..bb61d09889 100644 --- a/conf/checksums.ini +++ b/conf/checksums.ini @@ -8270,6 +8270,10 @@ sha256=8b4750523a07102c90c7eecf1743f852ce2aadcb7a43284a9e06baf70beb9b8a md5=e0bc5b08d467cc3763550923087772d3 sha256=f77cda95fa7cea5e7ad189ac18a165bb3886a66bc5f97c6398a9e5dc16c8a671 +[http://ftp.gnome.org/pub/GNOME/sources/glib/2.22/glib-2.22.1.tar.bz2] +md5=12297a7da577321647b38ade0593cb3c +sha256=4898d340c830a5903115412ec5b95eb03b410efdfb1c5316d36f12f8be85577d + [ftp://ftp.gtk.org/pub/gtk/v2.4/glib-2.4.6.tar.bz2] md5=a45db7d82480da431f6cd00ea041a534 sha256=d2ca79bac06a625d9276b48492c2c1caccf7f8962f9b331b39796391013e72f2 diff --git a/recipes/glib-2.0/bug-556515.patch b/recipes/glib-2.0/bug-556515.patch new file mode 100644 index 0000000000..0af15a6f8f --- /dev/null +++ b/recipes/glib-2.0/bug-556515.patch @@ -0,0 +1,35 @@ +https://bugzilla.gnome.org/show_bug.cgi?id=556515 - g_object_unref race condition + + +diff --git /tmp/gobject.c glib-2.21.6/gobject/gobject.c +index 454d8c2..75f479c 100644 +--- /tmp/gobject.c ++++ glib-2.21.6/gobject/gobject.c +@@ -2380,11 +2380,12 @@ g_object_unref (gpointer _object) + old_ref = g_atomic_int_get (&object->ref_count); + if (old_ref > 1) + { ++ gboolean do_toggle_ref_notify = (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)); + if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) + goto retry_atomic_decrement1; + + /* if we went from 2->1 we need to notify toggle refs if any */ +- if (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)) ++ if (do_toggle_ref_notify) + toggle_refs_notify (object, TRUE); + } + else +@@ -2397,11 +2398,12 @@ g_object_unref (gpointer _object) + old_ref = g_atomic_int_get ((int *)&object->ref_count); + if (old_ref > 1) + { ++ gboolean do_toggle_ref_notify = (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)); + if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) + goto retry_atomic_decrement2; + + /* if we went from 2->1 we need to notify toggle refs if any */ +- if (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)) ++ if (do_toggle_ref_notify) + toggle_refs_notify (object, TRUE); + + return; diff --git a/recipes/glib-2.0/glib-2.0-2.22.0/atomic-thumb.patch b/recipes/glib-2.0/glib-2.0-2.22.0/atomic-thumb.patch deleted file mode 100644 index d7aa08821f..0000000000 --- a/recipes/glib-2.0/glib-2.0-2.22.0/atomic-thumb.patch +++ /dev/null @@ -1,42 +0,0 @@ -# gatomic.c uses SWP, which doesn't work in Thumb mode. -# Put that source file into a separate convenience library which is always built as ARM. - -Index: glib-2.18.1/glib/Makefile.am -=================================================================== ---- glib-2.18.1/glib/Makefile.am 2008-09-18 00:33:57.000000000 +0200 -+++ glib-2.18.1/glib/Makefile.am 2008-11-08 10:13:27.000000000 +0100 -@@ -80,6 +80,7 @@ - galiasdef.c - - lib_LTLIBRARIES = libglib-2.0.la -+noinst_LTLIBRARIES = libgatomic.la - - if OS_WIN32_AND_DLL_COMPILATION - if MS_LIB_AVAILABLE -@@ -96,10 +97,14 @@ - uninstall-ms-lib: - $(uninstall_ms_lib_cmd) - -+libgatomic_la_CFLAGS = $(CFLAGS) -mno-thumb -+ -+libgatomic_la_SOURCES = \ -+ gatomic.c -+ - libglib_2_0_la_SOURCES = \ - garray.c \ - gasyncqueue.c \ -- gatomic.c \ - gbacktrace.c \ - gbase64.c \ - gbookmarkfile.c \ -@@ -286,8 +291,8 @@ - pcre_inc = - endif - --libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@ $(pcre_lib) --libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ $(glib_win32_res) $(glib_def) -+libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@ $(pcre_lib) libgatomic.la -+libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ $(glib_win32_res) $(glib_def) libgatomic.la - - libglib_2_0_la_LDFLAGS = \ - $(glib_win32_res_ldflag) \ diff --git a/recipes/glib-2.0/glib-2.0-2.22.0/bug-556515.patch b/recipes/glib-2.0/glib-2.0-2.22.0/bug-556515.patch deleted file mode 100644 index b03a0afb3f..0000000000 --- a/recipes/glib-2.0/glib-2.0-2.22.0/bug-556515.patch +++ /dev/null @@ -1,34 +0,0 @@ ---- /tmp/gobject.c 2009-09-23 10:02:19.000000000 +0200 -+++ glib-2.21.6/gobject/gobject.c 2009-09-23 14:52:46.000000000 +0200 -@@ -2377,14 +2376,15 @@ - - /* here we want to atomically do: if (ref_count>1) { ref_count--; return; } */ - retry_atomic_decrement1: -- old_ref = g_atomic_int_get (&object->ref_count); -+ old_ref = g_atomic_int_get ((int *)&object->ref_count); - if (old_ref > 1) - { -+ gboolean do_toggle_ref_notify = (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)); - if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) - goto retry_atomic_decrement1; - - /* if we went from 2->1 we need to notify toggle refs if any */ -- if (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)) -+ if (do_toggle_ref_notify) - toggle_refs_notify (object, TRUE); - } - else -@@ -2397,11 +2397,12 @@ - old_ref = g_atomic_int_get ((int *)&object->ref_count); - if (old_ref > 1) - { -+ gboolean do_toggle_ref_notify = (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)); - if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) - goto retry_atomic_decrement2; - - /* if we went from 2->1 we need to notify toggle refs if any */ -- if (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)) -+ if (do_toggle_ref_notify) - toggle_refs_notify (object, TRUE); - - return; diff --git a/recipes/glib-2.0/glib-2.0-2.22.0/configure-libtool.patch b/recipes/glib-2.0/glib-2.0-2.22.0/configure-libtool.patch deleted file mode 100644 index 3ba79b8986..0000000000 --- a/recipes/glib-2.0/glib-2.0-2.22.0/configure-libtool.patch +++ /dev/null @@ -1,34 +0,0 @@ -# Poky renames libtool to $host_alias-libtool. -# ./$host_alias-libtool isn't created until after configure runs with libtool >= 2.2.2 -# so we can't call # it at this point. We can safely assume a version is available -# from PATH though - ---- glib-2.12.10/configure.in.orig 2006-06-05 13:34:08.000000000 +0100 -+++ glib-2.12.10/configure.in 2006-06-05 13:34:36.000000000 +0100 -@@ -1174,7 +1174,7 @@ - G_MODULE_LDFLAGS= - else - export SED -- G_MODULE_LDFLAGS=`(./libtool --config; echo eval echo \\$export_dynamic_flag_spec) | sh` -+ G_MODULE_LDFLAGS=`($host_alias-libtool --config; echo eval echo \\$export_dynamic_flag_spec) | sh` - fi - dnl G_MODULE_IMPL= don't reset, so cmd-line can override - G_MODULE_NEED_USCORE=0 -@@ -1265,7 +1265,7 @@ - LDFLAGS="$LDFLAGS $G_MODULE_LDFLAGS" - dnl *** check for OSF1/5.0 RTLD_GLOBAL brokenness - echo "void glib_plugin_test(void) { }" > plugin.c -- ${SHELL} ./libtool --mode=compile ${CC} -shared \ -+ ${SHELL} $host_alias-libtool --mode=compile ${CC} -shared \ - -export-dynamic -o plugin.o plugin.c 2>&1 >/dev/null - AC_CACHE_CHECK([for RTLD_GLOBAL brokenness], - glib_cv_rtldglobal_broken,[ -@@ -1339,7 +1339,7 @@ - - AC_MSG_CHECKING(for the suffix of shared libraries) - export SED --shrext_cmds=`./libtool --config | grep '^shrext_cmds='` -+shrext_cmds=`$host_alias-libtool --config | grep '^shrext_cmds='` - eval $shrext_cmds - module=yes eval std_shrext=$shrext_cmds - # chop the initial dot diff --git a/recipes/glib-2.0/glib-2.0-2.22.0/gobject.patch b/recipes/glib-2.0/glib-2.0-2.22.0/gobject.patch deleted file mode 100644 index d9c7b7e791..0000000000 --- a/recipes/glib-2.0/glib-2.0-2.22.0/gobject.patch +++ /dev/null @@ -1,99 +0,0 @@ -diff --git a/gobject/gobject.c b/gobject/gobject.c -index 454d8c2..60c502b 100644 ---- a/gobject/gobject.c -+++ b/gobject/gobject.c -@@ -182,7 +182,7 @@ static GQuark quark_closure_array = 0; - static GQuark quark_weak_refs = 0; - static GQuark quark_toggle_refs = 0; - static GParamSpecPool *pspec_pool = NULL; --static GObjectNotifyContext property_notify_context = { 0, }; -+static GObjectNotifyContext property_notify_context = { G_STATIC_PRIVATE_INIT, }; - static gulong gobject_signals[LAST_SIGNAL] = { 0, }; - static guint (*floating_flag_handler) (GObject*, gint) = object_floating_flag_handler; - G_LOCK_DEFINE_STATIC (construction_mutex); -@@ -321,7 +321,6 @@ g_object_do_class_init (GObjectClass *class) - quark_weak_refs = g_quark_from_static_string ("GObject-weak-references"); - quark_toggle_refs = g_quark_from_static_string ("GObject-toggle-references"); - pspec_pool = g_param_spec_pool_new (TRUE); -- property_notify_context.quark_notify_queue = g_quark_from_static_string ("GObject-notify-queue"); - property_notify_context.dispatcher = g_object_notify_dispatcher; - - class->constructor = g_object_constructor; -diff --git a/gobject/gobjectnotifyqueue.c b/gobject/gobjectnotifyqueue.c -index 1d5787b..173a8ed 100644 ---- a/gobject/gobjectnotifyqueue.c -+++ b/gobject/gobjectnotifyqueue.c -@@ -38,7 +38,7 @@ typedef void (*GObjectNotifyQueueDispatcher) (GObject *object, - /* --- structures --- */ - struct _GObjectNotifyContext - { -- GQuark quark_notify_queue; -+ GStaticPrivate key_notify_objects; - GObjectNotifyQueueDispatcher dispatcher; - GTrashStack *_nqueue_trash; /* unused */ - }; -@@ -68,16 +68,27 @@ static inline GObjectNotifyQueue* - g_object_notify_queue_freeze (GObject *object, - GObjectNotifyContext *context) - { -+ GHashTable *objects; - GObjectNotifyQueue *nqueue; - -- nqueue = g_datalist_id_get_data (&object->qdata, context->quark_notify_queue); -+ objects = g_static_private_get (&context->key_notify_objects); -+ if (!objects) -+ { -+ objects = g_hash_table_new_full (g_direct_hash, g_direct_equal, -+ NULL, g_object_notify_queue_free); -+ -+ g_static_private_set (&context->key_notify_objects, objects, -+ (GDestroyNotify) g_hash_table_unref); -+ } -+ -+ nqueue = g_hash_table_lookup (objects, object); - if (!nqueue) - { - nqueue = (void*) g_list_alloc (); - memset (nqueue, 0, sizeof (*nqueue)); - nqueue->context = context; -- g_datalist_id_set_data_full (&object->qdata, context->quark_notify_queue, -- nqueue, g_object_notify_queue_free); -+ -+ g_hash_table_insert (objects, object, nqueue); - } - - g_return_val_if_fail (nqueue->freeze_count < 65535, nqueue); -@@ -94,6 +105,7 @@ g_object_notify_queue_thaw (GObject *object, - GParamSpec *pspecs_mem[16], **pspecs, **free_me = NULL; - GSList *slist; - guint n_pspecs = 0; -+ GHashTable *objects; - - g_return_if_fail (nqueue->freeze_count > 0); - -@@ -119,7 +131,10 @@ g_object_notify_queue_thaw (GObject *object, - - pspecs[n_pspecs++] = pspec; - } -- g_datalist_id_set_data (&object->qdata, context->quark_notify_queue, NULL); -+ objects = g_static_private_get (&context->key_notify_objects); -+ g_hash_table_remove (objects, object); -+ if (g_hash_table_size (objects) == 0) -+ g_static_private_set (&context->key_notify_objects, NULL, NULL); - - if (n_pspecs) - context->dispatcher (object, n_pspecs, pspecs); -@@ -162,7 +177,13 @@ static inline GObjectNotifyQueue* - g_object_notify_queue_from_object (GObject *object, - GObjectNotifyContext *context) - { -- return g_datalist_id_get_data (&object->qdata, context->quark_notify_queue); -+ GHashTable *objects; -+ -+ objects = g_static_private_get (&context->key_notify_objects); -+ if (objects == NULL) -+ return NULL; -+ -+ return g_hash_table_lookup (objects, object); - } - diff --git a/recipes/glib-2.0/glib-2.0-2.22.1/atomic-thumb.patch b/recipes/glib-2.0/glib-2.0-2.22.1/atomic-thumb.patch new file mode 100644 index 0000000000..d7aa08821f --- /dev/null +++ b/recipes/glib-2.0/glib-2.0-2.22.1/atomic-thumb.patch @@ -0,0 +1,42 @@ +# gatomic.c uses SWP, which doesn't work in Thumb mode. +# Put that source file into a separate convenience library which is always built as ARM. + +Index: glib-2.18.1/glib/Makefile.am +=================================================================== +--- glib-2.18.1/glib/Makefile.am 2008-09-18 00:33:57.000000000 +0200 ++++ glib-2.18.1/glib/Makefile.am 2008-11-08 10:13:27.000000000 +0100 +@@ -80,6 +80,7 @@ + galiasdef.c + + lib_LTLIBRARIES = libglib-2.0.la ++noinst_LTLIBRARIES = libgatomic.la + + if OS_WIN32_AND_DLL_COMPILATION + if MS_LIB_AVAILABLE +@@ -96,10 +97,14 @@ + uninstall-ms-lib: + $(uninstall_ms_lib_cmd) + ++libgatomic_la_CFLAGS = $(CFLAGS) -mno-thumb ++ ++libgatomic_la_SOURCES = \ ++ gatomic.c ++ + libglib_2_0_la_SOURCES = \ + garray.c \ + gasyncqueue.c \ +- gatomic.c \ + gbacktrace.c \ + gbase64.c \ + gbookmarkfile.c \ +@@ -286,8 +291,8 @@ + pcre_inc = + endif + +-libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@ $(pcre_lib) +-libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ $(glib_win32_res) $(glib_def) ++libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@ $(pcre_lib) libgatomic.la ++libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ $(glib_win32_res) $(glib_def) libgatomic.la + + libglib_2_0_la_LDFLAGS = \ + $(glib_win32_res_ldflag) \ diff --git a/recipes/glib-2.0/glib-2.0-2.22.1/bug-556515.patch b/recipes/glib-2.0/glib-2.0-2.22.1/bug-556515.patch new file mode 100644 index 0000000000..b03a0afb3f --- /dev/null +++ b/recipes/glib-2.0/glib-2.0-2.22.1/bug-556515.patch @@ -0,0 +1,34 @@ +--- /tmp/gobject.c 2009-09-23 10:02:19.000000000 +0200 ++++ glib-2.21.6/gobject/gobject.c 2009-09-23 14:52:46.000000000 +0200 +@@ -2377,14 +2376,15 @@ + + /* here we want to atomically do: if (ref_count>1) { ref_count--; return; } */ + retry_atomic_decrement1: +- old_ref = g_atomic_int_get (&object->ref_count); ++ old_ref = g_atomic_int_get ((int *)&object->ref_count); + if (old_ref > 1) + { ++ gboolean do_toggle_ref_notify = (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)); + if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) + goto retry_atomic_decrement1; + + /* if we went from 2->1 we need to notify toggle refs if any */ +- if (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)) ++ if (do_toggle_ref_notify) + toggle_refs_notify (object, TRUE); + } + else +@@ -2397,11 +2397,12 @@ + old_ref = g_atomic_int_get ((int *)&object->ref_count); + if (old_ref > 1) + { ++ gboolean do_toggle_ref_notify = (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)); + if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) + goto retry_atomic_decrement2; + + /* if we went from 2->1 we need to notify toggle refs if any */ +- if (old_ref == 2 && OBJECT_HAS_TOGGLE_REF (object)) ++ if (do_toggle_ref_notify) + toggle_refs_notify (object, TRUE); + + return; diff --git a/recipes/glib-2.0/glib-2.0-2.22.1/configure-libtool.patch b/recipes/glib-2.0/glib-2.0-2.22.1/configure-libtool.patch new file mode 100644 index 0000000000..3ba79b8986 --- /dev/null +++ b/recipes/glib-2.0/glib-2.0-2.22.1/configure-libtool.patch @@ -0,0 +1,34 @@ +# Poky renames libtool to $host_alias-libtool. +# ./$host_alias-libtool isn't created until after configure runs with libtool >= 2.2.2 +# so we can't call # it at this point. We can safely assume a version is available +# from PATH though + +--- glib-2.12.10/configure.in.orig 2006-06-05 13:34:08.000000000 +0100 ++++ glib-2.12.10/configure.in 2006-06-05 13:34:36.000000000 +0100 +@@ -1174,7 +1174,7 @@ + G_MODULE_LDFLAGS= + else + export SED +- G_MODULE_LDFLAGS=`(./libtool --config; echo eval echo \\$export_dynamic_flag_spec) | sh` ++ G_MODULE_LDFLAGS=`($host_alias-libtool --config; echo eval echo \\$export_dynamic_flag_spec) | sh` + fi + dnl G_MODULE_IMPL= don't reset, so cmd-line can override + G_MODULE_NEED_USCORE=0 +@@ -1265,7 +1265,7 @@ + LDFLAGS="$LDFLAGS $G_MODULE_LDFLAGS" + dnl *** check for OSF1/5.0 RTLD_GLOBAL brokenness + echo "void glib_plugin_test(void) { }" > plugin.c +- ${SHELL} ./libtool --mode=compile ${CC} -shared \ ++ ${SHELL} $host_alias-libtool --mode=compile ${CC} -shared \ + -export-dynamic -o plugin.o plugin.c 2>&1 >/dev/null + AC_CACHE_CHECK([for RTLD_GLOBAL brokenness], + glib_cv_rtldglobal_broken,[ +@@ -1339,7 +1339,7 @@ + + AC_MSG_CHECKING(for the suffix of shared libraries) + export SED +-shrext_cmds=`./libtool --config | grep '^shrext_cmds='` ++shrext_cmds=`$host_alias-libtool --config | grep '^shrext_cmds='` + eval $shrext_cmds + module=yes eval std_shrext=$shrext_cmds + # chop the initial dot diff --git a/recipes/glib-2.0/glib-2.0-2.22.1/gobject.patch b/recipes/glib-2.0/glib-2.0-2.22.1/gobject.patch new file mode 100644 index 0000000000..d9c7b7e791 --- /dev/null +++ b/recipes/glib-2.0/glib-2.0-2.22.1/gobject.patch @@ -0,0 +1,99 @@ +diff --git a/gobject/gobject.c b/gobject/gobject.c +index 454d8c2..60c502b 100644 +--- a/gobject/gobject.c ++++ b/gobject/gobject.c +@@ -182,7 +182,7 @@ static GQuark quark_closure_array = 0; + static GQuark quark_weak_refs = 0; + static GQuark quark_toggle_refs = 0; + static GParamSpecPool *pspec_pool = NULL; +-static GObjectNotifyContext property_notify_context = { 0, }; ++static GObjectNotifyContext property_notify_context = { G_STATIC_PRIVATE_INIT, }; + static gulong gobject_signals[LAST_SIGNAL] = { 0, }; + static guint (*floating_flag_handler) (GObject*, gint) = object_floating_flag_handler; + G_LOCK_DEFINE_STATIC (construction_mutex); +@@ -321,7 +321,6 @@ g_object_do_class_init (GObjectClass *class) + quark_weak_refs = g_quark_from_static_string ("GObject-weak-references"); + quark_toggle_refs = g_quark_from_static_string ("GObject-toggle-references"); + pspec_pool = g_param_spec_pool_new (TRUE); +- property_notify_context.quark_notify_queue = g_quark_from_static_string ("GObject-notify-queue"); + property_notify_context.dispatcher = g_object_notify_dispatcher; + + class->constructor = g_object_constructor; +diff --git a/gobject/gobjectnotifyqueue.c b/gobject/gobjectnotifyqueue.c +index 1d5787b..173a8ed 100644 +--- a/gobject/gobjectnotifyqueue.c ++++ b/gobject/gobjectnotifyqueue.c +@@ -38,7 +38,7 @@ typedef void (*GObjectNotifyQueueDispatcher) (GObject *object, + /* --- structures --- */ + struct _GObjectNotifyContext + { +- GQuark quark_notify_queue; ++ GStaticPrivate key_notify_objects; + GObjectNotifyQueueDispatcher dispatcher; + GTrashStack *_nqueue_trash; /* unused */ + }; +@@ -68,16 +68,27 @@ static inline GObjectNotifyQueue* + g_object_notify_queue_freeze (GObject *object, + GObjectNotifyContext *context) + { ++ GHashTable *objects; + GObjectNotifyQueue *nqueue; + +- nqueue = g_datalist_id_get_data (&object->qdata, context->quark_notify_queue); ++ objects = g_static_private_get (&context->key_notify_objects); ++ if (!objects) ++ { ++ objects = g_hash_table_new_full (g_direct_hash, g_direct_equal, ++ NULL, g_object_notify_queue_free); ++ ++ g_static_private_set (&context->key_notify_objects, objects, ++ (GDestroyNotify) g_hash_table_unref); ++ } ++ ++ nqueue = g_hash_table_lookup (objects, object); + if (!nqueue) + { + nqueue = (void*) g_list_alloc (); + memset (nqueue, 0, sizeof (*nqueue)); + nqueue->context = context; +- g_datalist_id_set_data_full (&object->qdata, context->quark_notify_queue, +- nqueue, g_object_notify_queue_free); ++ ++ g_hash_table_insert (objects, object, nqueue); + } + + g_return_val_if_fail (nqueue->freeze_count < 65535, nqueue); +@@ -94,6 +105,7 @@ g_object_notify_queue_thaw (GObject *object, + GParamSpec *pspecs_mem[16], **pspecs, **free_me = NULL; + GSList *slist; + guint n_pspecs = 0; ++ GHashTable *objects; + + g_return_if_fail (nqueue->freeze_count > 0); + +@@ -119,7 +131,10 @@ g_object_notify_queue_thaw (GObject *object, + + pspecs[n_pspecs++] = pspec; + } +- g_datalist_id_set_data (&object->qdata, context->quark_notify_queue, NULL); ++ objects = g_static_private_get (&context->key_notify_objects); ++ g_hash_table_remove (objects, object); ++ if (g_hash_table_size (objects) == 0) ++ g_static_private_set (&context->key_notify_objects, NULL, NULL); + + if (n_pspecs) + context->dispatcher (object, n_pspecs, pspecs); +@@ -162,7 +177,13 @@ static inline GObjectNotifyQueue* + g_object_notify_queue_from_object (GObject *object, + GObjectNotifyContext *context) + { +- return g_datalist_id_get_data (&object->qdata, context->quark_notify_queue); ++ GHashTable *objects; ++ ++ objects = g_static_private_get (&context->key_notify_objects); ++ if (objects == NULL) ++ return NULL; ++ ++ return g_hash_table_lookup (objects, object); + } + diff --git a/recipes/glib-2.0/glib-2.0-native_2.22.0.bb b/recipes/glib-2.0/glib-2.0-native_2.22.0.bb deleted file mode 100644 index b5ce9da849..0000000000 --- a/recipes/glib-2.0/glib-2.0-native_2.22.0.bb +++ /dev/null @@ -1,40 +0,0 @@ -require glib-2.0_${PV}.bb - -FILESPATH = "${FILE_DIRNAME}/glib-2.0-${PV}:${FILE_DIRNAME}/files" -DEPENDS = "gettext-native gtk-doc-native" -EXTRA_OECONF = "" - -inherit native - -do_configure_prepend() { - if [ -e ${S}/${TARGET_SYS}-libtool ] ; then - echo "${TARGET_SYS}-libtool already present" - else - cp ${STAGING_BINDIR}/${TARGET_SYS}-libtool ${S} - fi - -} - -do_stage () { - install -m 0755 gobject/glib-mkenums ${STAGING_BINDIR}/ - install -m 0755 gobject/.libs/glib-genmarshal ${STAGING_BINDIR}/ - install -m 0755 glib-gettextize ${STAGING_BINDIR}/ - oe_libinstall -so -C glib libglib-2.0 ${STAGING_LIBDIR} - oe_libinstall -so -C gmodule libgmodule-2.0 ${STAGING_LIBDIR} - oe_libinstall -so -C gthread libgthread-2.0 ${STAGING_LIBDIR} - oe_libinstall -so -C gobject libgobject-2.0 ${STAGING_LIBDIR} - oe_libinstall -so -C gio libgio-2.0 ${STAGING_LIBDIR} - autotools_stage_includes - install -d ${STAGING_INCDIR}/glib-2.0/glib - install -m 0755 ${S}/glibconfig.h ${STAGING_INCDIR}/glib-2.0/glibconfig.h - install -d ${STAGING_DATADIR}/aclocal - install -m 0644 ${S}/m4macros/glib-2.0.m4 ${STAGING_DATADIR}/aclocal/glib-2.0.m4 - install -m 0644 ${S}/m4macros/glib-gettext.m4 ${STAGING_DATADIR}/aclocal/glib-gettext.m4 - install -d ${STAGING_DATADIR}/glib-2.0/gettext/po - install -m 0755 mkinstalldirs ${STAGING_DATADIR}/glib-2.0/gettext/ - install -m 0644 po/Makefile.in.in ${STAGING_DATADIR}/glib-2.0/gettext/po/ -} - -do_install () { - : -} diff --git a/recipes/glib-2.0/glib-2.0-native_2.22.1.bb b/recipes/glib-2.0/glib-2.0-native_2.22.1.bb new file mode 100644 index 0000000000..b5ce9da849 --- /dev/null +++ b/recipes/glib-2.0/glib-2.0-native_2.22.1.bb @@ -0,0 +1,40 @@ +require glib-2.0_${PV}.bb + +FILESPATH = "${FILE_DIRNAME}/glib-2.0-${PV}:${FILE_DIRNAME}/files" +DEPENDS = "gettext-native gtk-doc-native" +EXTRA_OECONF = "" + +inherit native + +do_configure_prepend() { + if [ -e ${S}/${TARGET_SYS}-libtool ] ; then + echo "${TARGET_SYS}-libtool already present" + else + cp ${STAGING_BINDIR}/${TARGET_SYS}-libtool ${S} + fi + +} + +do_stage () { + install -m 0755 gobject/glib-mkenums ${STAGING_BINDIR}/ + install -m 0755 gobject/.libs/glib-genmarshal ${STAGING_BINDIR}/ + install -m 0755 glib-gettextize ${STAGING_BINDIR}/ + oe_libinstall -so -C glib libglib-2.0 ${STAGING_LIBDIR} + oe_libinstall -so -C gmodule libgmodule-2.0 ${STAGING_LIBDIR} + oe_libinstall -so -C gthread libgthread-2.0 ${STAGING_LIBDIR} + oe_libinstall -so -C gobject libgobject-2.0 ${STAGING_LIBDIR} + oe_libinstall -so -C gio libgio-2.0 ${STAGING_LIBDIR} + autotools_stage_includes + install -d ${STAGING_INCDIR}/glib-2.0/glib + install -m 0755 ${S}/glibconfig.h ${STAGING_INCDIR}/glib-2.0/glibconfig.h + install -d ${STAGING_DATADIR}/aclocal + install -m 0644 ${S}/m4macros/glib-2.0.m4 ${STAGING_DATADIR}/aclocal/glib-2.0.m4 + install -m 0644 ${S}/m4macros/glib-gettext.m4 ${STAGING_DATADIR}/aclocal/glib-gettext.m4 + install -d ${STAGING_DATADIR}/glib-2.0/gettext/po + install -m 0755 mkinstalldirs ${STAGING_DATADIR}/glib-2.0/gettext/ + install -m 0644 po/Makefile.in.in ${STAGING_DATADIR}/glib-2.0/gettext/po/ +} + +do_install () { + : +} diff --git a/recipes/glib-2.0/glib-2.0_2.22.0.bb b/recipes/glib-2.0/glib-2.0_2.22.0.bb deleted file mode 100644 index 5f915c2ee5..0000000000 --- a/recipes/glib-2.0/glib-2.0_2.22.0.bb +++ /dev/null @@ -1,15 +0,0 @@ -require glib.inc -PR = "${INC_PR}.0" - -SRC_URI = "\ - http://ftp.gnome.org/pub/GNOME/sources/glib/2.22/glib-${PV}.tar.bz2 \ - file://glibconfig-sysdefs.h \ - file://configure-libtool.patch;patch=1 \ - file://bug-556515.patch;patch=1 \ -" - - -SRC_URI_append_arm = " file://atomic-thumb.patch;patch=1 \ -" -SRC_URI_append_armv6 = " file://gatomic_armv6.patch;patch=1" -SRC_URI_append_armv7a = " file://gatomic_armv6.patch;patch=1" diff --git a/recipes/glib-2.0/glib-2.0_2.22.1.bb b/recipes/glib-2.0/glib-2.0_2.22.1.bb new file mode 100644 index 0000000000..5f915c2ee5 --- /dev/null +++ b/recipes/glib-2.0/glib-2.0_2.22.1.bb @@ -0,0 +1,15 @@ +require glib.inc +PR = "${INC_PR}.0" + +SRC_URI = "\ + http://ftp.gnome.org/pub/GNOME/sources/glib/2.22/glib-${PV}.tar.bz2 \ + file://glibconfig-sysdefs.h \ + file://configure-libtool.patch;patch=1 \ + file://bug-556515.patch;patch=1 \ +" + + +SRC_URI_append_arm = " file://atomic-thumb.patch;patch=1 \ +" +SRC_URI_append_armv6 = " file://gatomic_armv6.patch;patch=1" +SRC_URI_append_armv7a = " file://gatomic_armv6.patch;patch=1" -- cgit v1.2.3