Commit 899895ef authored by Laurent Aimar's avatar Laurent Aimar

Factorized 8->16 bits audio conversions.

parent f3a2e18c
...@@ -596,56 +596,42 @@ static block_t *U8toS8( filter_t *p_filter, block_t *p_block ) ...@@ -596,56 +596,42 @@ static block_t *U8toS8( filter_t *p_filter, block_t *p_block )
} }
/* */ /* */
static block_t *S8toU16( filter_t *p_filter, block_t *p_block ) static inline block_t *X8toX16( filter_t *p_filter, block_t *p_block,
bool b_signed_src, bool b_signed_dst )
{ {
block_t *p_block_out; block_t *p_block_out;
int8_t *p_in;
uint16_t *p_out;
int i;
p_block_out = p_block_out = filter_NewAudioBuffer( p_filter, p_block->i_buffer*2 );
filter_NewAudioBuffer( p_filter, p_block->i_buffer*2 );
if( !p_block_out ) if( !p_block_out )
{ {
msg_Warn( p_filter, "can't get output buffer" ); msg_Warn( p_filter, "can't get output buffer" );
return NULL; return NULL;
} }
p_in = (int8_t *)p_block->p_buffer; if( b_signed_src == b_signed_dst )
p_out = (uint16_t *)p_block_out->p_buffer;
for( i = p_block->i_buffer; i--; )
*p_out++ = ((*p_in++) + 128) << 8;
p_block_out->i_nb_samples = p_block->i_nb_samples;
p_block_out->i_dts = p_block->i_dts;
p_block_out->i_pts = p_block->i_pts;
p_block_out->i_length = p_block->i_length;
p_block_out->i_rate = p_block->i_rate;
block_Release( p_block );
return p_block_out;
}
static block_t *U8toS16( filter_t *p_filter, block_t *p_block )
{
block_t *p_block_out;
uint8_t *p_in;
int16_t *p_out;
int i;
p_block_out = filter_NewAudioBuffer( p_filter, p_block->i_buffer*2 );
if( !p_block_out )
{ {
msg_Warn( p_filter, "can't get output buffer" ); /* U8->U16 or S8->S16 */
return NULL; uint8_t *p_in = (uint8_t *)p_block->p_buffer;
uint16_t *p_out = (uint16_t *)p_block_out->p_buffer;
for( int i = p_block->i_buffer; i--; )
*p_out++ = (*p_in++) << 8;
} }
else if( b_signed_src )
p_in = (uint8_t *)p_block->p_buffer; {
p_out = (int16_t *)p_block_out->p_buffer; /* S8->U16 */
int8_t *p_in = (int8_t *)p_block->p_buffer;
for( i = p_block->i_buffer; i--; ) uint16_t *p_out = (uint16_t *)p_block_out->p_buffer;
for( int i = p_block->i_buffer; i--; )
*p_out++ = ((*p_in++) + 128) << 8;
}
else
{
/* U8->S16 */
uint8_t *p_in = (uint8_t *)p_block->p_buffer;
int16_t *p_out = (int16_t *)p_block_out->p_buffer;
for( int i = p_block->i_buffer; i--; )
*p_out++ = ((*p_in++) - 128) << 8; *p_out++ = ((*p_in++) - 128) << 8;
}
p_block_out->i_nb_samples = p_block->i_nb_samples; p_block_out->i_nb_samples = p_block->i_nb_samples;
p_block_out->i_dts = p_block->i_dts; p_block_out->i_dts = p_block->i_dts;
...@@ -656,67 +642,24 @@ static block_t *U8toS16( filter_t *p_filter, block_t *p_block ) ...@@ -656,67 +642,24 @@ static block_t *U8toS16( filter_t *p_filter, block_t *p_block )
block_Release( p_block ); block_Release( p_block );
return p_block_out; return p_block_out;
} }
static block_t *S8toS16( filter_t *p_filter, block_t *p_block ) static block_t *S8toS16( filter_t *p_filter, block_t *p_block )
{ {
block_t *p_block_out; return X8toX16( p_filter, p_block, true, true );
int8_t *p_in;
int16_t *p_out;
int i;
p_block_out = filter_NewAudioBuffer( p_filter, p_block->i_buffer*2 );
if( !p_block_out )
{
msg_Warn( p_filter, "can't get output buffer" );
return NULL;
}
p_in = (int8_t *)p_block->p_buffer;
p_out = (int16_t *)p_block_out->p_buffer;
for( i = p_block->i_buffer; i--; )
*p_out++ = (*p_in++) << 8;
p_block_out->i_nb_samples = p_block->i_nb_samples;
p_block_out->i_dts = p_block->i_dts;
p_block_out->i_pts = p_block->i_pts;
p_block_out->i_length = p_block->i_length;
p_block_out->i_rate = p_block->i_rate;
block_Release( p_block );
return p_block_out;
} }
static block_t *U8toU16( filter_t *p_filter, block_t *p_block ) static block_t *U8toU16( filter_t *p_filter, block_t *p_block )
{ {
block_t *p_block_out; return X8toX16( p_filter, p_block, true, true );
uint8_t *p_in; }
uint16_t *p_out; static block_t *S8toU16( filter_t *p_filter, block_t *p_block )
int i; {
return X8toX16( p_filter, p_block, true, false );
p_block_out = filter_NewAudioBuffer( p_filter, p_block->i_buffer*2 ); }
if( !p_block_out ) static block_t *U8toS16( filter_t *p_filter, block_t *p_block )
{ {
msg_Warn( p_filter, "can't get output buffer" ); return X8toX16( p_filter, p_block, false, true );
return NULL; }
}
p_in = (uint8_t *)p_block->p_buffer;
p_out = (uint16_t *)p_block_out->p_buffer;
for( i = p_block->i_buffer; i--; )
*p_out++ = (*p_in++) << 8;
p_block_out->i_nb_samples = p_block->i_nb_samples;
p_block_out->i_dts = p_block->i_dts;
p_block_out->i_pts = p_block->i_pts;
p_block_out->i_length = p_block->i_length;
p_block_out->i_rate = p_block->i_rate;
block_Release( p_block );
return p_block_out;
}
/***************************************************************************** /*****************************************************************************
* Swap a buffer of words * Swap a buffer of words
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment