From c8649d0e0bbc726313a5e483ecdaba34ed33e19b Mon Sep 17 00:00:00 2001 From: Jean-Marc Valin <jmvalin@jmvalin.ca> Date: Thu, 27 Oct 2011 22:25:33 -0400 Subject: [PATCH] Gives the Opus code direct access to (non-opaque) OpusRepacketizer This avoids potential alignment issues with allocating a char array on the stack. --- src/opus_encoder.c | 10 ++++------ src/opus_multistream.c | 11 ++++------- src/opus_private.h | 9 +++++++++ src/repacketizer.c | 9 --------- 4 files changed, 17 insertions(+), 22 deletions(-) diff --git a/src/opus_encoder.c b/src/opus_encoder.c index 83e673d88..494b6456c 100644 --- a/src/opus_encoder.c +++ b/src/opus_encoder.c @@ -724,10 +724,9 @@ int opus_encode_float(OpusEncoder *st, const opus_val16 *pcm, int frame_size, if (frame_size > st->Fs/50 && (st->mode == MODE_CELT_ONLY || st->bandwidth > OPUS_BANDWIDTH_WIDEBAND)) { VARDECL(unsigned char, tmp_data); - VARDECL(unsigned char, rp_); int nb_frames; int bak_mode, bak_bandwidth, bak_channels, bak_to_mono; - OpusRepacketizer *rp; + OpusRepacketizer rp; int bytes_per_frame; @@ -735,9 +734,8 @@ int opus_encode_float(OpusEncoder *st, const opus_val16 *pcm, int frame_size, bytes_per_frame = max_data_bytes/nb_frames-3; ALLOC(tmp_data, nb_frames*bytes_per_frame, unsigned char); - ALLOC(rp_, opus_repacketizer_get_size(), unsigned char); - rp = opus_repacketizer_init((OpusRepacketizer*)rp_); + opus_repacketizer_init(&rp); bak_mode = st->user_forced_mode; bak_bandwidth = st->user_bandwidth; @@ -762,11 +760,11 @@ int opus_encode_float(OpusEncoder *st, const opus_val16 *pcm, int frame_size, tmp_len = opus_encode_native(st, pcm+i*(st->channels*st->Fs/50), st->Fs/50, tmp_data+i*bytes_per_frame, bytes_per_frame); if (tmp_len<0) return OPUS_INTERNAL_ERROR; - ret = opus_repacketizer_cat(rp, tmp_data+i*bytes_per_frame, tmp_len); + ret = opus_repacketizer_cat(&rp, tmp_data+i*bytes_per_frame, tmp_len); if (ret<0) return OPUS_INTERNAL_ERROR; } - ret = opus_repacketizer_out(rp, data, max_data_bytes); + ret = opus_repacketizer_out(&rp, data, max_data_bytes); if (ret<0) return OPUS_INTERNAL_ERROR; diff --git a/src/opus_multistream.c b/src/opus_multistream.c index a44156809..e35da736a 100644 --- a/src/opus_multistream.c +++ b/src/opus_multistream.c @@ -237,13 +237,10 @@ int opus_multistream_encode_float( VARDECL(opus_val16, buf); /* Max size in case the encoder decides to return three frames */ unsigned char tmp_data[3*1275+7]; - VARDECL(unsigned char, rp_); - OpusRepacketizer *rp; + OpusRepacketizer rp; ALLOC_STACK; ALLOC(buf, 2*frame_size, opus_val16); - ALLOC(rp_, opus_repacketizer_get_size(), unsigned char); - rp = (OpusRepacketizer*)rp_; ptr = (char*)st + align(sizeof(OpusMSEncoder)); coupled_size = opus_encoder_get_size(2); mono_size = opus_encoder_get_size(1); @@ -261,7 +258,7 @@ int opus_multistream_encode_float( int len; int curr_max; - opus_repacketizer_init(rp); + opus_repacketizer_init(&rp); enc = (OpusEncoder*)ptr; if (s < st->layout.nb_coupled_streams) { @@ -293,8 +290,8 @@ int opus_multistream_encode_float( /* We need to use the repacketizer to add the self-delimiting lengths while taking into account the fact that the encoder can now return more than one frame at a time (e.g. 60 ms CELT-only) */ - opus_repacketizer_cat(rp, tmp_data, len); - len = opus_repacketizer_out_range_impl(rp, 0, opus_repacketizer_get_nb_frames(rp), data, max_data_bytes-tot_size, s != st->layout.nb_streams-1); + opus_repacketizer_cat(&rp, tmp_data, len); + len = opus_repacketizer_out_range_impl(&rp, 0, opus_repacketizer_get_nb_frames(&rp), data, max_data_bytes-tot_size, s != st->layout.nb_streams-1); data += len; tot_size += len; } diff --git a/src/opus_private.h b/src/opus_private.h index ea7acb74c..b35370525 100644 --- a/src/opus_private.h +++ b/src/opus_private.h @@ -32,6 +32,15 @@ #include "arch.h" #include "opus.h" +struct OpusRepacketizer { + unsigned char toc; + int nb_frames; + const unsigned char *frames[48]; + short len[48]; + int framesize; +}; + + #define MODE_SILK_ONLY 1000 #define MODE_HYBRID 1001 #define MODE_CELT_ONLY 1002 diff --git a/src/repacketizer.c b/src/repacketizer.c index 925770060..e947383a8 100644 --- a/src/repacketizer.c +++ b/src/repacketizer.c @@ -33,15 +33,6 @@ #include "opus_private.h" #include "os_support.h" -struct OpusRepacketizer { - unsigned char toc; - int nb_frames; - const unsigned char *frames[48]; - short len[48]; - int framesize; -}; - - int opus_repacketizer_get_size(void) { -- GitLab