Hello community,

here is the log from the commit of package alsa for openSUSE:12.3 checked in at 
2013-02-04 17:56:18
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:12.3/alsa (Old)
 and      /work/SRC/openSUSE:12.3/.alsa.new (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "alsa", Maintainer is "[email protected]"

Changes:
--------
--- /work/SRC/openSUSE:12.3/alsa/alsa.changes   2013-01-31 01:12:04.000000000 
+0100
+++ /work/SRC/openSUSE:12.3/.alsa.new/alsa.changes      2013-02-04 
17:56:25.000000000 +0100
@@ -1,0 +2,13 @@
+Fri Feb  1 08:10:43 CET 2013 - [email protected]
+
+- Backport a few fix patches from upstream, mostly for fixing
+  crashes in multi-thread programs:
+  0044-configure-do-not-detect-incorrect-cross-compiler.patch
+  0045-ucm-Set-uc_mgr-ctl-to-NULL-after-closing-it.patch
+  0046-snd_pcm_direct_parse_open_conf-use-thread-safe-getgr.patch
+  0047-Add-snd_lib_error_set_local-to-install-a-thread-loca.patch
+  0048-snd_device_name_hint-do-not-change-the-global-error-.patch
+  0049-snd_device_name_hint-do-not-use-global-snd_config.patch
+  0050-conf-Fix-a-memory-access-violation-resulting-from-im.patch
+
+-------------------------------------------------------------------

New:
----
  0044-configure-do-not-detect-incorrect-cross-compiler.patch
  0045-ucm-Set-uc_mgr-ctl-to-NULL-after-closing-it.patch
  0046-snd_pcm_direct_parse_open_conf-use-thread-safe-getgr.patch
  0047-Add-snd_lib_error_set_local-to-install-a-thread-loca.patch
  0048-snd_device_name_hint-do-not-change-the-global-error-.patch
  0049-snd_device_name_hint-do-not-use-global-snd_config.patch
  0050-conf-Fix-a-memory-access-violation-resulting-from-im.patch

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ alsa.spec ++++++
--- /var/tmp/diff_new_pack.O1s2Va/_old  2013-02-04 17:56:26.000000000 +0100
+++ /var/tmp/diff_new_pack.O1s2Va/_new  2013-02-04 17:56:26.000000000 +0100
@@ -1,7 +1,7 @@
 #
 # spec file for package alsa
 #
-# Copyright (c) 2012 SUSE LINUX Products GmbH, Nuernberg, Germany.
+# Copyright (c) 2013 SUSE LINUX Products GmbH, Nuernberg, Germany.
 #
 # All modifications and additions to the file contributed by third parties
 # remain the property of their copyright owners, unless otherwise agreed
@@ -95,6 +95,13 @@
 Patch41:        0041-configure-Quite-AM_CONDITIONAL-arguments.patch
 Patch42:        0042-mixer-Don-t-build-simple_abst-when-no-libdl-is-avail.patch
 Patch43:        0043-Fix-endian-check-in-local.h.patch
+Patch44:        0044-configure-do-not-detect-incorrect-cross-compiler.patch
+Patch45:        0045-ucm-Set-uc_mgr-ctl-to-NULL-after-closing-it.patch
+Patch46:        0046-snd_pcm_direct_parse_open_conf-use-thread-safe-getgr.patch
+Patch47:        0047-Add-snd_lib_error_set_local-to-install-a-thread-loca.patch
+Patch48:        0048-snd_device_name_hint-do-not-change-the-global-error-.patch
+Patch49:        0049-snd_device_name_hint-do-not-use-global-snd_config.patch
+Patch50:        0050-conf-Fix-a-memory-access-violation-resulting-from-im.patch
 #
 Patch99:        alsa-lib-doxygen-avoid-crash-for-11.3.diff
 Url:            http://www.alsa-project.org/
@@ -188,6 +195,13 @@
 %patch41 -p1
 %patch42 -p1
 %patch43 -p1
+%patch44 -p1
+%patch45 -p1
+%patch46 -p1
+%patch47 -p1
+%patch48 -p1
+%patch49 -p1
+%patch50 -p1
 %if %suse_version == 1130
 %patch99 -p1
 %endif

++++++ 0044-configure-do-not-detect-incorrect-cross-compiler.patch ++++++
>From b11911dddf2fd58e24c808da26105cb1e1bce722 Mon Sep 17 00:00:00 2001
From: Olivier Blin <[email protected]>
Date: Sat, 15 Dec 2012 01:58:59 +0100
Subject: [PATCH 44/50] configure: do not detect incorrect cross-compiler

On Ubuntu 11.04, configuring with --build=x86_64-unknown-linux-gnu
--host=x86_64-linux-gnu finds a wrong cross-compiler:
checking for cross-compiler... x86_64-x86_64-pc-linux-gnu-gcc

This happens because of a dash vs underscore inconsistency in configure.in:
host=x86_64-pc-linux-gnu
host_cpu=x86_64
host_os=linux-gnu
which ${host_cpu}-${host_os}-gcc >/dev/null 2>&1 && echo 
${host_cpu}-${host-os}-gcc

This bug has been introduced in the initial --with-host support from
2002, commit eb267ade29c9a49c07b1c33dc9bf7a6790217400

This configure command is about "cross-compiling for i586", where the
system compiler is used, which just -m32 additional options.
The --build value comes from config.guess.
---
 configure.in |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

--- a/configure.in
+++ b/configure.in
@@ -31,7 +31,7 @@ then
 
   which ${program_prefix}gcc >/dev/null 2>&1 && CC=${program_prefix}gcc
   which ${host_cpu}-${host_os}-gcc >/dev/null 2>&1 \
-  && CC=${host_cpu}-${host-os}-gcc
+  && CC=${host_cpu}-${host_os}-gcc
   which ${host_cpu}-${host_vendor}-${host_os}-gcc >/dev/null 2>&1 \
   && CC=${host_cpu}-${host_vendor}-${host_os}-gcc
 
++++++ 0045-ucm-Set-uc_mgr-ctl-to-NULL-after-closing-it.patch ++++++
>From 1629e2fbf3dc211eceb37f980e11e5babe1cefe4 Mon Sep 17 00:00:00 2001
From: Tanu Kaskinen <[email protected]>
Date: Sat, 26 Jan 2013 14:20:20 +0200
Subject: [PATCH 45/50] ucm: Set uc_mgr->ctl to NULL after closing it.

Fixes a double-free bug.

Signed-off-by: Tanu Kaskinen <[email protected]>
Acked-by: Liam Girdwood <[email protected]>
Signed-off-by: Takashi Iwai <[email protected]>
---
 src/ucm/main.c |    1 +
 1 file changed, 1 insertion(+)

--- a/src/ucm/main.c
+++ b/src/ucm/main.c
@@ -145,6 +145,7 @@ static int open_ctl(snd_use_case_mgr_t *
                free(uc_mgr->ctl_dev);
                uc_mgr->ctl_dev = NULL;
                snd_ctl_close(uc_mgr->ctl);
+               uc_mgr->ctl = NULL;
        
        }
        err = snd_ctl_open(ctl, ctl_dev, 0);
++++++ 0046-snd_pcm_direct_parse_open_conf-use-thread-safe-getgr.patch ++++++
>From 2cfc8b9b44a8e493c41b3d63d5a00b306a18a5ed Mon Sep 17 00:00:00 2001
From: Jerome Forissier <[email protected]>
Date: Wed, 30 Jan 2013 16:22:17 +0100
Subject: [PATCH 46/50] snd_pcm_direct_parse_open_conf(): use thread-safe
 getgrnam_r()

Fixes a thread safety issue with snd_pcm_open().

Signed-off-by: Jerome Forissier <[email protected]>
Signed-off-by: Takashi Iwai <[email protected]>
---
 src/pcm/pcm_direct.c |   15 +++++++++++----
 1 file changed, 11 insertions(+), 4 deletions(-)

--- a/src/pcm/pcm_direct.c
+++ b/src/pcm/pcm_direct.c
@@ -1629,13 +1629,20 @@ int snd_pcm_direct_parse_open_conf(snd_c
                                continue;
                        }
                        if (isdigit(*group) == 0) {
-                               struct group *grp = getgrnam(group);
-                               if (grp == NULL) {
+                               long clen = sysconf(_SC_GETGR_R_SIZE_MAX);
+                               size_t len = (clen == -1) ? 1024 : (size_t)clen;
+                               struct group grp, *pgrp;
+                               char *buffer = (char *)malloc(len);
+                               if (buffer == NULL)
+                                       return -ENOMEM;
+                               int st = getgrnam_r(group, &grp, buffer, len, 
&pgrp);
+                               if (st != 0) {
                                        SNDERR("The field ipc_gid must be a 
valid group (create group %s)", group);
-                                       free(group);
+                                       free(buffer);
                                        return -EINVAL;
                                }
-                               rec->ipc_gid = grp->gr_gid;
+                               rec->ipc_gid = pgrp->gr_gid;
+                               free(buffer);
                        } else {
                                rec->ipc_gid = strtol(group, &endp, 10);
                        }
++++++ 0047-Add-snd_lib_error_set_local-to-install-a-thread-loca.patch ++++++
>From 44c1a623dd1fc9e831616b663bebc54ca98df994 Mon Sep 17 00:00:00 2001
From: Jerome Forissier <[email protected]>
Date: Thu, 31 Jan 2013 15:47:23 +0100
Subject: [PATCH 47/50] Add snd_lib_error_set_local() to install a thread-local
 error handler.

This is required so we can make other functions reentrant (such as
snd_device_name_hint()).
The default error handling function snd_lib_error_default() now checks
if a local handler exists, and if so, calls it. Otherwise, the previous
behavior is unchanged.

Signed-off-by: Jerome Forissier <[email protected]>
Signed-off-by: Takashi Iwai <[email protected]>
---
 configure.in    |   10 ++++++++++
 include/error.h |    6 ++++++
 src/error.c     |   24 +++++++++++++++++++++++-
 3 files changed, 39 insertions(+), 1 deletion(-)

--- a/configure.in
+++ b/configure.in
@@ -281,6 +281,16 @@ else
   AC_MSG_RESULT(no)
 fi
 
+dnl Check for __thread
+AC_MSG_CHECKING([for __thread])
+AC_LINK_IFELSE([AC_LANG_PROGRAM([#if defined(__GNUC__) && (defined(__i386__) 
|| defined(__x86_64__)) && ((__GNUC__ < 4) || (__GNUC__ == 4 && __GNUC_MINOR__ 
< 1) || (__GNUC__ == 4 && __GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ < 2))
+#error gcc has this bug: http://gcc.gnu.org/ml/gcc-bugs/2006-09/msg02275.html
+#endif], [static __thread int p = 0])],
+[AC_DEFINE(HAVE___THREAD, 1,
+Define to 1 if compiler supports __thread)
+AC_MSG_RESULT([yes])],
+[AC_MSG_RESULT([no])])
+
 dnl Check for librt
 AC_MSG_CHECKING(for librt)
 AC_ARG_WITH(librt,
--- a/include/error.h
+++ b/include/error.h
@@ -74,5 +74,11 @@ extern int snd_lib_error_set_handler(snd
 }
 #endif
 
+typedef void (*snd_local_error_handler_t)(const char *file, int line,
+                                         const char *func, int err,
+                                         const char *fmt, va_list arg);
+
+snd_local_error_handler_t snd_lib_error_set_local(snd_local_error_handler_t 
func);
+
 #endif /* __ALSA_ERROR_H */
 
--- a/src/error.c
+++ b/src/error.c
@@ -60,6 +60,21 @@ const char *snd_strerror(int errnum)
        return snd_error_codes[errnum];
 }
 
+#ifdef HAVE___THREAD
+#define TLS_PFX                __thread
+#else
+#define TLS_PFX                /* NOP */
+#endif
+
+static TLS_PFX snd_local_error_handler_t local_error = NULL;
+
+snd_local_error_handler_t snd_lib_error_set_local(snd_local_error_handler_t 
func)
+{
+       snd_local_error_handler_t old = local_error;
+       local_error = func;
+       return old;
+}
+
 /**
  * \brief The default error handler function.
  * \param file The filename where the error was hit.
@@ -69,12 +84,19 @@ const char *snd_strerror(int errnum)
  * \param fmt The message (including the format characters).
  * \param ... Optional arguments.
  *
- * Prints the error message including location to \c stderr.
+ * If a local error function has been installed for the current thread by
+ * \ref snd_lib_error_set_local, it is called. Otherwise, prints the error
+ * message including location to \c stderr.
  */
 static void snd_lib_error_default(const char *file, int line, const char 
*function, int err, const char *fmt, ...)
 {
        va_list arg;
        va_start(arg, fmt);
+       if (local_error) {
+               local_error(file, line, function, err, fmt, arg);
+               va_end(arg);
+               return;
+       }
        fprintf(stderr, "ALSA lib %s:%i:(%s) ", file, line, function);
        vfprintf(stderr, fmt, arg);
        if (err)
++++++ 0048-snd_device_name_hint-do-not-change-the-global-error-.patch ++++++
>From 25dbb102810b31c02358904d70d53c960fb0a10e Mon Sep 17 00:00:00 2001
From: Jerome Forissier <[email protected]>
Date: Thu, 31 Jan 2013 15:47:24 +0100
Subject: [PATCH 48/50] snd_device_name_hint(): do not change the global error
 handler.

This is the first step towards making this function reentrant.

Signed-off-by: Jerome Forissier <[email protected]>
Signed-off-by: Takashi Iwai <[email protected]>
---
 src/control/namehint.c |   15 +++++++--------
 1 file changed, 7 insertions(+), 8 deletions(-)

--- a/src/control/namehint.c
+++ b/src/control/namehint.c
@@ -80,7 +80,8 @@ static void zero_handler(const char *fil
                         int line ATTRIBUTE_UNUSED,
                         const char *function ATTRIBUTE_UNUSED,
                         int err ATTRIBUTE_UNUSED,
-                        const char *fmt ATTRIBUTE_UNUSED, ...)
+                        const char *fmt ATTRIBUTE_UNUSED,
+                        va_list arg ATTRIBUTE_UNUSED)
 {
 }
 
@@ -212,7 +213,7 @@ static int try_config(struct hint_list *
                      const char *base,
                      const char *name)
 {
-       snd_lib_error_handler_t eh;
+       snd_local_error_handler_t eh;
        snd_config_t *res = NULL, *cfg, *cfg1, *n;
        snd_config_iterator_t i, next;
        char *buf, *buf1 = NULL, *buf2;
@@ -239,10 +240,9 @@ static int try_config(struct hint_list *
                sprintf(buf, "%s:CARD=%s", name, 
snd_ctl_card_info_get_id(list->info));
        else
                strcpy(buf, name);
-       eh = snd_lib_error;
-       snd_lib_error_set_handler(&zero_handler);
+       eh = snd_lib_error_set_local(&zero_handler);
        err = snd_config_search_definition(snd_config, base, buf, &res);
-       snd_lib_error_set_handler(eh);
+       snd_lib_error_set_local(eh);
        if (err < 0)
                goto __skip_add;
        cleanup_res = 1;
@@ -337,10 +337,9 @@ static int try_config(struct hint_list *
                goto __ok;
        /* find, if all parameters have a default, */
        /* otherwise filter this definition */
-       eh = snd_lib_error;
-       snd_lib_error_set_handler(&zero_handler);
+       eh = snd_lib_error_set_local(&zero_handler);
        err = snd_config_search_alias_hooks(snd_config, base, buf, &res);
-       snd_lib_error_set_handler(eh);
+       snd_lib_error_set_local(eh);
        if (err < 0)
                goto __cleanup;
        if (snd_config_search(res, "@args", &cfg) >= 0) {
++++++ 0049-snd_device_name_hint-do-not-use-global-snd_config.patch ++++++
>From f49b2dc522a2564315c76d075203b15a39941e8a Mon Sep 17 00:00:00 2001
From: Jerome Forissier <[email protected]>
Date: Thu, 31 Jan 2013 15:47:25 +0100
Subject: [PATCH 49/50] snd_device_name_hint(): do not use global snd_config.

This commit and its parent make the function reentrant.

Signed-off-by: Jerome Forissier <[email protected]>
Signed-off-by: Takashi Iwai <[email protected]>
---
 src/control/namehint.c |   52 ++++++++++++++++++++++++++++---------------------
 1 file changed, 30 insertions(+), 22 deletions(-)

--- a/src/control/namehint.c
+++ b/src/control/namehint.c
@@ -209,7 +209,8 @@ static char *get_dev_name(struct hint_li
 #define BUF_SIZE 128
 #endif
 
-static int try_config(struct hint_list *list,
+static int try_config(snd_config_t *config,
+                     struct hint_list *list,
                      const char *base,
                      const char *name)
 {
@@ -229,7 +230,7 @@ static int try_config(struct hint_list *
                return -ENOMEM;
        sprintf(buf, "%s.%s", base, name);
        /* look for redirection */
-       if (snd_config_search(snd_config, buf, &cfg) >= 0 &&
+       if (snd_config_search(config, buf, &cfg) >= 0 &&
            snd_config_get_string(cfg, &str) >= 0 &&
            ((strncmp(base, str, strlen(base)) == 0 &&
             str[strlen(base)] == '.') || strchr(str, '.') == NULL))
@@ -241,7 +242,7 @@ static int try_config(struct hint_list *
        else
                strcpy(buf, name);
        eh = snd_lib_error_set_local(&zero_handler);
-       err = snd_config_search_definition(snd_config, base, buf, &res);
+       err = snd_config_search_definition(config, base, buf, &res);
        snd_lib_error_set_local(eh);
        if (err < 0)
                goto __skip_add;
@@ -338,7 +339,7 @@ static int try_config(struct hint_list *
        /* find, if all parameters have a default, */
        /* otherwise filter this definition */
        eh = snd_lib_error_set_local(&zero_handler);
-       err = snd_config_search_alias_hooks(snd_config, base, buf, &res);
+       err = snd_config_search_alias_hooks(config, base, buf, &res);
        snd_lib_error_set_local(eh);
        if (err < 0)
                goto __cleanup;
@@ -405,7 +406,7 @@ static const next_devices_t next_devices
 };
 #endif
 
-static int add_card(struct hint_list *list, int card)
+static int add_card(snd_config_t *config, struct hint_list *list, int card)
 {
        int err, ok;
        snd_config_t *conf, *n;
@@ -417,7 +418,7 @@ static int add_card(struct hint_list *li
        
        snd_ctl_card_info_alloca(&info);
        list->info = info;
-       err = snd_config_search(snd_config, list->siface, &conf);
+       err = snd_config_search(config, list->siface, &conf);
        if (err < 0)
                return err;
        sprintf(ctl_name, "hw:%i", card);
@@ -448,7 +449,7 @@ static int add_card(struct hint_list *li
                        ok = 0;
                        for (device = 0; err >= 0 && device <= max_device; 
device++) {
                                list->device = device;
-                               err = try_config(list, list->siface, str);
+                               err = try_config(config, list, list->siface, 
str);
                                if (err < 0)
                                        break;
                                ok++;
@@ -463,7 +464,7 @@ static int add_card(struct hint_list *li
                if (err < 0) {
                        list->card = card;
                        list->device = -1;
-                       err = try_config(list, list->siface, str);
+                       err = try_config(config, list, list->siface, str);
                }
                if (err == -ENOMEM)
                        goto __error;
@@ -492,14 +493,14 @@ static int get_card_name(struct hint_lis
        return 0;
 }
 
-static int add_software_devices(struct hint_list *list)
+static int add_software_devices(snd_config_t *config, struct hint_list *list)
 {
        int err;
        snd_config_t *conf, *n;
        snd_config_iterator_t i, next;
        const char *str;
 
-       err = snd_config_search(snd_config, list->siface, &conf);
+       err = snd_config_search(config, list->siface, &conf);
        if (err < 0)
                return err;
        snd_config_for_each(i, next, conf) {
@@ -508,7 +509,7 @@ static int add_software_devices(struct h
                        continue;
                list->card = -1;
                list->device = -1;
-               err = try_config(list, list->siface, str);
+               err = try_config(config, list, list->siface, str);
                if (err == -ENOMEM)
                        return -ENOMEM;
        }
@@ -546,13 +547,14 @@ int snd_device_name_hint(int card, const
        struct hint_list list;
        char ehints[24];
        const char *str;
-       snd_config_t *conf;
+       snd_config_t *conf, *local_config = NULL;
+       snd_config_update_t *local_config_update = NULL;
        snd_config_iterator_t i, next;
        int err;
 
        if (hints == NULL)
                return -EINVAL;
-       err = snd_config_update();
+       err = snd_config_update_r(&local_config, &local_config_update, NULL);
        if (err < 0)
                return err;
        list.list = NULL;
@@ -572,18 +574,21 @@ int snd_device_name_hint(int card, const
                list.iface = SND_CTL_ELEM_IFACE_HWDEP;
        else if (strcmp(iface, "ctl") == 0)
                list.iface = SND_CTL_ELEM_IFACE_MIXER;
-       else
-               return -EINVAL;
+       else {
+               err = -EINVAL;
+               goto __error;
+       }
+
        list.show_all = 0;
        list.cardname = NULL;
-       if (snd_config_search(snd_config, "defaults.namehint.showall", &conf) 
>= 0)
+       if (snd_config_search(local_config, "defaults.namehint.showall", &conf) 
>= 0)
                list.show_all = snd_config_get_bool(conf) > 0;
        if (card >= 0) {
                err = get_card_name(&list, card);
                if (err >= 0)
-                       err = add_card(&list, card);
+                       err = add_card(local_config, &list, card);
        } else {
-               add_software_devices(&list);
+               add_software_devices(local_config, &list);
                err = snd_card_next(&card);
                if (err < 0)
                        goto __error;
@@ -591,7 +596,7 @@ int snd_device_name_hint(int card, const
                        err = get_card_name(&list, card);
                        if (err < 0)
                                goto __error;
-                       err = add_card(&list, card);
+                       err = add_card(local_config, &list, card);
                        if (err < 0)
                                goto __error;
                        err = snd_card_next(&card);
@@ -600,7 +605,7 @@ int snd_device_name_hint(int card, const
                }
        }
        sprintf(ehints, "namehint.%s", list.siface);
-       err = snd_config_search(snd_config, ehints, &conf);
+       err = snd_config_search(local_config, ehints, &conf);
        if (err >= 0) {
                snd_config_for_each(i, next, conf) {
                        if (snd_config_get_string(snd_config_iterator_entry(i),
@@ -617,7 +622,6 @@ int snd_device_name_hint(int card, const
                snd_device_name_free_hint((void **)list.list);
                if (list.cardname)
                        free(list.cardname);
-               return err;
        } else {
                err = hint_list_add(&list, NULL, NULL);
                if (err < 0)
@@ -626,7 +630,11 @@ int snd_device_name_hint(int card, const
                if (list.cardname)
                        free(list.cardname);
        }
-       return 0;
+       if (local_config)
+               snd_config_delete(local_config);
+       if (local_config_update)
+               snd_config_update_free(local_config_update);
+       return err;
 }
 
 /**
++++++ 0050-conf-Fix-a-memory-access-violation-resulting-from-im.patch ++++++
>From 7f2b2c8c1650a1883b48abfcdb455138943854f9 Mon Sep 17 00:00:00 2001
From: Allan Wirth <[email protected]>
Date: Thu, 31 Jan 2013 13:55:33 -0500
Subject: [PATCH 50/50] conf: Fix a memory access violation resulting from
 improper error propogation

Fixes an issue where a variable is used undeclared, which can cause seg
faults on some systems if the configuration file is not formatted
properly.

Signed-off-by: Allan Wirth <[email protected]>
Signed-off-by: Takashi Iwai <[email protected]>
---
 src/conf.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

--- a/src/conf.c
+++ b/src/conf.c
@@ -3530,7 +3530,7 @@ int snd_config_hook_load(snd_config_t *r
                                if (err < 0)
                                        goto _err;
                        }
-               } else if (config_file_open(root, fi[idx].name) < 0)
+               } else if ((err = config_file_open(root, fi[idx].name)) < 0)
                        goto _err;
        }
        *dst = NULL;



-- 
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to