* [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
@ 2014-07-29 7:04 Jun Zhu
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 2/3] pulseaudio: Fix mutext issue when do pause in gstreamer Jun Zhu
` (3 more replies)
0 siblings, 4 replies; 13+ messages in thread
From: Jun Zhu @ 2014-07-29 7:04 UTC (permalink / raw)
To: meta-freescale; +Cc: Jun Zhu
on i.MX seriese boards, some pulseaudio defualt setting should be
modified to improve the user experience:
- Daemon's exit_idle_time: set value as -1 to make pulseaudio service
never be terminated by any user-space app.
- Resample mothed: switch to the build-in ffmpeg to improve the
sound quality.
- Flat_Volumes: set value as "no" to align with the normal use case.
These customized configuration would be installed to overwrite the
original version.
Signed-off-by: Jun Zhu <R01007@freescale.com>
---
.../pulseaudio/pulseaudio/daemon.conf | 87 ++++++++++
.../pulseaudio/pulseaudio/default.pa | 170 ++++++++++++++++++++
.../pulseaudio/pulseaudio_5.0.bbappend | 23 +++
3 files changed, 280 insertions(+)
create mode 100644 recipes-multimedia/pulseaudio/pulseaudio/daemon.conf
create mode 100644 recipes-multimedia/pulseaudio/pulseaudio/default.pa
create mode 100644 recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
diff --git a/recipes-multimedia/pulseaudio/pulseaudio/daemon.conf b/recipes-multimedia/pulseaudio/pulseaudio/daemon.conf
new file mode 100644
index 0000000..54854eb
--- /dev/null
+++ b/recipes-multimedia/pulseaudio/pulseaudio/daemon.conf
@@ -0,0 +1,87 @@
+# This file is part of PulseAudio.
+#
+# PulseAudio is free software; you can redistribute it and/or modify
+# it under the terms of the GNU Lesser General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# PulseAudio is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public License
+# along with PulseAudio; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+# USA.
+
+## Configuration file for the PulseAudio daemon. See pulse-daemon.conf(5) for
+## more information. Default values are commented out. Use either ; or # for
+## commenting.
+
+; daemonize = no
+; fail = yes
+; allow-module-loading = yes
+; allow-exit = yes
+; use-pid-file = yes
+; system-instance = no
+; local-server-type = user
+; enable-shm = yes
+; shm-size-bytes = 0 # setting this 0 will use the system-default, usually 64 MiB
+; lock-memory = no
+; cpu-limit = no
+
+; high-priority = yes
+; nice-level = -11
+
+; realtime-scheduling = yes
+; realtime-priority = 5
+
+exit-idle-time = -1
+; scache-idle-time = 20
+
+; dl-search-path = (depends on architecture)
+
+; load-default-script-file = yes
+; default-script-file = /etc/pulse/default.pa
+
+; log-target = auto
+; log-level = notice
+; log-meta = no
+; log-time = no
+; log-backtrace = 0
+
+resample-method = ffmpeg
+; enable-remixing = yes
+; enable-lfe-remixing = no
+
+flat-volumes = no
+
+; rlimit-fsize = -1
+; rlimit-data = -1
+; rlimit-stack = -1
+; rlimit-core = -1
+; rlimit-as = -1
+; rlimit-rss = -1
+; rlimit-nproc = -1
+; rlimit-nofile = 256
+; rlimit-memlock = -1
+; rlimit-locks = -1
+; rlimit-sigpending = -1
+; rlimit-msgqueue = -1
+; rlimit-nice = 31
+; rlimit-rtprio = 9
+; rlimit-rttime = 1000000
+
+; default-sample-format = s16le
+; default-sample-rate = 44100
+; alternate-sample-rate = 48000
+; default-sample-channels = 2
+; default-channel-map = front-left,front-right
+
+; default-fragments = 4
+; default-fragment-size-msec = 25
+
+; enable-deferred-volume = yes
+; deferred-volume-safety-margin-usec = 8000
+; deferred-volume-extra-delay-usec = 0
diff --git a/recipes-multimedia/pulseaudio/pulseaudio/default.pa b/recipes-multimedia/pulseaudio/pulseaudio/default.pa
new file mode 100644
index 0000000..83a6ba8
--- /dev/null
+++ b/recipes-multimedia/pulseaudio/pulseaudio/default.pa
@@ -0,0 +1,170 @@
+#!/usr/bin/pulseaudio -nF
+#
+# This file is part of PulseAudio.
+#
+# PulseAudio is free software; you can redistribute it and/or modify it
+# under the terms of the GNU Lesser General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# PulseAudio is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public License
+# along with PulseAudio; if not, write to the Free Software Foundation,
+# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
+
+# This startup script is used only if PulseAudio is started per-user
+# (i.e. not in system mode)
+
+.nofail
+
+### Load something into the sample cache
+#load-sample-lazy x11-bell /usr/share/sounds/gtk-events/activate.wav
+#load-sample-lazy pulse-hotplug /usr/share/sounds/startup3.wav
+#load-sample-lazy pulse-coldplug /usr/share/sounds/startup3.wav
+#load-sample-lazy pulse-access /usr/share/sounds/generic.wav
+
+.fail
+
+### Automatically restore the volume of streams and devices
+load-module module-device-restore
+load-module module-stream-restore
+load-module module-card-restore
+
+### Automatically augment property information from .desktop files
+### stored in /usr/share/application
+load-module module-augment-properties
+
+### Should be after module-*-restore but before module-*-detect
+load-module module-switch-on-port-available
+
+### Load audio drivers statically
+### (it's probably better to not load these drivers manually, but instead
+### use module-udev-detect -- see below -- for doing this automatically)
+#load-module module-alsa-sink
+#load-module module-alsa-source device=hw:1,0
+#load-module module-oss device="/dev/dsp" sink_name=output source_name=input
+#load-module module-oss-mmap device="/dev/dsp" sink_name=output source_name=input
+#load-module module-null-sink
+#load-module module-pipe-sink
+
+### Automatically load driver modules depending on the hardware available
+.ifexists module-udev-detect.so
+load-module module-udev-detect tsched=0
+.else
+### Use the static hardware detection module (for systems that lack udev support)
+load-module module-detect
+.endif
+
+### Automatically connect sink and source if JACK server is present
+.ifexists module-jackdbus-detect.so
+.nofail
+load-module module-jackdbus-detect channels=2
+.fail
+.endif
+
+### Automatically load driver modules for Bluetooth hardware
+.ifexists module-bluetooth-policy.so
+load-module module-bluetooth-policy
+.endif
+
+.ifexists module-bluetooth-discover.so
+load-module module-bluetooth-discover
+.endif
+
+### Load several protocols
+.ifexists module-esound-protocol-unix.so
+load-module module-esound-protocol-unix
+.endif
+load-module module-native-protocol-unix
+
+### Network access (may be configured with paprefs, so leave this commented
+### here if you plan to use paprefs)
+#load-module module-esound-protocol-tcp
+#load-module module-native-protocol-tcp
+#load-module module-zeroconf-publish
+
+### Load the RTP receiver module (also configured via paprefs, see above)
+#load-module module-rtp-recv
+
+### Load the RTP sender module (also configured via paprefs, see above)
+#load-module module-null-sink sink_name=rtp format=s16be channels=2 rate=44100 sink_properties="device.description='RTP Multicast Sink'"
+#load-module module-rtp-send source=rtp.monitor
+
+### Load additional modules from GConf settings. This can be configured with the paprefs tool.
+### Please keep in mind that the modules configured by paprefs might conflict with manually
+### loaded modules.
+.ifexists module-gconf.so
+.nofail
+load-module module-gconf
+.fail
+.endif
+
+### Automatically restore the default sink/source when changed by the user
+### during runtime
+### NOTE: This should be loaded as early as possible so that subsequent modules
+### that look up the default sink/source get the right value
+load-module module-default-device-restore
+
+### Automatically move streams to the default sink if the sink they are
+### connected to dies, similar for sources
+load-module module-rescue-streams
+
+### Make sure we always have a sink around, even if it is a null sink.
+load-module module-always-sink
+
+### Honour intended role device property
+load-module module-intended-roles
+
+### Automatically suspend sinks/sources that become idle for too long
+load-module module-suspend-on-idle
+
+### If autoexit on idle is enabled we want to make sure we only quit
+### when no local session needs us anymore.
+.ifexists module-console-kit.so
+load-module module-console-kit
+.endif
+.ifexists module-systemd-login.so
+load-module module-systemd-login
+.endif
+
+### Enable positioned event sounds
+load-module module-position-event-sounds
+
+### Cork music/video streams when a phone stream is active
+load-module module-role-cork
+
+### Modules to allow autoloading of filters (such as echo cancellation)
+### on demand. module-filter-heuristics tries to determine what filters
+### make sense, and module-filter-apply does the heavy-lifting of
+### loading modules and rerouting streams.
+load-module module-filter-heuristics
+load-module module-filter-apply
+
+### Load DBus protocol
+.ifexists module-dbus-protocol.so
+load-module module-dbus-protocol
+.endif
+
+# X11 modules should not be started from default.pa so that one daemon
+# can be shared by multiple sessions.
+
+### Load X11 bell module
+#load-module module-x11-bell sample=bell-windowing-system
+
+### Register ourselves in the X11 session manager
+#load-module module-x11-xsmp
+
+### Publish connection data in the X11 root window
+#.ifexists module-x11-publish.so
+#.nofail
+#load-module module-x11-publish
+#.fail
+#.endif
+
+### Make some devices default
+#set-default-sink output
+#set-default-source input
diff --git a/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend b/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
new file mode 100644
index 0000000..993c340
--- /dev/null
+++ b/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
@@ -0,0 +1,23 @@
+# As it can not overwrite the version in the layer meta-fsl-arm, we have to use
+# another file extension for new patch to the append in the meta-fsl-arm
+
+FILESEXTRAPATHS_prepend := "${THISDIR}/${PN}:"
+
+SRC_URI_append = " file://daemon.conf \
+ file://default.pa \
+"
+
+do_install_append() {
+ # FIXME: Install the customized pulseaudio damon setting to overwrite the default one
+ install -m 0644 ${WORKDIR}/daemon.conf ${D}${sysconfdir}/pulse/daemon.conf
+ install -m 0644 ${WORKDIR}/default.pa ${D}${sysconfdir}/pulse/default.pa
+
+ #FIXME: Remove the kde desktop, because there are two destop in default
+ # (pulseaudio-kde.destop, pulseaudio.destop), then the pulseaudio server
+ # will be started twice, pulseaudio will have issue to switch to default input/output.
+ if [ -e ${D}${sysconfdir}/xdg/autostart/pulseaudio-kde.desktop ]
+ then
+ rm ${D}${sysconfdir}/xdg/autostart/pulseaudio-kde.desktop
+ fi
+}
+
--
1.7.9.5
^ permalink raw reply related [flat|nested] 13+ messages in thread
* [meta-fsl-arm][PATCH 2/3] pulseaudio: Fix mutext issue when do pause in gstreamer
2014-07-29 7:04 [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Jun Zhu
@ 2014-07-29 7:04 ` Jun Zhu
2014-07-29 13:40 ` Otavio Salvador
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 3/3] pulseaudio: Fix no sound issue after plugin/out headphone Jun Zhu
` (2 subsequent siblings)
3 siblings, 1 reply; 13+ messages in thread
From: Jun Zhu @ 2014-07-29 7:04 UTC (permalink / raw)
To: meta-freescale; +Cc: Jun Zhu
Pulseaudio crashes when other program using sound:
Assertion 'pthread_mutex_unlock(&m->mutex) == 0' failed
at pulsecore/mutex-posix.c:106, function pa_mutex_unlock().
Disable PTHREAD priority inheritance feature is the easiest
workaround solutions for this issue.
Signed-off-by: Jun Zhu <R01007@freescale.com>
---
...dio-mutex-issue-when-do-pause-in-gstreame.patch | 34 ++++++++++++++++++++
.../pulseaudio/pulseaudio_5.0.bbappend | 1 +
2 files changed, 35 insertions(+)
create mode 100644 recipes-multimedia/pulseaudio/pulseaudio/0001-Fix-pulseaudio-mutex-issue-when-do-pause-in-gstreame.patch
diff --git a/recipes-multimedia/pulseaudio/pulseaudio/0001-Fix-pulseaudio-mutex-issue-when-do-pause-in-gstreame.patch b/recipes-multimedia/pulseaudio/pulseaudio/0001-Fix-pulseaudio-mutex-issue-when-do-pause-in-gstreame.patch
new file mode 100644
index 0000000..67bc46f
--- /dev/null
+++ b/recipes-multimedia/pulseaudio/pulseaudio/0001-Fix-pulseaudio-mutex-issue-when-do-pause-in-gstreame.patch
@@ -0,0 +1,34 @@
+From c21e24f5c53e81fc715905c54a6c82b69e397e63 Mon Sep 17 00:00:00 2001
+From: "shengjiu.wang" <b02247@freescale.com>
+Date: Thu, 3 Apr 2014 14:22:02 +0800
+Subject: [PATCH] Fix pulseaudio mutex issue when do pause in gstreamer
+
+The error log is "Assertion 'pthread_mutex_unlock(&m->mutex) == 0'
+failed at pulsecore/mutex-posix.c:106, function pa_mutex_unlock(). Aborting"
+
+This fix is a workaround base on the solution from this link "
+https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/932096"
+
+Upstream status: N/A
+ - It is i.MX specific
+
+Signed-off-by: shengjiu.wang <b02247@freescale.com>
+---
+ src/pulsecore/mutex-posix.c | 1 +
+ 1 file changed, 1 insertion(+)
+
+diff --git a/src/pulsecore/mutex-posix.c b/src/pulsecore/mutex-posix.c
+index 36c2787..d592501 100644
+--- a/src/pulsecore/mutex-posix.c
++++ b/src/pulsecore/mutex-posix.c
+@@ -30,6 +30,7 @@
+ #include <pulsecore/macro.h>
+
+ #include "mutex.h"
++#undef HAVE_PTHREAD_PRIO_INHERIT
+
+ struct pa_mutex {
+ pthread_mutex_t mutex;
+--
+1.7.9.5
+
diff --git a/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend b/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
index 993c340..4ea4921 100644
--- a/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
+++ b/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
@@ -5,6 +5,7 @@ FILESEXTRAPATHS_prepend := "${THISDIR}/${PN}:"
SRC_URI_append = " file://daemon.conf \
file://default.pa \
+ file://0001-Fix-pulseaudio-mutex-issue-when-do-pause-in-gstreame.patch \
"
do_install_append() {
--
1.7.9.5
^ permalink raw reply related [flat|nested] 13+ messages in thread
* [meta-fsl-arm][PATCH 3/3] pulseaudio: Fix no sound issue after plugin/out headphone
2014-07-29 7:04 [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Jun Zhu
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 2/3] pulseaudio: Fix mutext issue when do pause in gstreamer Jun Zhu
@ 2014-07-29 7:04 ` Jun Zhu
2014-07-29 13:46 ` Otavio Salvador
2014-07-29 13:37 ` [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Otavio Salvador
2014-07-29 13:46 ` Daiane Angolini
3 siblings, 1 reply; 13+ messages in thread
From: Jun Zhu @ 2014-07-29 7:04 UTC (permalink / raw)
To: meta-freescale; +Cc: Jun Zhu
This issue found on the i.MX6 testing: when switch audio output
between headphone and speaker, sometimes it found no sound when
plugin headphone.
Root cause is the the core-subscribe.c has a defer queue for
audio sink's switch event and stores the status in database.
Because it is a defer queue, sometimes the stored status is changed
not as user expected.
Signed-off-by: Jun Zhu <R01007@freescale.com>
---
...here-is-no-sound-after-plugin-plugout-hea.patch | 127 ++++++++++++++++++++
.../pulseaudio/pulseaudio_5.0.bbappend | 1 +
2 files changed, 128 insertions(+)
create mode 100644 recipes-multimedia/pulseaudio/pulseaudio/0002-Fix-issue-there-is-no-sound-after-plugin-plugout-hea.patch
diff --git a/recipes-multimedia/pulseaudio/pulseaudio/0002-Fix-issue-there-is-no-sound-after-plugin-plugout-hea.patch b/recipes-multimedia/pulseaudio/pulseaudio/0002-Fix-issue-there-is-no-sound-after-plugin-plugout-hea.patch
new file mode 100644
index 0000000..0d4d73a
--- /dev/null
+++ b/recipes-multimedia/pulseaudio/pulseaudio/0002-Fix-issue-there-is-no-sound-after-plugin-plugout-hea.patch
@@ -0,0 +1,127 @@
+From 7dfff7e62296779dca9831598af082ee72bfed41 Mon Sep 17 00:00:00 2001
+From: Shengjiu Wang <b02247@freescale.com>
+Date: Mon, 5 May 2014 14:21:16 +0800
+Subject: [PATCH] Fix issue: there is no sound after plugin/plugout headphone
+
+In default config, when switching headphone with speaker, the unused one will
+be switch off. And pulseaudio will store the setting in the database for
+restore later, when switch back to the output path.
+But the core-subscribe.c has a defer queue for these events, like sink|new,
+sink|change, which will read the current switch status and store it in
+the database. Because it is a defer queue, sometimes the stored status is
+changed not as user's requirement. below is the call flow.
+
+init:
+ store on for speaker to database.
+ store on for headphone to database.
+---Activating analog-output-speaker
+ switch on speaker
+ switch off headphone
+----headphone plugin
+ ---analog-output-speaker status no
+ ---Activating analog-output
+ Queued event (SINK|CHANGE|0)
+ switch off speaker
+ switch off headphone
+ ---analog-output-headphone status yes
+ ---Activating analog-output-headphone
+ switch off speaker
+ switch off headphone
+ Dispatched event (SINK|CHANGE|0)
+ store off for headphone to database.
+
+Meantime the root cause is not found, a workaround is used by changing the
+configure file.
+
+Another change is remain the volume same as the asound.state.
+
+Upstream Status: N/A
+ - It is i.Mx specific
+
+Signed-off-by: Shengjiu Wang <b02247@freescale.com>
+---
+ .../alsa/mixer/paths/analog-output-headphones.conf | 8 ++++----
+ .../alsa/mixer/paths/analog-output-speaker.conf | 8 ++++----
+ src/modules/alsa/mixer/paths/analog-output.conf | 8 ++++----
+ 3 files changed, 12 insertions(+), 12 deletions(-)
+
+diff --git a/src/modules/alsa/mixer/paths/analog-output-headphones.conf b/src/modules/alsa/mixer/paths/analog-output-headphones.conf
+index b1a349a..7bfa79e 100644
+--- a/src/modules/alsa/mixer/paths/analog-output-headphones.conf
++++ b/src/modules/alsa/mixer/paths/analog-output-headphones.conf
+@@ -63,8 +63,8 @@ volume = off
+
+ [Element Headphone]
+ required-any = any
+-switch = mute
+-volume = merge
++switch = on
++volume = ignore
+ override-map.1 = all
+ override-map.2 = all-left,all-right
+
+@@ -86,8 +86,8 @@ switch = mute
+ volume = zero
+
+ [Element Speaker]
+-switch = off
+-volume = off
++switch = on
++volume = ignore
+
+ [Element Desktop Speaker]
+ switch = off
+diff --git a/src/modules/alsa/mixer/paths/analog-output-speaker.conf b/src/modules/alsa/mixer/paths/analog-output-speaker.conf
+index d79fad1..eae40a0 100644
+--- a/src/modules/alsa/mixer/paths/analog-output-speaker.conf
++++ b/src/modules/alsa/mixer/paths/analog-output-speaker.conf
+@@ -62,8 +62,8 @@ volume = off
+ ; This profile path is intended to control the speaker, let's mute headphones
+ ; else there will be a spike when plugging in headphones
+ [Element Headphone]
+-switch = off
+-volume = off
++switch = on
++volume = ignore
+
+ [Element Headphone2]
+ switch = off
+@@ -71,8 +71,8 @@ volume = off
+
+ [Element Speaker]
+ required-any = any
+-switch = mute
+-volume = merge
++switch = on
++volume = ignore
+ override-map.1 = all
+ override-map.2 = all-left,all-right
+
+diff --git a/src/modules/alsa/mixer/paths/analog-output.conf b/src/modules/alsa/mixer/paths/analog-output.conf
+index 3a552c9..bd5c12b 100644
+--- a/src/modules/alsa/mixer/paths/analog-output.conf
++++ b/src/modules/alsa/mixer/paths/analog-output.conf
+@@ -53,16 +53,16 @@ switch = off
+ ; headphones. But it should not hurt if we leave the headphone jack
+ ; enabled nonetheless.
+ [Element Headphone]
+-switch = mute
+-volume = zero
++switch = on
++volume = ignore
+
+ [Element Headphone2]
+ switch = mute
+ volume = zero
+
+ [Element Speaker]
+-switch = mute
+-volume = off
++switch = on
++volume = ignore
+
+ [Element Desktop Speaker]
+ switch = mute
+--
+1.7.9.5
+
diff --git a/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend b/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
index 4ea4921..5b2b1a9 100644
--- a/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
+++ b/recipes-multimedia/pulseaudio/pulseaudio_5.0.bbappend
@@ -6,6 +6,7 @@ FILESEXTRAPATHS_prepend := "${THISDIR}/${PN}:"
SRC_URI_append = " file://daemon.conf \
file://default.pa \
file://0001-Fix-pulseaudio-mutex-issue-when-do-pause-in-gstreame.patch \
+ file://0002-Fix-issue-there-is-no-sound-after-plugin-plugout-hea.patch \
"
do_install_append() {
--
1.7.9.5
^ permalink raw reply related [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-29 7:04 [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Jun Zhu
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 2/3] pulseaudio: Fix mutext issue when do pause in gstreamer Jun Zhu
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 3/3] pulseaudio: Fix no sound issue after plugin/out headphone Jun Zhu
@ 2014-07-29 13:37 ` Otavio Salvador
2014-07-30 8:08 ` junzhu
2014-07-29 13:46 ` Daiane Angolini
3 siblings, 1 reply; 13+ messages in thread
From: Otavio Salvador @ 2014-07-29 13:37 UTC (permalink / raw)
To: Jun Zhu; +Cc: meta-freescale@yoctoproject.org
Hello Jun,
On Tue, Jul 29, 2014 at 4:04 AM, Jun Zhu <R01007@freescale.com> wrote:
> on i.MX seriese boards, some pulseaudio defualt setting should be
> modified to improve the user experience:
> - Daemon's exit_idle_time: set value as -1 to make pulseaudio service
> never be terminated by any user-space app.
> - Resample mothed: switch to the build-in ffmpeg to improve the
> sound quality.
> - Flat_Volumes: set value as "no" to align with the normal use case.
>
> These customized configuration would be installed to overwrite the
> original version.
>
> Signed-off-by: Jun Zhu <R01007@freescale.com>
Your subject say's i.MX. Does it imply you tested it in all i.MX
platforms? Or this has been tested in i.MX6 only?
You seem to rely in ffmpeg, I fear this has license implications, does it not?
You patch needs to be adjusted to not include this files for other
machines. Please rework it.
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 2/3] pulseaudio: Fix mutext issue when do pause in gstreamer
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 2/3] pulseaudio: Fix mutext issue when do pause in gstreamer Jun Zhu
@ 2014-07-29 13:40 ` Otavio Salvador
0 siblings, 0 replies; 13+ messages in thread
From: Otavio Salvador @ 2014-07-29 13:40 UTC (permalink / raw)
To: Jun Zhu; +Cc: meta-freescale@yoctoproject.org
On Tue, Jul 29, 2014 at 4:04 AM, Jun Zhu <R01007@freescale.com> wrote:
> Pulseaudio crashes when other program using sound:
> Assertion 'pthread_mutex_unlock(&m->mutex) == 0' failed
> at pulsecore/mutex-posix.c:106, function pa_mutex_unlock().
>
> Disable PTHREAD priority inheritance feature is the easiest
> workaround solutions for this issue.
>
> Signed-off-by: Jun Zhu <R01007@freescale.com>
I think you can accomplish the same using:
pulseaudio_cv_PTHREAD_PRIO_INHERIT=no
in CACHED_CONFIGUREVARS as:
CACHED_CONFIGUREVARS_append_mx6 = "
pulseaudio_cv_PTHREAD_PRIO_INHERIT=no"
Can you give it a try?
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 3/3] pulseaudio: Fix no sound issue after plugin/out headphone
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 3/3] pulseaudio: Fix no sound issue after plugin/out headphone Jun Zhu
@ 2014-07-29 13:46 ` Otavio Salvador
0 siblings, 0 replies; 13+ messages in thread
From: Otavio Salvador @ 2014-07-29 13:46 UTC (permalink / raw)
To: Jun Zhu; +Cc: meta-freescale@yoctoproject.org
On Tue, Jul 29, 2014 at 4:04 AM, Jun Zhu <R01007@freescale.com> wrote:
> This issue found on the i.MX6 testing: when switch audio output
> between headphone and speaker, sometimes it found no sound when
> plugin headphone.
> Root cause is the the core-subscribe.c has a defer queue for
> audio sink's switch event and stores the status in database.
> Because it is a defer queue, sometimes the stored status is changed
> not as user expected.
>
> Signed-off-by: Jun Zhu <R01007@freescale.com>
The patch needs to be included only for i.MX6.
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-29 7:04 [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Jun Zhu
` (2 preceding siblings ...)
2014-07-29 13:37 ` [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Otavio Salvador
@ 2014-07-29 13:46 ` Daiane Angolini
3 siblings, 0 replies; 13+ messages in thread
From: Daiane Angolini @ 2014-07-29 13:46 UTC (permalink / raw)
To: Jun Zhu; +Cc: meta-freescale@yoctoproject.org
On Tue, Jul 29, 2014 at 4:04 AM, Jun Zhu <R01007@freescale.com> wrote:
> on i.MX seriese boards, some pulseaudio defualt setting should be
when you send v2, please not the typo "seriese"
> modified to improve the user experience:
> - Daemon's exit_idle_time: set value as -1 to make pulseaudio service
> never be terminated by any user-space app.
> - Resample mothed: switch to the build-in ffmpeg to improve the
typo "mothed"
Daiane
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-29 13:37 ` [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Otavio Salvador
@ 2014-07-30 8:08 ` junzhu
2014-07-30 12:44 ` Otavio Salvador
0 siblings, 1 reply; 13+ messages in thread
From: junzhu @ 2014-07-30 8:08 UTC (permalink / raw)
To: Otavio Salvador; +Cc: meta-freescale@yoctoproject.org
-----Original Message-----
From: otavio.salvador@gmail.com [mailto:otavio.salvador@gmail.com] On Behalf Of Otavio Salvador
Sent: Tuesday, July 29, 2014 9:38 PM
To: Zhu Jun-R01007
Cc: meta-freescale@yoctoproject.org
Subject: Re: [meta-freescale] [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
Hello Jun,
On Tue, Jul 29, 2014 at 4:04 AM, Jun Zhu <R01007@freescale.com> wrote:
> on i.MX seriese boards, some pulseaudio defualt setting should be
> modified to improve the user experience:
> - Daemon's exit_idle_time: set value as -1 to make pulseaudio service
> never be terminated by any user-space app.
> - Resample mothed: switch to the build-in ffmpeg to improve the sound
> quality.
> - Flat_Volumes: set value as "no" to align with the normal use case.
>
> These customized configuration would be installed to overwrite the
> original version.
>
> Signed-off-by: Jun Zhu <R01007@freescale.com>
Your subject say's i.MX. Does it imply you tested it in all i.MX platforms? Or this has been tested in i.MX6 only?
[Zhu Jun-R01007] It is only tested on i.Mx6, so I will adjust it in Patch v2
You seem to rely in ffmpeg, I fear this has license implications, does it not?
[Zhu Jun-R01007] PulseAudio has a built-in resample library from ffmpeg and code can be found under pulseaudio-5.0/src/pulsecore/ffmpeg. So it may not causes the license problem.
You patch needs to be adjusted to not include this files for other machines. Please rework it.
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-30 8:08 ` junzhu
@ 2014-07-30 12:44 ` Otavio Salvador
2014-07-31 9:42 ` junzhu
0 siblings, 1 reply; 13+ messages in thread
From: Otavio Salvador @ 2014-07-30 12:44 UTC (permalink / raw)
To: junzhu@freescale.com; +Cc: meta-freescale@yoctoproject.org
On Wed, Jul 30, 2014 at 5:08 AM, junzhu@freescale.com
<junzhu@freescale.com> wrote:
...
> Your subject say's i.MX. Does it imply you tested it in all i.MX platforms? Or this has been tested in i.MX6 only?
> [Zhu Jun-R01007] It is only tested on i.Mx6, so I will adjust it in Patch v2
Ok. Please rework it so it applies /only/ for the referred platform
and not all others.
> You seem to rely in ffmpeg, I fear this has license implications, does it not?
> [Zhu Jun-R01007] PulseAudio has a built-in resample library from ffmpeg and code can be found under pulseaudio-5.0/src/pulsecore/ffmpeg. So it may not causes the license problem.
Please give it a test without ffmpeg compiled to be sure of that. Does
the sound works in a system without ffmpeg?
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-30 12:44 ` Otavio Salvador
@ 2014-07-31 9:42 ` junzhu
2014-07-31 12:08 ` Otavio Salvador
0 siblings, 1 reply; 13+ messages in thread
From: junzhu @ 2014-07-31 9:42 UTC (permalink / raw)
To: Otavio Salvador; +Cc: meta-freescale@yoctoproject.org
Hi, Otavio,
PulseAudio's core contains the several algorithms for the resampler, and ffmpeg resample algorithm is one of them. So it can choose the algorithm by the Daemon configuration file
There is no configure option to disable ffmpeg resample when do the pulseaudio build. So we have to modify the source code to disable it. And the source code for ffmpeg resamplpe (src/pulsecore/ffmpeg) has the GNU Lesser General License.
Regards,
Jun Zhu
-----Original Message-----
From: otavio.salvador@gmail.com [mailto:otavio.salvador@gmail.com] On Behalf Of Otavio Salvador
Sent: Wednesday, July 30, 2014 8:45 PM
To: Zhu Jun-R01007
Cc: meta-freescale@yoctoproject.org
Subject: Re: [meta-freescale] [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
On Wed, Jul 30, 2014 at 5:08 AM, junzhu@freescale.com <junzhu@freescale.com> wrote:
...
> Your subject say's i.MX. Does it imply you tested it in all i.MX platforms? Or this has been tested in i.MX6 only?
> [Zhu Jun-R01007] It is only tested on i.Mx6, so I will adjust it in
> Patch v2
Ok. Please rework it so it applies /only/ for the referred platform and not all others.
> You seem to rely in ffmpeg, I fear this has license implications, does it not?
> [Zhu Jun-R01007] PulseAudio has a built-in resample library from ffmpeg and code can be found under pulseaudio-5.0/src/pulsecore/ffmpeg. So it may not causes the license problem.
Please give it a test without ffmpeg compiled to be sure of that. Does the sound works in a system without ffmpeg?
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-31 9:42 ` junzhu
@ 2014-07-31 12:08 ` Otavio Salvador
2014-07-31 12:09 ` Otavio Salvador
0 siblings, 1 reply; 13+ messages in thread
From: Otavio Salvador @ 2014-07-31 12:08 UTC (permalink / raw)
To: junzhu@freescale.com; +Cc: meta-freescale@yoctoproject.org
On Thu, Jul 31, 2014 at 6:42 AM, junzhu@freescale.com
<junzhu@freescale.com> wrote:
> PulseAudio's core contains the several algorithms for the resampler, and ffmpeg resample algorithm is one of them. So it can choose the algorithm by the Daemon configuration file
Yes, I got this.
My question is if the audio works
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-31 12:08 ` Otavio Salvador
@ 2014-07-31 12:09 ` Otavio Salvador
2014-07-31 15:46 ` Lauren Post
0 siblings, 1 reply; 13+ messages in thread
From: Otavio Salvador @ 2014-07-31 12:09 UTC (permalink / raw)
To: junzhu@freescale.com; +Cc: meta-freescale@yoctoproject.org
On Thu, Jul 31, 2014 at 9:08 AM, Otavio Salvador
<otavio@ossystems.com.br> wrote:
> On Thu, Jul 31, 2014 at 6:42 AM, junzhu@freescale.com
> <junzhu@freescale.com> wrote:
>> PulseAudio's core contains the several algorithms for the resampler, and ffmpeg resample algorithm is one of them. So it can choose the algorithm by the Daemon configuration file
>
> Yes, I got this.
>
> My question is if the audio works
(oops, send button too soon) ... works in case the system does not
have ffmpeg support? Does it uses a fallback mechanism? This needs
testing.
--
Otavio Salvador O.S. Systems
http://www.ossystems.com.br http://code.ossystems.com.br
Mobile: +55 (53) 9981-7854 Mobile: +1 (347) 903-9750
^ permalink raw reply [flat|nested] 13+ messages in thread
* Re: [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms
2014-07-31 12:09 ` Otavio Salvador
@ 2014-07-31 15:46 ` Lauren Post
0 siblings, 0 replies; 13+ messages in thread
From: Lauren Post @ 2014-07-31 15:46 UTC (permalink / raw)
To: Otavio Salvador, junzhu@freescale.com; +Cc: meta-freescale@yoctoproject.org
Otavio,
We build two images for testing, one is without ffmpeg. That is what our prebuilts have. Second image is internal only is one with ffmpeg (we use it to test license restricted component combinations like chromium). Both images use same pulse audio configuration.
So pulseaudio can be configured with a pulse audio ffmpeg block that works with and without ffmpeg. It does not require ffmpeg to work.
So to answer your question, pulse audio works with this configuration without having ffmpeg in the image.
Lauren
> <junzhu@freescale.com> wrote:
>> PulseAudio's core contains the several algorithms for the resampler,
>> and ffmpeg resample algorithm is one of them. So it can choose the
>> algorithm by the Daemon configuration file
>
> Yes, I got this.
>
> My question is if the audio works
(oops, send button too soon) ... works in case the system does not have ffmpeg support? Does it uses a fallback mechanism? This needs testing.
--
^ permalink raw reply [flat|nested] 13+ messages in thread
end of thread, other threads:[~2014-07-31 15:46 UTC | newest]
Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-07-29 7:04 [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Jun Zhu
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 2/3] pulseaudio: Fix mutext issue when do pause in gstreamer Jun Zhu
2014-07-29 13:40 ` Otavio Salvador
2014-07-29 7:04 ` [meta-fsl-arm][PATCH 3/3] pulseaudio: Fix no sound issue after plugin/out headphone Jun Zhu
2014-07-29 13:46 ` Otavio Salvador
2014-07-29 13:37 ` [meta-fsl-arm][PATCH 1/3] pulseaudio: Customize pulseaudio configuration for i.MX platforms Otavio Salvador
2014-07-30 8:08 ` junzhu
2014-07-30 12:44 ` Otavio Salvador
2014-07-31 9:42 ` junzhu
2014-07-31 12:08 ` Otavio Salvador
2014-07-31 12:09 ` Otavio Salvador
2014-07-31 15:46 ` Lauren Post
2014-07-29 13:46 ` Daiane Angolini
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.