opus: Fix crash when getting unexpected channel position

gst_opus_channel_names is a static array with only 13 items.
GstAudioChannelPosition have bigger values than that.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4798>
This commit is contained in:
Xavier Claessens 2023-06-07 14:24:46 -04:00 committed by GStreamer Marge Bot
parent 2769986ca9
commit b687e19e10

View file

@ -508,8 +508,7 @@ gst_opus_enc_find_channel_position_in_vorbis_order (GstOpusEnc * enc,
}
}
GST_WARNING_OBJECT (enc,
"Channel position %s is not representable in Vorbis order",
gst_opus_channel_names[position]);
"Channel position %d is not representable in Vorbis order", position);
return -1;
}
@ -615,8 +614,8 @@ gst_opus_enc_setup_channel_mappings (GstOpusEnc * enc,
needs to be done */
if (!positions_done[position]) {
int cv;
GST_DEBUG_OBJECT (enc, "Channel position %s is not mapped yet, adding",
gst_opus_channel_names[position]);
GST_DEBUG_OBJECT (enc, "Channel position %d is not mapped yet, adding",
position);
cv = gst_opus_enc_find_channel_position_in_vorbis_order (enc, position);
if (cv < 0)
goto unpositioned;