Import THPAudio.c from MKDD
This commit is contained in:
parent
732e9ff777
commit
40b1a42e08
2 changed files with 118 additions and 102 deletions
|
|
@ -2,131 +2,147 @@
|
|||
|
||||
u32 THPAudioDecode(s16 *audioBuffer, u8 *audioFrame, s32 flag)
|
||||
{
|
||||
// THPAudioRecordHeader *header;
|
||||
// THPAudioDecodeInfo decInfo;
|
||||
// u8 *left, *right;
|
||||
// s16 *decLeftPtr, *decRightPtr;
|
||||
// s16 yn1, yn2;
|
||||
// s32 i;
|
||||
// s32 step;
|
||||
// s32 sample;
|
||||
// s64 yn;
|
||||
THPAudioRecordHeader *header;
|
||||
THPAudioDecodeInfo decInfo;
|
||||
u8 *left, *right;
|
||||
s16 *decLeftPtr, *decRightPtr;
|
||||
s16 yn1, yn2;
|
||||
s32 i;
|
||||
s32 step;
|
||||
s32 sample;
|
||||
s64 yn;
|
||||
|
||||
// if (audioBuffer == NULL || audioFrame == NULL) {
|
||||
// return 0;
|
||||
// }
|
||||
if (audioBuffer == NULL || audioFrame == NULL) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
// header = (THPAudioRecordHeader *)audioFrame;
|
||||
// left = audioFrame + sizeof(THPAudioRecordHeader);
|
||||
// right = left + header->offsetNextChannel;
|
||||
header = (THPAudioRecordHeader *)audioFrame;
|
||||
left = audioFrame + sizeof(THPAudioRecordHeader);
|
||||
right = left + header->offsetNextChannel;
|
||||
|
||||
// if (flag == 1) {
|
||||
// decRightPtr = audioBuffer;
|
||||
// decLeftPtr = audioBuffer + header->sampleSize;
|
||||
// step = 1;
|
||||
// }
|
||||
// else {
|
||||
// decRightPtr = audioBuffer;
|
||||
// decLeftPtr = audioBuffer + 1;
|
||||
// step = 2;
|
||||
// }
|
||||
if (flag == 1) {
|
||||
decRightPtr = audioBuffer;
|
||||
decLeftPtr = audioBuffer + header->sampleSize;
|
||||
step = 1;
|
||||
}
|
||||
else {
|
||||
decRightPtr = audioBuffer;
|
||||
decLeftPtr = audioBuffer + 1;
|
||||
step = 2;
|
||||
}
|
||||
|
||||
// if (header->offsetNextChannel == 0) {
|
||||
// __THPAudioInitialize(&decInfo, left);
|
||||
if (header->offsetNextChannel == 0) {
|
||||
__THPAudioInitialize(&decInfo, left);
|
||||
|
||||
// yn1 = header->lYn1;
|
||||
// yn2 = header->lYn2;
|
||||
yn1 = header->lYn1;
|
||||
yn2 = header->lYn2;
|
||||
|
||||
// for (i = 0; i < header->sampleSize; i++) {
|
||||
// sample = __THPAudioGetNewSample(&decInfo);
|
||||
// yn = header->lCoef[decInfo.predictor][1] * yn2;
|
||||
// yn += header->lCoef[decInfo.predictor][0] * yn1;
|
||||
// yn += (sample << decInfo.scale) << 11;
|
||||
// yn <<= 5;
|
||||
for (i = 0; i < header->sampleSize; i++) {
|
||||
sample = __THPAudioGetNewSample(&decInfo);
|
||||
yn = header->lCoef[decInfo.predictor][1] * yn2;
|
||||
yn += header->lCoef[decInfo.predictor][0] * yn1;
|
||||
yn += (sample << decInfo.scale) << 11;
|
||||
yn <<= 5;
|
||||
|
||||
// if (sample > 0x8000) {
|
||||
// yn += 0x10000;
|
||||
// }
|
||||
// else if ((sample == 0x8000) && ((yn & 0x10000) != 0)) {
|
||||
// yn += 0x10000;
|
||||
// }
|
||||
if ((u16)(yn & 0xffff) > 0x8000) {
|
||||
yn += 0x10000;
|
||||
}
|
||||
else if ((u16)(yn & 0xffff) == 0x8000) {
|
||||
if ((yn & 0x10000))
|
||||
yn += 0x10000;
|
||||
}
|
||||
|
||||
// yn += 0x8000;
|
||||
if (yn > 2147483647LL) {
|
||||
yn = 2147483647LL;
|
||||
}
|
||||
|
||||
// if (yn > 2147483647LL) {
|
||||
// yn = 2147483647LL;
|
||||
// }
|
||||
if (yn < -2147483648LL) {
|
||||
yn = -2147483648LL;
|
||||
}
|
||||
|
||||
// if (yn < -2147483648LL) {
|
||||
// yn = -2147483648LL;
|
||||
// }
|
||||
*decLeftPtr = (s16)(yn >> 16);
|
||||
decLeftPtr += step;
|
||||
*decRightPtr = (s16)(yn >> 16);
|
||||
decRightPtr += step;
|
||||
yn2 = yn1;
|
||||
yn1 = (s16)(yn >> 16);
|
||||
}
|
||||
}
|
||||
else {
|
||||
__THPAudioInitialize(&decInfo, left);
|
||||
|
||||
// *decLeftPtr = (s16)(yn >> 16);
|
||||
// decLeftPtr += step;
|
||||
// *decRightPtr = (s16)(yn >> 16);
|
||||
// decRightPtr += step;
|
||||
// yn2 = yn1;
|
||||
// yn1 = (s16)(yn >> 16);
|
||||
// }
|
||||
// }
|
||||
// else {
|
||||
// __THPAudioInitialize(&decInfo, left);
|
||||
yn1 = header->lYn1;
|
||||
yn2 = header->lYn2;
|
||||
|
||||
// yn1 = header->lYn1;
|
||||
// yn2 = header->lYn2;
|
||||
for (i = 0; i < header->sampleSize; i++) {
|
||||
sample = __THPAudioGetNewSample(&decInfo);
|
||||
yn = header->lCoef[decInfo.predictor][1] * yn2;
|
||||
yn += header->lCoef[decInfo.predictor][0] * yn1;
|
||||
yn += (sample << decInfo.scale) << 11;
|
||||
yn <<= 5;
|
||||
|
||||
// for (i = 0; i < header->sampleSize; i++) {
|
||||
// sample = __THPAudioGetNewSample(&decInfo);
|
||||
// yn = header->lCoef[decInfo.predictor][1] * yn2;
|
||||
// yn += header->lCoef[decInfo.predictor][0] * yn1;
|
||||
// yn += (sample << decInfo.scale) << 11;
|
||||
// yn <<= 5;
|
||||
// yn += 0x8000;
|
||||
if ((u16)(yn & 0xffff) > 0x8000) {
|
||||
yn += 0x10000;
|
||||
}
|
||||
else {
|
||||
if ((u16)(yn & 0xffff) == 0x8000) {
|
||||
if ((yn & 0x10000))
|
||||
yn += 0x10000;
|
||||
}
|
||||
}
|
||||
|
||||
// if (yn > 2147483647LL) {
|
||||
// yn = 2147483647LL;
|
||||
// }
|
||||
if (yn > 2147483647LL) {
|
||||
yn = 2147483647LL;
|
||||
}
|
||||
|
||||
// if (yn < -2147483648LL) {
|
||||
// yn = -2147483648LL;
|
||||
// }
|
||||
if (yn < -2147483648LL) {
|
||||
yn = -2147483648LL;
|
||||
}
|
||||
|
||||
// *decLeftPtr = (s16)(yn >> 16);
|
||||
// decLeftPtr += step;
|
||||
// yn2 = yn1;
|
||||
// yn1 = (s16)(yn >> 16);
|
||||
// }
|
||||
*decLeftPtr = (s16)(yn >> 16);
|
||||
decLeftPtr += step;
|
||||
yn2 = yn1;
|
||||
yn1 = (s16)(yn >> 16);
|
||||
}
|
||||
|
||||
// __THPAudioInitialize(&decInfo, right);
|
||||
__THPAudioInitialize(&decInfo, right);
|
||||
|
||||
// yn1 = header->rYn1;
|
||||
// yn2 = header->rYn2;
|
||||
yn1 = header->rYn1;
|
||||
yn2 = header->rYn2;
|
||||
|
||||
// for (i = 0; i < header->sampleSize; i++) {
|
||||
// sample = __THPAudioGetNewSample(&decInfo);
|
||||
// yn = header->rCoef[decInfo.predictor][1] * yn2;
|
||||
// yn += header->rCoef[decInfo.predictor][0] * yn1;
|
||||
// yn += (sample << decInfo.scale) << 11;
|
||||
// yn <<= 5;
|
||||
for (i = 0; i < header->sampleSize; i++) {
|
||||
sample = __THPAudioGetNewSample(&decInfo);
|
||||
yn = header->rCoef[decInfo.predictor][1] * yn2;
|
||||
yn += header->rCoef[decInfo.predictor][0] * yn1;
|
||||
yn += (sample << decInfo.scale) << 11;
|
||||
yn <<= 5;
|
||||
|
||||
// yn += 0x8000;
|
||||
if ((u16)(yn & 0xffff) > 0x8000) {
|
||||
yn += 0x10000;
|
||||
}
|
||||
else {
|
||||
if ((u16)(yn & 0xffff) == 0x8000) {
|
||||
if ((yn & 0x10000))
|
||||
yn += 0x10000;
|
||||
}
|
||||
}
|
||||
|
||||
// if (yn > 2147483647LL) {
|
||||
// yn = 2147483647LL;
|
||||
// }
|
||||
if (yn > 2147483647LL) {
|
||||
yn = 2147483647LL;
|
||||
}
|
||||
|
||||
// if (yn < -2147483648LL) {
|
||||
// yn = -2147483648LL;
|
||||
// }
|
||||
if (yn < -2147483648LL) {
|
||||
yn = -2147483648LL;
|
||||
}
|
||||
|
||||
// *decRightPtr = (s16)(yn >> 16);
|
||||
// decRightPtr += step;
|
||||
// yn2 = yn1;
|
||||
// yn1 = (s16)(yn >> 16);
|
||||
// }
|
||||
// }
|
||||
*decRightPtr = (s16)(yn >> 16);
|
||||
decRightPtr += step;
|
||||
yn2 = yn1;
|
||||
yn1 = (s16)(yn >> 16);
|
||||
}
|
||||
}
|
||||
|
||||
// return header->sampleSize;
|
||||
return header->sampleSize;
|
||||
}
|
||||
|
||||
static s32 __THPAudioGetNewSample(THPAudioDecodeInfo *info)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue