Skip to content
Snippets Groups Projects
Commit 370286cd authored by Jean-Marc Valin's avatar Jean-Marc Valin
Browse files

updating the update draft

parent 741ced30
No related branches found
No related tags found
No related merge requests found
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
<?rfc inline="yes"?> <?rfc inline="yes"?>
<?rfc compact="yes"?> <?rfc compact="yes"?>
<?rfc subcompact="no"?> <?rfc subcompact="no"?>
<rfc category="std" docName="draft-ietf-codec-opus-update-00" <rfc category="std" docName="draft-ietf-codec-opus-update-01"
ipr="trust200902"> ipr="trust200902">
<front> <front>
<title abbrev="Opus Update">Updates to the Opus Audio Codec</title> <title abbrev="Opus Update">Updates to the Opus Audio Codec</title>
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
<organization>Mozilla Corporation</organization> <organization>Mozilla Corporation</organization>
<address> <address>
<postal> <postal>
<street>650 Castro Street</street> <street>331 E. Evelyn Avenue</street>
<city>Mountain View</city> <city>Mountain View</city>
<region>CA</region> <region>CA</region>
<code>94041</code> <code>94041</code>
...@@ -47,7 +47,7 @@ ...@@ -47,7 +47,7 @@
<date day="13" month="January" year="2014" /> <date day="4" month="September" year="2014" />
<abstract> <abstract>
<t>This document addresses minor issues that were found in the specification <t>This document addresses minor issues that were found in the specification
...@@ -132,8 +132,8 @@ ...@@ -132,8 +132,8 @@
by a compressed packet more than about 16 MB long, so it's not a problem by a compressed packet more than about 16 MB long, so it's not a problem
for RTP. In theory, it <spanx style="emph">could</spanx> crash a file for RTP. In theory, it <spanx style="emph">could</spanx> crash a file
decoder (e.g. Opus in Ogg) if the memory just after the incoming packet decoder (e.g. Opus in Ogg) if the memory just after the incoming packet
is out-of-range, but that could not be achieved when attempted in a production is out-of-range, but our attempts to trigger such a crash in a production
application built using an affected version of the Opus decoder.</t> application built using an affected version of the Opus decoder failed.</t>
</section> </section>
<section anchor="resampler" title="Resampler buffer"> <section anchor="resampler" title="Resampler buffer">
...@@ -160,20 +160,22 @@ ...@@ -160,20 +160,22 @@
<t>The code can be fixed by applying the following changes to line 70 of silk/resampler_private_IIR_FIR.c: <t>The code can be fixed by applying the following changes to line 70 of silk/resampler_private_IIR_FIR.c:
<figure> <figure>
<artwork><![CDATA[ <artwork><![CDATA[
opus_int16 out[], /* O Output signal */
const opus_int16 in[], /* I Input signal */
opus_int32 inLen /* I Number of input samples */
) )
{ {
silk_resampler_state_struct *S = (silk_resampler_state_struct *)SS; silk_resampler_state_struct *S = \
(silk_resampler_state_struct *)SS;
opus_int32 nSamplesIn; opus_int32 nSamplesIn;
opus_int32 max_index_Q16, index_increment_Q16; opus_int32 max_index_Q16, index_increment_Q16;
- opus_int16 buf[ RESAMPLER_MAX_BATCH_SIZE_IN + RESAMPLER_ORDER_FIR_12 ]; - opus_int16 buf[ RESAMPLER_MAX_BATCH_SIZE_IN + \
+ opus_int16 buf[ 2*RESAMPLER_MAX_BATCH_SIZE_IN + RESAMPLER_ORDER_FIR_12 ]; RESAMPLER_ORDER_FIR_12 ];
+ opus_int16 buf[ 2*RESAMPLER_MAX_BATCH_SIZE_IN + \
RESAMPLER_ORDER_FIR_12 ];
/* Copy buffered samples to start of buffer */ /* Copy buffered samples to start of buffer */
- silk_memcpy( buf, S->sFIR, RESAMPLER_ORDER_FIR_12 * sizeof( opus_int32 ) ); - silk_memcpy( buf, S->sFIR, RESAMPLER_ORDER_FIR_12 \
+ silk_memcpy( buf, S->sFIR, RESAMPLER_ORDER_FIR_12 * sizeof( opus_int16 ) ); * sizeof( opus_int32 ) );
+ silk_memcpy( buf, S->sFIR, RESAMPLER_ORDER_FIR_12 \
* sizeof( opus_int16 ) );
/* Iterate over blocks of frameSizeIn input samples */ /* Iterate over blocks of frameSizeIn input samples */
index_increment_Q16 = S->invRatio_Q16; index_increment_Q16 = S->invRatio_Q16;
...@@ -181,28 +183,43 @@ ...@@ -181,28 +183,43 @@
nSamplesIn = silk_min( inLen, S->batchSize ); nSamplesIn = silk_min( inLen, S->batchSize );
/* Upsample 2x */ /* Upsample 2x */
silk_resampler_private_up2_HQ( S->sIIR, &buf[ RESAMPLER_ORDER_FIR_12 ], in, nSamplesIn ); silk_resampler_private_up2_HQ( S->sIIR, &buf[ \
RESAMPLER_ORDER_FIR_12 ], in, nSamplesIn );
max_index_Q16 = silk_LSHIFT32( nSamplesIn, 16 + 1 ); /* + 1 because 2x upsampling */ max_index_Q16 = silk_LSHIFT32( nSamplesIn, 16 + 1 \
out = silk_resampler_private_IIR_FIR_INTERPOL( out, buf, max_index_Q16, index_increment_Q16 ); ); /* + 1 because 2x upsampling */
out = silk_resampler_private_IIR_FIR_INTERPOL( out, \
buf, max_index_Q16, index_increment_Q16 );
in += nSamplesIn; in += nSamplesIn;
inLen -= nSamplesIn; inLen -= nSamplesIn;
if( inLen > 0 ) { if( inLen > 0 ) {
/* More iterations to do; copy last part of filtered signal to beginning of buffer */ /* More iterations to do; copy last part of \
- silk_memcpy( buf, &buf[ nSamplesIn << 1 ], RESAMPLER_ORDER_FIR_12 * sizeof( opus_int32 ) ); filtered signal to beginning of buffer */
+ silk_memmove( buf, &buf[ nSamplesIn << 1 ], RESAMPLER_ORDER_FIR_12 * sizeof( opus_int16 ) ); - silk_memcpy( buf, &buf[ nSamplesIn << 1 ], \
RESAMPLER_ORDER_FIR_12 * sizeof( opus_int32 ) );
+ silk_memmove( buf, &buf[ nSamplesIn << 1 ], \
RESAMPLER_ORDER_FIR_12 * sizeof( opus_int16 ) );
} else { } else {
break; break;
} }
} }
/* Copy last part of filtered signal to the state for the next call */ /* Copy last part of filtered signal to the state for \
- silk_memcpy( S->sFIR, &buf[ nSamplesIn << 1 ], RESAMPLER_ORDER_FIR_12 * sizeof( opus_int32 ) ); the next call */
+ silk_memcpy( S->sFIR, &buf[ nSamplesIn << 1 ], RESAMPLER_ORDER_FIR_12 * sizeof( opus_int16 ) ); - silk_memcpy( S->sFIR, &buf[ nSamplesIn << 1 ], \
RESAMPLER_ORDER_FIR_12 * sizeof( opus_int32 ) );
+ silk_memcpy( S->sFIR, &buf[ nSamplesIn << 1 ], \
RESAMPLER_ORDER_FIR_12 * sizeof( opus_int16 ) );
} }
]]></artwork> ]]></artwork>
</figure> </figure>
Note: due to RFC formatting conventions, lines exceeding the column width
in the patch above are split using a backslash character. The backslashes
at the end of a line and the white space at the beginning
of the following line are not part of the patch. A properly formatted patch
including the three changes above is available at
<eref target="http://jmvalin.ca/misc_stuff/opus_update.patch"/>.
</t> </t>
</section> </section>
...@@ -215,8 +232,8 @@ ...@@ -215,8 +232,8 @@
but when the output is downmixed to mono, the energy in the affected bands is cancelled but when the output is downmixed to mono, the energy in the affected bands is cancelled
sometimes resulting in audible artefacts. sometimes resulting in audible artefacts.
</t> </t>
<t>A possible work-around for this issue would be to optionally allow the decoder to <t>As a work-around for this issue, the decoder MAY choose not to apply the 180-degree
not apply the 180-degree phase shift when the output is meant to be downmixed (inside or phase shift when the output is meant to be downmixed (inside or
outside of the decoder). outside of the decoder).
</t> </t>
</section> </section>
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment