/*
|
* Copyright (C) 2003 - 2016 Sony Corporation
|
*
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
* you may not use this file except in compliance with the License.
|
* You may obtain a copy of the License at
|
*
|
* http://www.apache.org/licenses/LICENSE-2.0
|
*
|
* Unless required by applicable law or agreed to in writing, software
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
* See the License for the specific language governing permissions and
|
* limitations under the License.
|
*/
|
|
#include "ldac.h"
|
|
/***************************************************************************************************
|
Subfunction: Convert from 16bit Signed Integer PCM
|
***************************************************************************************************/
|
__inline static void byte_data_to_scalar_s16_ldac(
|
char *p_in,
|
SCALAR *p_out,
|
int nsmpl)
|
{
|
int i;
|
short *p_s;
|
|
p_s = (short *)p_in;
|
for (i = 0; i < nsmpl; i++) {
|
*p_out++ = (SCALAR)*p_s++;
|
}
|
|
return;
|
}
|
|
/***************************************************************************************************
|
Subfunction: Convert from 24bit Signed Integer PCM
|
***************************************************************************************************/
|
__inline static void byte_data_to_scalar_s24_ldac(
|
char *p_in,
|
SCALAR *p_out,
|
int nsmpl)
|
{
|
int i, val;
|
char *p_c;
|
SCALAR scale = _scalar(1.0) / _scalar(65536.0);
|
|
p_c = (char *)p_in;
|
for (i = 0; i < nsmpl; i++) {
|
#ifdef LDAC_HOST_ENDIAN_LITTLE
|
val = 0x000000ff & (*p_c++);
|
val |= 0x0000ff00 & (*p_c++ << 8);
|
val |= 0xffff0000 & (*p_c++ << 16);
|
#else /* LDAC_HOST_ENDIAN_LITTLE */
|
val = 0xffff0000 & (*p_c++ << 16);
|
val |= 0x0000ff00 & (*p_c++ << 8);
|
val |= 0x000000ff & (*p_c++);
|
#endif /* LDAC_HOST_ENDIAN_LITTLE */
|
*p_out++ = scale * (SCALAR)(val << 8); /* Sign Extension */
|
}
|
|
return;
|
}
|
|
/***************************************************************************************************
|
Subfunction: Convert from 32bit Signed Integer PCM
|
***************************************************************************************************/
|
__inline static void byte_data_to_scalar_s32_ldac(
|
char *p_in,
|
SCALAR *p_out,
|
int nsmpl)
|
{
|
int i;
|
int *p_l;
|
SCALAR scale = _scalar(1.0) / _scalar(65536.0);
|
|
p_l = (int *)p_in;
|
for (i = 0; i < nsmpl; i++) {
|
*p_out++ = scale * (SCALAR)*p_l++;
|
}
|
|
return;
|
}
|
|
/***************************************************************************************************
|
Subfunction: Convert from 32bit Float PCM
|
***************************************************************************************************/
|
__inline static void byte_data_to_scalar_f32_ldac(
|
char *p_in,
|
SCALAR *p_out,
|
int nsmpl)
|
{
|
int i;
|
float *p_f;
|
SCALAR scale = _scalar(32768.0);
|
|
p_f = (float *)p_in;
|
for (i = 0; i < nsmpl; i++) {
|
*p_out++ = scale * (SCALAR)*p_f++;
|
}
|
|
return;
|
}
|
|
/***************************************************************************************************
|
Set Input PCM
|
***************************************************************************************************/
|
DECLFUNC void set_input_pcm_ldac(
|
SFINFO *p_sfinfo,
|
char *pp_pcm[],
|
LDAC_SMPL_FMT_T format,
|
int nlnn)
|
{
|
int ich, isp;
|
int nchs = p_sfinfo->cfg.ch;
|
int nsmpl = npow2_ldac(nlnn);
|
SCALAR *p_time;
|
|
if (format == LDAC_SMPL_FMT_S16) {
|
for (ich = 0; ich < nchs; ich++) {
|
p_time = p_sfinfo->ap_ac[ich]->p_acsub->a_time;
|
for (isp = 0; isp < nsmpl; isp++) {
|
p_time[isp] = p_time[nsmpl+isp];
|
}
|
byte_data_to_scalar_s16_ldac(pp_pcm[ich], p_time+nsmpl, nsmpl);
|
}
|
}
|
else if (format == LDAC_SMPL_FMT_S24) {
|
for (ich = 0; ich < nchs; ich++) {
|
p_time = p_sfinfo->ap_ac[ich]->p_acsub->a_time;
|
for (isp = 0; isp < nsmpl; isp++) {
|
p_time[isp] = p_time[nsmpl+isp];
|
}
|
byte_data_to_scalar_s24_ldac(pp_pcm[ich], p_time+nsmpl, nsmpl);
|
}
|
}
|
else if (format == LDAC_SMPL_FMT_S32) {
|
for (ich = 0; ich < nchs; ich++) {
|
p_time = p_sfinfo->ap_ac[ich]->p_acsub->a_time;
|
for (isp = 0; isp < nsmpl; isp++) {
|
p_time[isp] = p_time[nsmpl+isp];
|
}
|
byte_data_to_scalar_s32_ldac(pp_pcm[ich], p_time+nsmpl, nsmpl);
|
}
|
}
|
else if (format == LDAC_SMPL_FMT_F32) {
|
for (ich = 0; ich < nchs; ich++) {
|
p_time = p_sfinfo->ap_ac[ich]->p_acsub->a_time;
|
for (isp = 0; isp < nsmpl; isp++) {
|
p_time[isp] = p_time[nsmpl+isp];
|
}
|
byte_data_to_scalar_f32_ldac(pp_pcm[ich], p_time+nsmpl, nsmpl);
|
}
|
}
|
|
return;
|
}
|