+++ /dev/null
-diff -urN alsa-lib-1.0.18-0rig//src/pcm/pcm_local.h alsa-lib-1.0.18/src/pcm/pcm_local.h
---- alsa-lib-1.0.18-0rig//src/pcm/pcm_local.h  2009-01-31 11:02:12.000000000 +0100
-+++ alsa-lib-1.0.18/src/pcm/pcm_local.h        2009-01-31 11:03:24.000000000 +0100
-@@ -611,6 +611,13 @@
-                          snd_pcm_hw_param_t var);
- int _snd_pcm_hw_param_set(snd_pcm_hw_params_t *params,
-                         snd_pcm_hw_param_t var, unsigned int val, int dir);
-+
-+#if   defined(AVR32_INLINE_BUG)
-+int _snd_pcm_hw_params_set_format(snd_pcm_hw_params_t *params,
-+                                              snd_pcm_format_t val);
-+int _snd_pcm_hw_params_set_subformat(snd_pcm_hw_params_t *params,
-+                                   snd_pcm_subformat_t val);
-+#else
- static inline int _snd_pcm_hw_params_set_format(snd_pcm_hw_params_t *params,
-                                               snd_pcm_format_t val)
- {
-@@ -624,7 +631,7 @@
-       return _snd_pcm_hw_param_set(params, SND_PCM_HW_PARAM_SUBFORMAT,
-                                    (unsigned long) val, 0);
- }
--
-+#endif
- int _snd_pcm_hw_param_set_min(snd_pcm_hw_params_t *params,
-                             snd_pcm_hw_param_t var, unsigned int val, int dir);
- int _snd_pcm_hw_param_set_max(snd_pcm_hw_params_t *params,
-diff -urN alsa-lib-1.0.18-0rig//src/pcm/pcm_route.c alsa-lib-1.0.18/src/pcm/pcm_route.c
---- alsa-lib-1.0.18-0rig//src/pcm/pcm_route.c  2009-01-31 11:02:12.000000000 +0100
-+++ alsa-lib-1.0.18/src/pcm/pcm_route.c        2009-01-31 11:03:18.000000000 +0100
-@@ -26,6 +26,7 @@
-  *
-  */
-   
-+
- #include <byteswap.h>
- #include <math.h>
- #include "pcm_local.h"
-@@ -106,6 +107,23 @@
- 
- #endif /* DOC_HIDDEN */
- 
-+
-+#if   defined(AVR32_INLINE_BUG)
-+int _snd_pcm_hw_params_set_format(snd_pcm_hw_params_t *params,
-+                                              snd_pcm_format_t val)
-+{
-+      return _snd_pcm_hw_param_set(params, SND_PCM_HW_PARAM_FORMAT,
-+                                   (unsigned long) val, 0);
-+}
-+
-+int _snd_pcm_hw_params_set_subformat(snd_pcm_hw_params_t *params,
-+                                   snd_pcm_subformat_t val)
-+{
-+      return _snd_pcm_hw_param_set(params, SND_PCM_HW_PARAM_SUBFORMAT,
-+                                   (unsigned long) val, 0);
-+}
-+#endif
-+
- static void snd_pcm_route_convert1_zero(const snd_pcm_channel_area_t *dst_area,
-                                       snd_pcm_uframes_t dst_offset,
-                                       const snd_pcm_channel_area_t *src_areas ATTRIBUTE_UNUSED,
-@@ -483,6 +501,8 @@
-                                 snd_pcm_uframes_t frames,
-                                 snd_pcm_route_params_t *params)
- {
-+#if   defined(AVR32_INLINE_BUG)
-+#endif
-       unsigned int dst_channel;
-       snd_pcm_route_ttable_dst_t *dstp;
-       const snd_pcm_channel_area_t *dst_area;
-@@ -551,8 +571,20 @@
-       _snd_pcm_hw_param_set_mask(sparams, SND_PCM_HW_PARAM_ACCESS,
-                                  &saccess_mask);
-       if (route->sformat != SND_PCM_FORMAT_UNKNOWN) {
-+#if   defined(AVR32_INLINE_BUG)
-+/* Start of  of problem */
-+#endif
-               _snd_pcm_hw_params_set_format(sparams, route->sformat);
-               _snd_pcm_hw_params_set_subformat(sparams, SND_PCM_SUBFORMAT_STD);
-+#if   0
-+              _snd_pcm_hw_param_set(sparams, SND_PCM_HW_PARAM_FORMAT,
-+                                   (unsigned long) route->sformat, 0);
-+              _snd_pcm_hw_param_set(sparams, SND_PCM_HW_PARAM_SUBFORMAT,
-+                                   (unsigned long) SND_PCM_SUBFORMAT_STD, 0);
-+#endif
-+#if   defined(AVR32_INLINE_BUG)
-+/* End of problem */
-+#endif
-       }
-       if (route->schannels >= 0) {
-               _snd_pcm_hw_param_set(sparams, SND_PCM_HW_PARAM_CHANNELS,
 
--- /dev/null
+diff -urN alsa-lib-1.0.18-0rig//src/pcm/pcm_local.h alsa-lib-1.0.18/src/pcm/pcm_local.h
+--- alsa-lib-1.0.18-0rig//src/pcm/pcm_local.h  2009-01-31 11:02:12.000000000 +0100
++++ alsa-lib-1.0.18/src/pcm/pcm_local.h        2009-01-31 11:03:24.000000000 +0100
+@@ -611,6 +611,13 @@
+                          snd_pcm_hw_param_t var);
+ int _snd_pcm_hw_param_set(snd_pcm_hw_params_t *params,
+                         snd_pcm_hw_param_t var, unsigned int val, int dir);
++
++#if   defined(AVR32_INLINE_BUG)
++int _snd_pcm_hw_params_set_format(snd_pcm_hw_params_t *params,
++                                              snd_pcm_format_t val);
++int _snd_pcm_hw_params_set_subformat(snd_pcm_hw_params_t *params,
++                                   snd_pcm_subformat_t val);
++#else
+ static inline int _snd_pcm_hw_params_set_format(snd_pcm_hw_params_t *params,
+                                               snd_pcm_format_t val)
+ {
+@@ -624,7 +631,7 @@
+       return _snd_pcm_hw_param_set(params, SND_PCM_HW_PARAM_SUBFORMAT,
+                                    (unsigned long) val, 0);
+ }
+-
++#endif
+ int _snd_pcm_hw_param_set_min(snd_pcm_hw_params_t *params,
+                             snd_pcm_hw_param_t var, unsigned int val, int dir);
+ int _snd_pcm_hw_param_set_max(snd_pcm_hw_params_t *params,
+diff -urN alsa-lib-1.0.18-0rig//src/pcm/pcm_route.c alsa-lib-1.0.18/src/pcm/pcm_route.c
+--- alsa-lib-1.0.18-0rig//src/pcm/pcm_route.c  2009-01-31 11:02:12.000000000 +0100
++++ alsa-lib-1.0.18/src/pcm/pcm_route.c        2009-01-31 11:03:18.000000000 +0100
+@@ -26,6 +26,7 @@
+  *
+  */
+   
++
+ #include <byteswap.h>
+ #include <math.h>
+ #include "pcm_local.h"
+@@ -106,6 +107,23 @@
+ 
+ #endif /* DOC_HIDDEN */
+ 
++
++#if   defined(AVR32_INLINE_BUG)
++int _snd_pcm_hw_params_set_format(snd_pcm_hw_params_t *params,
++                                              snd_pcm_format_t val)
++{
++      return _snd_pcm_hw_param_set(params, SND_PCM_HW_PARAM_FORMAT,
++                                   (unsigned long) val, 0);
++}
++
++int _snd_pcm_hw_params_set_subformat(snd_pcm_hw_params_t *params,
++                                   snd_pcm_subformat_t val)
++{
++      return _snd_pcm_hw_param_set(params, SND_PCM_HW_PARAM_SUBFORMAT,
++                                   (unsigned long) val, 0);
++}
++#endif
++
+ static void snd_pcm_route_convert1_zero(const snd_pcm_channel_area_t *dst_area,
+                                       snd_pcm_uframes_t dst_offset,
+                                       const snd_pcm_channel_area_t *src_areas ATTRIBUTE_UNUSED,
+@@ -483,6 +501,8 @@
+                                 snd_pcm_uframes_t frames,
+                                 snd_pcm_route_params_t *params)
+ {
++#if   defined(AVR32_INLINE_BUG)
++#endif
+       unsigned int dst_channel;
+       snd_pcm_route_ttable_dst_t *dstp;
+       const snd_pcm_channel_area_t *dst_area;
+@@ -551,8 +571,20 @@
+       _snd_pcm_hw_param_set_mask(sparams, SND_PCM_HW_PARAM_ACCESS,
+                                  &saccess_mask);
+       if (route->sformat != SND_PCM_FORMAT_UNKNOWN) {
++#if   defined(AVR32_INLINE_BUG)
++/* Start of  of problem */
++#endif
+               _snd_pcm_hw_params_set_format(sparams, route->sformat);
+               _snd_pcm_hw_params_set_subformat(sparams, SND_PCM_SUBFORMAT_STD);
++#if   0
++              _snd_pcm_hw_param_set(sparams, SND_PCM_HW_PARAM_FORMAT,
++                                   (unsigned long) route->sformat, 0);
++              _snd_pcm_hw_param_set(sparams, SND_PCM_HW_PARAM_SUBFORMAT,
++                                   (unsigned long) SND_PCM_SUBFORMAT_STD, 0);
++#endif
++#if   defined(AVR32_INLINE_BUG)
++/* End of problem */
++#endif
+       }
+       if (route->schannels >= 0) {
+               _snd_pcm_hw_param_set(sparams, SND_PCM_HW_PARAM_CHANNELS,
 
 # alsa-lib
 #
 #############################################################
-ALSA_LIB_VERSION = 1.0.24.1
+
+ALSA_LIB_VERSION = 1.0.25
 ALSA_LIB_SOURCE = alsa-lib-$(ALSA_LIB_VERSION).tar.bz2
 ALSA_LIB_SITE = ftp://ftp.alsa-project.org/pub/lib
 ALSA_LIB_INSTALL_STAGING = YES
-
 ALSA_LIB_CFLAGS=$(TARGET_CFLAGS)
-
 ALSA_LIB_CONF_OPT = --with-alsa-devdir=$(call qstrip,$(BR2_PACKAGE_ALSA_LIB_DEVDIR)) \
                    --with-pcm-plugins="$(call qstrip,$(BR2_PACKAGE_ALSA_LIB_PCM_PLUGINS))" \
                    --with-ctl-plugins="$(call qstrip,$(BR2_PACKAGE_ALSA_LIB_CTL_PLUGINS))" \
                    --without-versioned
 
+# Can't build with static & shared at the same time (1.0.25+)
+ifeq ($(BR2_PREFER_STATIC),y)
+ALSA_LIB_CONF_OPT += --enable-shared=no
+else
+ALSA_LIB_CONF_OPT += --enable-static=no
+endif
+
 ifneq ($(BR2_PACKAGE_ALSA_LIB_ALOAD),y)
 ALSA_LIB_CONF_OPT += --disable-aload
 endif