mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 01:45:33 +00:00
sys/sunaudio/: Attached find a patch that fixes a number of bugs with the SunAudio mixer plugin and fixes #344101: 1....
Original commit message from CVS: Patch by: Brian Cameron <brian dot cameron at sun dot com> * sys/sunaudio/gstsunaudiomixerctrl.c: (gst_sunaudiomixer_ctrl_open), (gst_sunaudiomixer_ctrl_build_list), (gst_sunaudiomixer_ctrl_new), (gst_sunaudiomixer_ctrl_set_volume), (gst_sunaudiomixer_ctrl_set_mute): * sys/sunaudio/gstsunaudiosink.c: (gst_sunaudiosink_class_init), (gst_sunaudiosink_init), (gst_sunaudiosink_prepare), (gst_sunaudiosink_write): Attached find a patch that fixes a number of bugs with the SunAudio mixer plugin and fixes #344101: 1. The gst_sunaudiomixer_ctrl_build_list kept appending the same 3 tracks onto the tracklist causing gnome-volume-control's preferences dialog to be messed up and would core dump if you checked/unchecked any item. 2. We weren't previously setting the MUTE flag properly. Fixing this makes gnome-volume-control work better. 3. Now we properly define the input track to be GST_MIXER_TRACK_INPUT and the monitor to be GST_MIXER_TRACK_OUTPUT, so that makes gnome-volume-control look better. Also some minor cleanup in gstsunaudiosink.c.
This commit is contained in:
parent
78d078e986
commit
6052579ae4
3 changed files with 67 additions and 32 deletions
24
ChangeLog
24
ChangeLog
|
@ -1,3 +1,27 @@
|
||||||
|
2006-06-09 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
|
Patch by: Brian Cameron <brian dot cameron at sun dot com>
|
||||||
|
|
||||||
|
* sys/sunaudio/gstsunaudiomixerctrl.c:
|
||||||
|
(gst_sunaudiomixer_ctrl_open), (gst_sunaudiomixer_ctrl_build_list),
|
||||||
|
(gst_sunaudiomixer_ctrl_new), (gst_sunaudiomixer_ctrl_set_volume),
|
||||||
|
(gst_sunaudiomixer_ctrl_set_mute):
|
||||||
|
* sys/sunaudio/gstsunaudiosink.c: (gst_sunaudiosink_class_init),
|
||||||
|
(gst_sunaudiosink_init), (gst_sunaudiosink_prepare),
|
||||||
|
(gst_sunaudiosink_write):
|
||||||
|
Attached find a patch that fixes a number of bugs with the SunAudio mixer
|
||||||
|
plugin and fixes #344101:
|
||||||
|
1. The gst_sunaudiomixer_ctrl_build_list kept appending the same 3 tracks onto
|
||||||
|
the tracklist causing gnome-volume-control's preferences dialog to be messed
|
||||||
|
up and would core dump if you checked/unchecked any item.
|
||||||
|
2. We weren't previously setting the MUTE flag properly. Fixing this makes
|
||||||
|
gnome-volume-control work better.
|
||||||
|
3. Now we properly define the input track to be GST_MIXER_TRACK_INPUT and
|
||||||
|
the monitor to be GST_MIXER_TRACK_OUTPUT, so that makes gnome-volume-control
|
||||||
|
look better.
|
||||||
|
Also some minor cleanup in gstsunaudiosink.c.
|
||||||
|
|
||||||
|
|
||||||
2006-06-09 Wim Taymans <wim@fluendo.com>
|
2006-06-09 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
* ext/jpeg/gstjpegdec.c: (gst_idct_method_get_type),
|
* ext/jpeg/gstjpegdec.c: (gst_idct_method_get_type),
|
||||||
|
|
|
@ -38,43 +38,48 @@
|
||||||
#define SCALE_FACTOR 2.55 /* 255/100 */
|
#define SCALE_FACTOR 2.55 /* 255/100 */
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_sunaudiomixer_ctrl_open (GstSunAudioMixerCtrl * sunaudio)
|
gst_sunaudiomixer_ctrl_open (GstSunAudioMixerCtrl * mixer)
|
||||||
{
|
{
|
||||||
int fd;
|
int fd;
|
||||||
|
|
||||||
/* First try to open non-blocking */
|
/* First try to open non-blocking */
|
||||||
fd = open (sunaudio->device, O_RDWR | O_NONBLOCK);
|
fd = open (mixer->device, O_RDWR | O_NONBLOCK);
|
||||||
|
|
||||||
if (fd >= 0) {
|
if (fd >= 0) {
|
||||||
close (fd);
|
close (fd);
|
||||||
fd = open (sunaudio->device, O_WRONLY);
|
fd = open (mixer->device, O_WRONLY);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fd == -1) {
|
if (fd == -1) {
|
||||||
GST_DEBUG_OBJECT (sunaudio,
|
GST_DEBUG_OBJECT (mixer,
|
||||||
"Failed to open mixer device %s, mixing disabled: %s", sunaudio->device,
|
"Failed to open mixer device %s, mixing disabled: %s", mixer->device,
|
||||||
strerror (errno));
|
strerror (errno));
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
sunaudio->mixer_fd = fd;
|
mixer->mixer_fd = fd;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gst_sunaudiomixer_ctrl_build_list (GstSunAudioMixerCtrl * sunaudio)
|
gst_sunaudiomixer_ctrl_build_list (GstSunAudioMixerCtrl * mixer)
|
||||||
{
|
{
|
||||||
GstMixerTrack *track;
|
GstMixerTrack *track;
|
||||||
|
|
||||||
g_return_if_fail (sunaudio->mixer_fd != -1);
|
g_return_if_fail (mixer->mixer_fd != -1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Do not continue appending the same 3 static tracks onto the list
|
||||||
|
*/
|
||||||
|
if (mixer->tracklist == NULL) {
|
||||||
track = gst_sunaudiomixer_track_new (0, 1, GST_MIXER_TRACK_OUTPUT);
|
track = gst_sunaudiomixer_track_new (0, 1, GST_MIXER_TRACK_OUTPUT);
|
||||||
sunaudio->tracklist = g_list_append (sunaudio->tracklist, track);
|
mixer->tracklist = g_list_append (mixer->tracklist, track);
|
||||||
track = gst_sunaudiomixer_track_new (1, 1, 0);
|
track = gst_sunaudiomixer_track_new (1, 1, GST_MIXER_TRACK_INPUT);
|
||||||
sunaudio->tracklist = g_list_append (sunaudio->tracklist, track);
|
mixer->tracklist = g_list_append (mixer->tracklist, track);
|
||||||
track = gst_sunaudiomixer_track_new (2, 1, 0);
|
track = gst_sunaudiomixer_track_new (2, 1, GST_MIXER_TRACK_OUTPUT);
|
||||||
sunaudio->tracklist = g_list_append (sunaudio->tracklist, track);
|
mixer->tracklist = g_list_append (mixer->tracklist, track);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GstSunAudioMixerCtrl *
|
GstSunAudioMixerCtrl *
|
||||||
|
@ -88,6 +93,7 @@ gst_sunaudiomixer_ctrl_new (const char *device)
|
||||||
|
|
||||||
ret->device = g_strdup (device);
|
ret->device = g_strdup (device);
|
||||||
ret->mixer_fd = -1;
|
ret->mixer_fd = -1;
|
||||||
|
ret->tracklist = NULL;
|
||||||
|
|
||||||
if (!gst_sunaudiomixer_ctrl_open (ret))
|
if (!gst_sunaudiomixer_ctrl_open (ret))
|
||||||
goto error;
|
goto error;
|
||||||
|
@ -172,7 +178,10 @@ gst_sunaudiomixer_ctrl_set_volume (GstSunAudioMixerCtrl * mixer,
|
||||||
|
|
||||||
g_return_if_fail (mixer->mixer_fd != -1);
|
g_return_if_fail (mixer->mixer_fd != -1);
|
||||||
|
|
||||||
volume = volumes[0] * SCALE_FACTOR + 0.5;
|
if (volume < 0)
|
||||||
|
volume = 0;
|
||||||
|
|
||||||
|
volume = volumes[0] * SCALE_FACTOR;
|
||||||
|
|
||||||
/* Set the volume */
|
/* Set the volume */
|
||||||
AUDIO_INITINFO (&audioinfo);
|
AUDIO_INITINFO (&audioinfo);
|
||||||
|
@ -198,29 +207,33 @@ gst_sunaudiomixer_ctrl_set_volume (GstSunAudioMixerCtrl * mixer,
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gst_sunaudiomixer_ctrl_set_mute (GstSunAudioMixerCtrl * sunaudio,
|
gst_sunaudiomixer_ctrl_set_mute (GstSunAudioMixerCtrl * mixer,
|
||||||
GstMixerTrack * track, gboolean mute)
|
GstMixerTrack * track, gboolean mute)
|
||||||
{
|
{
|
||||||
struct audio_info audioinfo;
|
struct audio_info audioinfo;
|
||||||
GstSunAudioMixerTrack *sunaudiotrack = GST_SUNAUDIO_MIXER_TRACK (track);
|
GstSunAudioMixerTrack *sunaudiotrack = GST_SUNAUDIO_MIXER_TRACK (track);
|
||||||
gint volume;
|
gint volume;
|
||||||
|
|
||||||
g_return_if_fail (sunaudio->mixer_fd != -1);
|
g_return_if_fail (mixer->mixer_fd != -1);
|
||||||
if (sunaudiotrack->track_num != 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
AUDIO_INITINFO (&audioinfo);
|
AUDIO_INITINFO (&audioinfo);
|
||||||
|
|
||||||
if (mute) {
|
if (mute) {
|
||||||
audioinfo.output_muted = 1;
|
|
||||||
volume = 0;
|
volume = 0;
|
||||||
|
track->flags |= GST_MIXER_TRACK_MUTE;
|
||||||
} else {
|
} else {
|
||||||
audioinfo.output_muted = 0;
|
|
||||||
volume = sunaudiotrack->vol;
|
volume = sunaudiotrack->vol;
|
||||||
|
track->flags &= ~GST_MIXER_TRACK_MUTE;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (sunaudiotrack->track_num) {
|
switch (sunaudiotrack->track_num) {
|
||||||
case 0:
|
case 0:
|
||||||
|
|
||||||
|
if (mute)
|
||||||
|
audioinfo.output_muted = 1;
|
||||||
|
else
|
||||||
|
audioinfo.output_muted = 0;
|
||||||
|
|
||||||
audioinfo.play.gain = volume;
|
audioinfo.play.gain = volume;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
|
@ -231,7 +244,7 @@ gst_sunaudiomixer_ctrl_set_mute (GstSunAudioMixerCtrl * sunaudio,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ioctl (sunaudio->mixer_fd, AUDIO_SETINFO, &audioinfo) < 0) {
|
if (ioctl (mixer->mixer_fd, AUDIO_SETINFO, &audioinfo) < 0) {
|
||||||
g_warning ("Error setting audio device volume");
|
g_warning ("Error setting audio device volume");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -160,10 +160,6 @@ gst_sunaudiosink_class_init (GstSunAudioSinkClass * klass)
|
||||||
gobject_class->get_property =
|
gobject_class->get_property =
|
||||||
GST_DEBUG_FUNCPTR (gst_sunaudiosink_get_property);
|
GST_DEBUG_FUNCPTR (gst_sunaudiosink_get_property);
|
||||||
|
|
||||||
g_object_class_install_property (gobject_class, PROP_DEVICE,
|
|
||||||
g_param_spec_string ("device", "Device", "Audio Device (/dev/audio)",
|
|
||||||
DEFAULT_DEVICE, G_PARAM_READWRITE));
|
|
||||||
|
|
||||||
gstbasesink_class->get_caps = GST_DEBUG_FUNCPTR (gst_sunaudiosink_getcaps);
|
gstbasesink_class->get_caps = GST_DEBUG_FUNCPTR (gst_sunaudiosink_getcaps);
|
||||||
|
|
||||||
gstaudiosink_class->open = GST_DEBUG_FUNCPTR (gst_sunaudiosink_open);
|
gstaudiosink_class->open = GST_DEBUG_FUNCPTR (gst_sunaudiosink_open);
|
||||||
|
@ -174,17 +170,22 @@ gst_sunaudiosink_class_init (GstSunAudioSinkClass * klass)
|
||||||
gstaudiosink_class->write = GST_DEBUG_FUNCPTR (gst_sunaudiosink_write);
|
gstaudiosink_class->write = GST_DEBUG_FUNCPTR (gst_sunaudiosink_write);
|
||||||
gstaudiosink_class->delay = GST_DEBUG_FUNCPTR (gst_sunaudiosink_delay);
|
gstaudiosink_class->delay = GST_DEBUG_FUNCPTR (gst_sunaudiosink_delay);
|
||||||
gstaudiosink_class->reset = GST_DEBUG_FUNCPTR (gst_sunaudiosink_reset);
|
gstaudiosink_class->reset = GST_DEBUG_FUNCPTR (gst_sunaudiosink_reset);
|
||||||
|
|
||||||
|
g_object_class_install_property (gobject_class, PROP_DEVICE,
|
||||||
|
g_param_spec_string ("device", "Device", "Audio Device (/dev/audio)",
|
||||||
|
DEFAULT_DEVICE, G_PARAM_READWRITE));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_sunaudiosink_init (GstSunAudioSink * sunaudiosink)
|
gst_sunaudiosink_init (GstSunAudioSink * sunaudiosink)
|
||||||
{
|
{
|
||||||
const char *audiodev;
|
const char *audiodev;
|
||||||
GstClockTime buffer_time;
|
|
||||||
GValue gvalue = { 0, };
|
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (sunaudiosink, "initializing sunaudiosink");
|
GST_DEBUG_OBJECT (sunaudiosink, "initializing sunaudiosink");
|
||||||
|
|
||||||
|
sunaudiosink->fd = -1;
|
||||||
|
|
||||||
audiodev = g_getenv ("AUDIODEV");
|
audiodev = g_getenv ("AUDIODEV");
|
||||||
if (audiodev == NULL)
|
if (audiodev == NULL)
|
||||||
audiodev = DEFAULT_DEVICE;
|
audiodev = DEFAULT_DEVICE;
|
||||||
|
@ -340,7 +341,6 @@ gst_sunaudiosink_prepare (GstAudioSink * asink, GstRingBufferSpec * spec)
|
||||||
ainfo.play.precision = spec->width;
|
ainfo.play.precision = spec->width;
|
||||||
ainfo.play.encoding = AUDIO_ENCODING_LINEAR;
|
ainfo.play.encoding = AUDIO_ENCODING_LINEAR;
|
||||||
ainfo.play.port = ports;
|
ainfo.play.port = ports;
|
||||||
ainfo.output_muted = 0;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* SunAudio doesn't really give access to buffer size, these values work. Setting
|
* SunAudio doesn't really give access to buffer size, these values work. Setting
|
||||||
|
@ -376,9 +376,7 @@ gst_sunaudiosink_unprepare (GstAudioSink * asink)
|
||||||
static guint
|
static guint
|
||||||
gst_sunaudiosink_write (GstAudioSink * asink, gpointer data, guint length)
|
gst_sunaudiosink_write (GstAudioSink * asink, gpointer data, guint length)
|
||||||
{
|
{
|
||||||
GstSunAudioSink *sunaudiosink = GST_SUNAUDIO_SINK (asink);
|
return write (GST_SUNAUDIO_SINK (asink)->fd, data, length);
|
||||||
|
|
||||||
return write (sunaudiosink->fd, data, length);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in a new issue