riff: Remove sample rate and channel count boundaries in caps

WAV is too generic to impose more-or-less arbitrary boundaries on the
sample rate and channel count caps. For example, there are 384 kHz WAV
files. Another example: it is in theory possible that somebody puts DSD
data into a WAV file, which will then have a sample rate of ~2.8 MHz.

For this reason, get rid of the rate and channel caps unless they are
fixed values. Downstream anyway usually knows the limitations better.

https://bugzilla.gnome.org/show_bug.cgi?id=761514
This commit is contained in:
Carlos Rafael Giani 2016-08-02 12:03:18 +02:00 committed by Sebastian Dröge
parent e5a67d71f7
commit 9adaeb0a71

View File

@ -1203,8 +1203,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
{ {
gboolean block_align = FALSE, rate_chan = TRUE; gboolean block_align = FALSE, rate_chan = TRUE;
GstCaps *caps = NULL; GstCaps *caps = NULL;
gint rate_min = 1000, rate_max = 96000;
gint channels_max = 2;
gint i; gint i;
if (channel_reorder_map) if (channel_reorder_map)
@ -1213,9 +1211,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
switch (codec_id) { switch (codec_id) {
case GST_RIFF_WAVE_FORMAT_PCM: /* PCM */ case GST_RIFF_WAVE_FORMAT_PCM: /* PCM */
rate_max = 192000;
channels_max = 8;
if (strf != NULL) { if (strf != NULL) {
gint ba = strf->blockalign; gint ba = strf->blockalign;
gint ch = strf->channels; gint ch = strf->channels;
@ -1299,9 +1294,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
break; break;
case GST_RIFF_WAVE_FORMAT_IEEE_FLOAT: case GST_RIFF_WAVE_FORMAT_IEEE_FLOAT:
rate_max = 192000;
channels_max = 8;
if (strf != NULL) { if (strf != NULL) {
gint ba = strf->blockalign; gint ba = strf->blockalign;
gint ch = strf->channels; gint ch = strf->channels;
@ -1351,7 +1343,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
strf->av_bps = strf->blockalign * strf->rate; strf->av_bps = strf->blockalign * strf->rate;
} }
} }
rate_max = 48000;
caps = gst_caps_new_empty_simple ("audio/x-alaw"); caps = gst_caps_new_empty_simple ("audio/x-alaw");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("A-law audio"); *codec_name = g_strdup ("A-law audio");
@ -1389,7 +1380,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
strf->av_bps = strf->blockalign * strf->rate; strf->av_bps = strf->blockalign * strf->rate;
} }
} }
rate_max = 48000;
caps = gst_caps_new_empty_simple ("audio/x-mulaw"); caps = gst_caps_new_empty_simple ("audio/x-mulaw");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("Mu-law audio"); *codec_name = g_strdup ("Mu-law audio");
@ -1420,9 +1410,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
break; break;
case GST_RIFF_WAVE_FORMAT_ITU_G726_ADPCM: case GST_RIFF_WAVE_FORMAT_ITU_G726_ADPCM:
rate_min = 8000;
rate_max = 8000;
channels_max = 1;
if (strf != NULL) { if (strf != NULL) {
gint bitrate; gint bitrate;
bitrate = 0; bitrate = 0;
@ -1451,8 +1438,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
break; break;
case GST_RIFF_WAVE_FORMAT_DSP_TRUESPEECH: case GST_RIFF_WAVE_FORMAT_DSP_TRUESPEECH:
rate_min = 8000;
rate_max = 8000;
caps = gst_caps_new_empty_simple ("audio/x-truespeech"); caps = gst_caps_new_empty_simple ("audio/x-truespeech");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("DSP Group TrueSpeech"); *codec_name = g_strdup ("DSP Group TrueSpeech");
@ -1460,15 +1445,12 @@ gst_riff_create_audio_caps (guint16 codec_id,
case GST_RIFF_WAVE_FORMAT_GSM610: case GST_RIFF_WAVE_FORMAT_GSM610:
case GST_RIFF_WAVE_FORMAT_MSN: case GST_RIFF_WAVE_FORMAT_MSN:
rate_min = 1;
caps = gst_caps_new_empty_simple ("audio/ms-gsm"); caps = gst_caps_new_empty_simple ("audio/ms-gsm");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("MS GSM audio"); *codec_name = g_strdup ("MS GSM audio");
break; break;
case GST_RIFF_WAVE_FORMAT_MPEGL12: /* mp1 or mp2 */ case GST_RIFF_WAVE_FORMAT_MPEGL12: /* mp1 or mp2 */
rate_min = 16000;
rate_max = 48000;
caps = gst_caps_new_simple ("audio/mpeg", caps = gst_caps_new_simple ("audio/mpeg",
"mpegversion", G_TYPE_INT, 1, "layer", G_TYPE_INT, 2, NULL); "mpegversion", G_TYPE_INT, 1, "layer", G_TYPE_INT, 2, NULL);
if (codec_name) if (codec_name)
@ -1476,8 +1458,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
break; break;
case GST_RIFF_WAVE_FORMAT_MPEGL3: /* mp3 */ case GST_RIFF_WAVE_FORMAT_MPEGL3: /* mp3 */
rate_min = 8000;
rate_max = 48000;
caps = gst_caps_new_simple ("audio/mpeg", caps = gst_caps_new_simple ("audio/mpeg",
"mpegversion", G_TYPE_INT, 1, "layer", G_TYPE_INT, 3, NULL); "mpegversion", G_TYPE_INT, 1, "layer", G_TYPE_INT, 3, NULL);
if (codec_name) if (codec_name)
@ -1485,18 +1465,12 @@ gst_riff_create_audio_caps (guint16 codec_id,
break; break;
case GST_RIFF_WAVE_FORMAT_AMR_NB: /* amr-nb */ case GST_RIFF_WAVE_FORMAT_AMR_NB: /* amr-nb */
rate_min = 8000;
rate_max = 8000;
channels_max = 1;
caps = gst_caps_new_empty_simple ("audio/AMR"); caps = gst_caps_new_empty_simple ("audio/AMR");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("AMR Narrow Band (NB)"); *codec_name = g_strdup ("AMR Narrow Band (NB)");
break; break;
case GST_RIFF_WAVE_FORMAT_AMR_WB: /* amr-wb */ case GST_RIFF_WAVE_FORMAT_AMR_WB: /* amr-wb */
rate_min = 16000;
rate_max = 16000;
channels_max = 1;
caps = gst_caps_new_empty_simple ("audio/AMR-WB"); caps = gst_caps_new_empty_simple ("audio/AMR-WB");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("AMR Wide Band (WB)"); *codec_name = g_strdup ("AMR Wide Band (WB)");
@ -1508,20 +1482,17 @@ gst_riff_create_audio_caps (guint16 codec_id,
case GST_RIFF_WAVE_FORMAT_VORBIS1PLUS: /* ogg/vorbis mode 1+ */ case GST_RIFF_WAVE_FORMAT_VORBIS1PLUS: /* ogg/vorbis mode 1+ */
case GST_RIFF_WAVE_FORMAT_VORBIS2PLUS: /* ogg/vorbis mode 2+ */ case GST_RIFF_WAVE_FORMAT_VORBIS2PLUS: /* ogg/vorbis mode 2+ */
case GST_RIFF_WAVE_FORMAT_VORBIS3PLUS: /* ogg/vorbis mode 3+ */ case GST_RIFF_WAVE_FORMAT_VORBIS3PLUS: /* ogg/vorbis mode 3+ */
rate_max = 192000;
caps = gst_caps_new_empty_simple ("audio/x-vorbis"); caps = gst_caps_new_empty_simple ("audio/x-vorbis");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("Vorbis"); *codec_name = g_strdup ("Vorbis");
break; break;
case GST_RIFF_WAVE_FORMAT_A52: case GST_RIFF_WAVE_FORMAT_A52:
channels_max = 6;
caps = gst_caps_new_empty_simple ("audio/x-ac3"); caps = gst_caps_new_empty_simple ("audio/x-ac3");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("AC-3 audio"); *codec_name = g_strdup ("AC-3 audio");
break; break;
case GST_RIFF_WAVE_FORMAT_DTS: case GST_RIFF_WAVE_FORMAT_DTS:
channels_max = 6;
caps = gst_caps_new_empty_simple ("audio/x-dts"); caps = gst_caps_new_empty_simple ("audio/x-dts");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("DTS audio"); *codec_name = g_strdup ("DTS audio");
@ -1532,7 +1503,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
case GST_RIFF_WAVE_FORMAT_AAC_AC: case GST_RIFF_WAVE_FORMAT_AAC_AC:
case GST_RIFF_WAVE_FORMAT_AAC_pm: case GST_RIFF_WAVE_FORMAT_AAC_pm:
{ {
channels_max = 8;
caps = gst_caps_new_simple ("audio/mpeg", caps = gst_caps_new_simple ("audio/mpeg",
"mpegversion", G_TYPE_INT, 4, NULL); "mpegversion", G_TYPE_INT, 4, NULL);
if (codec_name) if (codec_name)
@ -1546,7 +1516,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
{ {
gint version = (codec_id - GST_RIFF_WAVE_FORMAT_WMAV1) + 1; gint version = (codec_id - GST_RIFF_WAVE_FORMAT_WMAV1) + 1;
channels_max = 8;
block_align = TRUE; block_align = TRUE;
caps = gst_caps_new_simple ("audio/x-wma", caps = gst_caps_new_simple ("audio/x-wma",
@ -1583,9 +1552,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
break; break;
case GST_RIFF_WAVE_FORMAT_ADPCM_IMA_DK4: case GST_RIFF_WAVE_FORMAT_ADPCM_IMA_DK4:
rate_min = 8000;
rate_max = 96000;
channels_max = 2;
caps = caps =
gst_caps_new_simple ("audio/x-adpcm", "layout", G_TYPE_STRING, "dk4", gst_caps_new_simple ("audio/x-adpcm", "layout", G_TYPE_STRING, "dk4",
NULL); NULL);
@ -1593,9 +1559,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
*codec_name = g_strdup ("IMA/DK4 ADPCM"); *codec_name = g_strdup ("IMA/DK4 ADPCM");
break; break;
case GST_RIFF_WAVE_FORMAT_ADPCM_IMA_DK3: case GST_RIFF_WAVE_FORMAT_ADPCM_IMA_DK3:
rate_min = 8000;
rate_max = 96000;
channels_max = 2;
caps = caps =
gst_caps_new_simple ("audio/x-adpcm", "layout", G_TYPE_STRING, "dk3", gst_caps_new_simple ("audio/x-adpcm", "layout", G_TYPE_STRING, "dk3",
NULL); NULL);
@ -1604,9 +1567,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
break; break;
case GST_RIFF_WAVE_FORMAT_ADPCM_IMA_WAV: case GST_RIFF_WAVE_FORMAT_ADPCM_IMA_WAV:
rate_min = 8000;
rate_max = 96000;
channels_max = 2;
caps = caps =
gst_caps_new_simple ("audio/x-adpcm", "layout", G_TYPE_STRING, "dvi", gst_caps_new_simple ("audio/x-adpcm", "layout", G_TYPE_STRING, "dvi",
NULL); NULL);
@ -1620,8 +1580,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
GstMapInfo info; GstMapInfo info;
gsize size; gsize size;
channels_max = 8;
/* should be at least 22 bytes */ /* should be at least 22 bytes */
size = gst_buffer_get_size (strf_data); size = gst_buffer_get_size (strf_data);
@ -1716,7 +1674,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
strf->blockalign = strf->av_bps * strf->channels; strf->blockalign = strf->av_bps * strf->channels;
} }
} }
rate_max = 48000;
caps = gst_caps_new_empty_simple ("audio/x-alaw"); caps = gst_caps_new_empty_simple ("audio/x-alaw");
if (codec_name) if (codec_name)
@ -1739,7 +1696,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
strf->blockalign = strf->av_bps * strf->channels; strf->blockalign = strf->av_bps * strf->channels;
} }
} }
rate_max = 48000;
caps = gst_caps_new_empty_simple ("audio/x-mulaw"); caps = gst_caps_new_empty_simple ("audio/x-mulaw");
if (codec_name) if (codec_name)
*codec_name = g_strdup ("Mu-law audio"); *codec_name = g_strdup ("Mu-law audio");
@ -1824,11 +1780,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
if (strf != NULL) { if (strf != NULL) {
if (rate_chan) { if (rate_chan) {
if (strf->channels > channels_max)
goto too_many_channels;
if (strf->rate < rate_min || strf->rate > rate_max)
goto invalid_rate;
gst_caps_set_simple (caps, gst_caps_set_simple (caps,
"rate", G_TYPE_INT, strf->rate, "rate", G_TYPE_INT, strf->rate,
"channels", G_TYPE_INT, strf->channels, NULL); "channels", G_TYPE_INT, strf->channels, NULL);
@ -1838,18 +1789,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
"block_align", G_TYPE_INT, strf->blockalign, NULL); "block_align", G_TYPE_INT, strf->blockalign, NULL);
} }
} else { } else {
if (rate_chan) {
if (rate_min == rate_max)
gst_caps_set_simple (caps, "rate", G_TYPE_INT, rate_min, NULL);
else
gst_caps_set_simple (caps,
"rate", GST_TYPE_INT_RANGE, rate_min, rate_max, NULL);
if (channels_max == 1)
gst_caps_set_simple (caps, "channels", G_TYPE_INT, 1, NULL);
else
gst_caps_set_simple (caps,
"channels", GST_TYPE_INT_RANGE, 1, channels_max, NULL);
}
if (block_align) { if (block_align) {
gst_caps_set_simple (caps, gst_caps_set_simple (caps,
"block_align", GST_TYPE_INT_RANGE, 1, G_MAXINT, NULL); "block_align", GST_TYPE_INT_RANGE, 1, G_MAXINT, NULL);
@ -1863,20 +1802,6 @@ gst_riff_create_audio_caps (guint16 codec_id,
} }
return caps; return caps;
/* ERROR */
too_many_channels:
GST_WARNING
("Stream claims to contain %u channels, but format only supports %d",
strf->channels, channels_max);
gst_caps_unref (caps);
return NULL;
invalid_rate:
GST_WARNING
("Stream with sample_rate %u, but format only supports %d .. %d",
strf->rate, rate_min, rate_max);
gst_caps_unref (caps);
return NULL;
} }
GstCaps * GstCaps *