summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian@centricular.com>2015-11-02 16:52:28 +0200
committerSebastian Dröge <sebastian@centricular.com>2015-11-03 20:35:41 +0200
commit328f9088f340cb4fc84d79698e7f6220f5bb4db2 (patch)
treec00cb097f153b32a0e4a9837c7b44d6c1a214808
parent6b751360ae56583197ac678f05aadbc8b7aa46ec (diff)
downloadgstreamer-plugins-base-328f9088f340cb4fc84d79698e7f6220f5bb4db2.tar.gz
opusenc: Add GstAudioClippingMeta to buffers that need to be clipped
https://bugzilla.gnome.org/show_bug.cgi?id=757153
-rw-r--r--ext/opus/gstopusenc.c24
1 files changed, 20 insertions, 4 deletions
diff --git a/ext/opus/gstopusenc.c b/ext/opus/gstopusenc.c
index 24bdeafc4..17004ce1b 100644
--- a/ext/opus/gstopusenc.c
+++ b/ext/opus/gstopusenc.c
@@ -761,8 +761,8 @@ gst_opus_enc_setup (GstOpusEnc * enc)
lookahead);
/* lookahead is samples, the Opus header wants it in 48kHz samples */
- enc->lookahead = enc->pending_lookahead = lookahead;
lookahead = lookahead * 48000 / enc->sample_rate;
+ enc->lookahead = enc->pending_lookahead = lookahead;
gst_opus_header_create_caps (&caps, NULL, lookahead, enc->sample_rate,
enc->n_channels, enc->n_stereo_streams, enc->channel_mapping_family,
@@ -894,6 +894,7 @@ gst_opus_enc_encode (GstOpusEnc * enc, GstBuffer * buf)
GstBuffer *outbuf;
GstSegment *segment;
GstClockTime duration;
+ guint64 trim_start = 0, trim_end = 0;
guint max_payload_size;
gint frame_samples, input_samples, output_samples;
@@ -945,6 +946,7 @@ gst_opus_enc_encode (GstOpusEnc * enc, GstBuffer * buf)
"%" G_GINT64_FORMAT " extra samples of padding in this frame",
diff);
output_samples = frame_samples - diff;
+ trim_end = diff * 48000 / enc->sample_rate;
} else {
GST_DEBUG_OBJECT (enc,
"Need to add %" G_GINT64_FORMAT " extra samples in the next frame",
@@ -966,11 +968,16 @@ gst_opus_enc_encode (GstOpusEnc * enc, GstBuffer * buf)
/* Adjust for lookahead here */
if (enc->pending_lookahead) {
- if (input_samples > enc->pending_lookahead) {
- output_samples = input_samples - enc->pending_lookahead;
+ guint scaled_lookahead =
+ enc->pending_lookahead * enc->sample_rate / 48000;
+
+ if (input_samples > scaled_lookahead) {
+ output_samples = input_samples - scaled_lookahead;
+ trim_start = enc->pending_lookahead;
enc->pending_lookahead = 0;
} else {
- enc->pending_lookahead -= input_samples;
+ trim_start = input_samples * 48000 / enc->sample_rate;
+ enc->pending_lookahead -= trim_start;
output_samples = 0;
}
} else {
@@ -988,6 +995,7 @@ gst_opus_enc_encode (GstOpusEnc * enc, GstBuffer * buf)
output_samples = enc->consumed_samples - enc->encoded_samples;
input_samples = 0;
GST_DEBUG_OBJECT (enc, "draining %d samples", output_samples);
+ trim_end = (frame_samples - output_samples) * 48000 / enc->sample_rate;
} else if (enc->encoded_samples == enc->consumed_samples) {
GST_DEBUG_OBJECT (enc, "nothing to drain");
goto done;
@@ -1008,6 +1016,14 @@ gst_opus_enc_encode (GstOpusEnc * enc, GstBuffer * buf)
GST_DEBUG_OBJECT (enc, "encoding %d samples (%d bytes)",
frame_samples, (int) bytes);
+ if (trim_start || trim_end) {
+ GST_DEBUG_OBJECT (enc,
+ "Adding trim-start %" G_GUINT64_FORMAT " trim-end %" G_GUINT64_FORMAT,
+ trim_start, trim_end);
+ gst_buffer_add_audio_clipping_meta (outbuf, GST_FORMAT_DEFAULT, trim_start,
+ trim_end);
+ }
+
gst_buffer_map (outbuf, &omap, GST_MAP_WRITE);
outsize =