mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 06:58:49 +00:00
- Don't misuse fragment property for storing the fragment size
Original commit message from CVS: - Don't misuse fragment property for storing the fragment size - Better property descriptions - correctly calculate fragment_time
This commit is contained in:
parent
629bc459df
commit
a8b166e3e4
1 changed files with 41 additions and 35 deletions
|
@ -219,30 +219,29 @@ gst_osssink_class_init (GstOssSinkClass *klass)
|
||||||
parent_class = g_type_class_ref(GST_TYPE_ELEMENT);
|
parent_class = g_type_class_ref(GST_TYPE_ELEMENT);
|
||||||
|
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_DEVICE,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_DEVICE,
|
||||||
g_param_spec_string("device","device","device",
|
g_param_spec_string ("device", "Device", "The device to use for output",
|
||||||
"/dev/dsp", G_PARAM_READWRITE)); /* CHECKME! */
|
"/dev/dsp", G_PARAM_READWRITE)); /* CHECKME! */
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_MUTE,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_MUTE,
|
||||||
g_param_spec_boolean("mute","mute","mute",
|
g_param_spec_boolean ("mute", "Mute", "Mute the audio",
|
||||||
TRUE, G_PARAM_READWRITE));
|
TRUE, G_PARAM_READWRITE));
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_SYNC,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_SYNC,
|
||||||
g_param_spec_boolean ("sync", "Sync", "If syncing on timestamps should be enabled",
|
g_param_spec_boolean ("sync", "Sync", "If syncing on timestamps should be enabled",
|
||||||
TRUE, G_PARAM_READWRITE));
|
TRUE, G_PARAM_READWRITE));
|
||||||
|
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FORMAT,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FORMAT,
|
||||||
g_param_spec_enum ("format","format","format",
|
g_param_spec_enum ("format", "Format", "The format the device is configured for",
|
||||||
GST_TYPE_OSSSINK_FORMAT, AFMT_S16_LE, G_PARAM_READWRITE));
|
GST_TYPE_OSSSINK_FORMAT, AFMT_S16_LE, G_PARAM_READWRITE));
|
||||||
|
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_CHANNELS,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_CHANNELS,
|
||||||
g_param_spec_enum("channels","channels","channels",
|
g_param_spec_enum ("channels", "Channels", "The number of channels used for playback",
|
||||||
GST_TYPE_OSSSINK_CHANNELS, 2, G_PARAM_READWRITE));
|
GST_TYPE_OSSSINK_CHANNELS, 2, G_PARAM_READWRITE));
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FREQUENCY,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FREQUENCY,
|
||||||
g_param_spec_int("frequency","frequency","frequency",
|
g_param_spec_int ("frequency", "Frequency", "The frequency of the device",
|
||||||
0,G_MAXINT,44100,G_PARAM_READWRITE));
|
0, 48000, 44100, G_PARAM_READWRITE));
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FRAGMENT,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FRAGMENT,
|
||||||
g_param_spec_int("fragment","fragment","fragment",
|
g_param_spec_int ("fragment", "Fragment",
|
||||||
|
"The fragment as 0xMMMMSSSS (MMMM = total fragments, 2^SSSS = fragment size)",
|
||||||
0, G_MAXINT, 6, G_PARAM_READWRITE));
|
0, G_MAXINT, 6, G_PARAM_READWRITE));
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_BUFFER_SIZE,
|
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_BUFFER_SIZE,
|
||||||
g_param_spec_int("buffer_size","buffer_size","buffer_size",
|
g_param_spec_int ("buffer_size", "Buffer size", "The buffer size",
|
||||||
0, G_MAXINT, 4096, G_PARAM_READWRITE));
|
0, G_MAXINT, 4096, G_PARAM_READWRITE));
|
||||||
|
|
||||||
gst_osssink_signals[SIGNAL_HANDOFF] =
|
gst_osssink_signals[SIGNAL_HANDOFF] =
|
||||||
|
@ -384,6 +383,7 @@ gst_osssink_sync_parms (GstOssSink *osssink)
|
||||||
gint target_channels;
|
gint target_channels;
|
||||||
gint target_frequency;
|
gint target_frequency;
|
||||||
GObject *object;
|
GObject *object;
|
||||||
|
gint fragscale, frag_ln;
|
||||||
|
|
||||||
g_return_val_if_fail (osssink != NULL, FALSE);
|
g_return_val_if_fail (osssink != NULL, FALSE);
|
||||||
g_return_val_if_fail (GST_IS_OSSSINK (osssink), FALSE);
|
g_return_val_if_fail (GST_IS_OSSSINK (osssink), FALSE);
|
||||||
|
@ -412,9 +412,18 @@ gst_osssink_sync_parms (GstOssSink *osssink)
|
||||||
ioctl (osssink->fd, SNDCTL_DSP_CHANNELS, &osssink->channels);
|
ioctl (osssink->fd, SNDCTL_DSP_CHANNELS, &osssink->channels);
|
||||||
ioctl (osssink->fd, SNDCTL_DSP_SPEED, &osssink->frequency);
|
ioctl (osssink->fd, SNDCTL_DSP_SPEED, &osssink->frequency);
|
||||||
|
|
||||||
ioctl (osssink->fd, SNDCTL_DSP_GETBLKSIZE, &osssink->fragment);
|
ioctl (osssink->fd, SNDCTL_DSP_GETBLKSIZE, &osssink->fragment_size);
|
||||||
ioctl (osssink->fd, SNDCTL_DSP_GETOSPACE, &ospace);
|
ioctl (osssink->fd, SNDCTL_DSP_GETOSPACE, &ospace);
|
||||||
|
|
||||||
|
/* calculate new fragment using a poor man's logarithm function */
|
||||||
|
fragscale = 1;
|
||||||
|
frag_ln = 0;
|
||||||
|
while (fragscale < ospace.fragsize) {
|
||||||
|
fragscale <<= 1;
|
||||||
|
frag_ln++;
|
||||||
|
}
|
||||||
|
osssink->fragment = ospace.fragstotal << 16 | frag_ln;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "osssink: set sound card to %dHz %d bit %s (%d bytes buffer, %08x fragment)",
|
GST_INFO (GST_CAT_PLUGIN_INFO, "osssink: set sound card to %dHz %d bit %s (%d bytes buffer, %08x fragment)",
|
||||||
osssink->frequency, osssink->format,
|
osssink->frequency, osssink->format,
|
||||||
(osssink->channels == 2) ? "stereo" : "mono", ospace.bytes, osssink->fragment);
|
(osssink->channels == 2) ? "stereo" : "mono", ospace.bytes, osssink->fragment);
|
||||||
|
@ -427,7 +436,7 @@ gst_osssink_sync_parms (GstOssSink *osssink)
|
||||||
g_object_notify (object, "format");
|
g_object_notify (object, "format");
|
||||||
g_object_thaw_notify (object);
|
g_object_thaw_notify (object);
|
||||||
|
|
||||||
osssink->fragment_time = (1000000 * osssink->fragment) / osssink->bps;
|
osssink->fragment_time = (GST_SECOND * osssink->fragment_size) / osssink->bps;
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "fragment time %u %llu\n", osssink->bps, osssink->fragment_time);
|
GST_INFO (GST_CAT_PLUGIN_INFO, "fragment time %u %llu\n", osssink->bps, osssink->fragment_time);
|
||||||
|
|
||||||
if (target_format != osssink->format ||
|
if (target_format != osssink->format ||
|
||||||
|
@ -480,10 +489,6 @@ gst_osssink_get_time (GstClock *clock, gpointer data)
|
||||||
}
|
}
|
||||||
res = (osssink->handled - delay) * GST_SECOND / osssink->bps;
|
res = (osssink->handled - delay) * GST_SECOND / osssink->bps;
|
||||||
|
|
||||||
/*
|
|
||||||
g_print ("from osssink: %lld %d %lld %d\n", res, delay, osssink->handled, osssink->bps);
|
|
||||||
*/
|
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -928,6 +933,7 @@ gst_osssink_change_state (GstElement *element)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case GST_STATE_READY_TO_PAUSED:
|
case GST_STATE_READY_TO_PAUSED:
|
||||||
|
break;
|
||||||
case GST_STATE_PAUSED_TO_PLAYING:
|
case GST_STATE_PAUSED_TO_PLAYING:
|
||||||
osssink->resync = TRUE;
|
osssink->resync = TRUE;
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue