mirror of https://github.com/mstorsjo/fdk-aac.git
Merge "Remove obsolete uni drc precedence handling" am: 7f83eb07af
Original change: https://android-review.googlesource.com/c/platform/external/aac/+/2562610 Change-Id: I8d29d1b5b13251bd3f375da79156dfeead7104d8 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
commit
dc087c5c90
|
@ -1,7 +1,7 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
Software License for The Fraunhofer FDK AAC Codec Library for Android
|
||||
|
||||
© Copyright 1995 - 2020 Fraunhofer-Gesellschaft zur Förderung der angewandten
|
||||
© Copyright 1995 - 2023 Fraunhofer-Gesellschaft zur Förderung der angewandten
|
||||
Forschung e.V. All rights reserved.
|
||||
|
||||
1. INTRODUCTION
|
||||
|
@ -217,7 +217,6 @@ void aacDecoder_drcInit(HANDLE_AAC_DRC self) {
|
|||
self->progRefLevel = pParams->targetRefLevel;
|
||||
self->progRefLevelPresent = 0;
|
||||
self->presMode = -1;
|
||||
self->uniDrcPrecedence = 0;
|
||||
|
||||
aacDecoder_drcReset(self);
|
||||
}
|
||||
|
@ -353,12 +352,6 @@ AAC_DECODER_ERROR aacDecoder_drcSetParam(HANDLE_AAC_DRC self,
|
|||
self->numOutChannels = (INT)value;
|
||||
self->update = 1;
|
||||
break;
|
||||
case UNIDRC_PRECEDENCE:
|
||||
if (self == NULL) {
|
||||
return AAC_DEC_INVALID_HANDLE;
|
||||
}
|
||||
self->uniDrcPrecedence = (UCHAR)value;
|
||||
break;
|
||||
default:
|
||||
return AAC_DEC_SET_PARAM_FAIL;
|
||||
} /* switch(param) */
|
||||
|
@ -1258,7 +1251,6 @@ static void aacDecoder_drcParameterHandling(HANDLE_AAC_DRC self,
|
|||
/* switch on/off processing */
|
||||
self->enable = ((p->boost > (FIXP_DBL)0) || (p->cut > (FIXP_DBL)0) ||
|
||||
(p->applyHeavyCompression == ON) || (p->targetRefLevel >= 0));
|
||||
self->enable = (self->enable && !self->uniDrcPrecedence);
|
||||
|
||||
self->prevAacNumChannels = aacNumChannels;
|
||||
self->update = 0;
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
Software License for The Fraunhofer FDK AAC Codec Library for Android
|
||||
|
||||
© Copyright 1995 - 2020 Fraunhofer-Gesellschaft zur Förderung der angewandten
|
||||
© Copyright 1995 - 2023 Fraunhofer-Gesellschaft zur Förderung der angewandten
|
||||
Forschung e.V. All rights reserved.
|
||||
|
||||
1. INTRODUCTION
|
||||
|
@ -133,8 +133,7 @@ typedef enum {
|
|||
APPLY_HEAVY_COMPRESSION,
|
||||
DEFAULT_PRESENTATION_MODE,
|
||||
ENCODER_TARGET_LEVEL,
|
||||
MAX_OUTPUT_CHANNELS,
|
||||
UNIDRC_PRECEDENCE
|
||||
MAX_OUTPUT_CHANNELS
|
||||
} AACDEC_DRC_PARAM;
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
Software License for The Fraunhofer FDK AAC Codec Library for Android
|
||||
|
||||
© Copyright 1995 - 2019 Fraunhofer-Gesellschaft zur Förderung der angewandten
|
||||
© Copyright 1995 - 2023 Fraunhofer-Gesellschaft zur Förderung der angewandten
|
||||
Forschung e.V. All rights reserved.
|
||||
|
||||
1. INTRODUCTION
|
||||
|
@ -207,11 +207,6 @@ typedef struct {
|
|||
position in the bitstream (only one per frame) */
|
||||
UINT drcPayloadPosition[MAX_DRC_THREADS]; /* Used to store the DRC payload
|
||||
positions in the bitstream */
|
||||
|
||||
UCHAR
|
||||
uniDrcPrecedence; /* Flag for signalling that uniDrc is active and takes
|
||||
precedence over legacy DRC */
|
||||
|
||||
UCHAR applyExtGain; /* Flag is 1 if extGain has to be applied, otherwise 0. */
|
||||
|
||||
FIXP_DBL additionalGainPrev; /* Gain of previous frame to be applied to the
|
||||
|
|
|
@ -3310,12 +3310,6 @@ LINKSPEC_CPP AAC_DECODER_ERROR CAacDecoder_DecodeFrame(
|
|||
FDKmemcpy(drcChMap, self->chMapping, (8) * sizeof(UCHAR));
|
||||
}
|
||||
|
||||
/* deactivate legacy DRC in case uniDrc is active, i.e. uniDrc payload is
|
||||
* present and one of DRC or Loudness Normalization is switched on */
|
||||
aacDecoder_drcSetParam(
|
||||
self->hDrcInfo, UNIDRC_PRECEDENCE,
|
||||
FDK_drcDec_GetParam(self->hUniDrcDecoder, DRC_DEC_IS_ACTIVE));
|
||||
|
||||
/* Extract DRC control data and map it to channels (without bitstream delay)
|
||||
*/
|
||||
mapped = aacDecoder_drcProlog(
|
||||
|
|
|
@ -1689,8 +1689,6 @@ LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_DecodeFrame(HANDLE_AACDECODER self,
|
|||
FIXP_DBL channelGain[(8)];
|
||||
int reverseInChannelMap[(8)];
|
||||
int reverseOutChannelMap[(8)];
|
||||
int numDrcOutChannels = FDK_drcDec_GetParam(
|
||||
self->hUniDrcDecoder, DRC_DEC_TARGET_CHANNEL_COUNT_SELECTED);
|
||||
FDKmemclear(channelGain, sizeof(channelGain));
|
||||
for (ch = 0; ch < (8); ch++) {
|
||||
reverseInChannelMap[ch] = ch;
|
||||
|
@ -1713,17 +1711,6 @@ LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_DecodeFrame(HANDLE_AACDECODER self,
|
|||
drcDelay += CConcealment_GetDelay(&self->concealCommonData) *
|
||||
self->streamInfo.frameSize;
|
||||
|
||||
for (ch = 0; ch < self->streamInfo.numChannels; ch++) {
|
||||
UCHAR mapValue = FDK_chMapDescr_getMapValue(
|
||||
&self->mapDescr, (UCHAR)ch, self->chMapIndex);
|
||||
if (mapValue < (8)) reverseInChannelMap[mapValue] = ch;
|
||||
}
|
||||
for (ch = 0; ch < (int)numDrcOutChannels; ch++) {
|
||||
UCHAR mapValue = FDK_chMapDescr_getMapValue(
|
||||
&self->mapDescr, (UCHAR)ch, numDrcOutChannels);
|
||||
if (mapValue < (8)) reverseOutChannelMap[mapValue] = ch;
|
||||
}
|
||||
|
||||
/* The output of SBR and MPS is interleaved. Deinterleaving may be
|
||||
* necessary for FDK_drcDec_ProcessTime, which accepts deinterleaved
|
||||
* audio only. */
|
||||
|
@ -1758,11 +1745,9 @@ LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_DecodeFrame(HANDLE_AACDECODER self,
|
|||
FDK_drcDec_Preprocess(self->hUniDrcDecoder);
|
||||
|
||||
/* apply DRC1 gain sequence */
|
||||
for (ch = 0; ch < self->streamInfo.numChannels; ch++) {
|
||||
FDK_drcDec_ProcessTime(self->hUniDrcDecoder, drcDelay, DRC_DEC_DRC1,
|
||||
ch, reverseInChannelMap[ch] - ch, 1,
|
||||
drcWorkBuffer, self->streamInfo.frameSize);
|
||||
}
|
||||
FDK_drcDec_ProcessTime(self->hUniDrcDecoder, drcDelay, DRC_DEC_DRC1,
|
||||
0, 0, self->streamInfo.numChannels,
|
||||
drcWorkBuffer, self->streamInfo.frameSize);
|
||||
/* apply downmix */
|
||||
FDK_drcDec_ApplyDownmix(
|
||||
self->hUniDrcDecoder, reverseInChannelMap, reverseOutChannelMap,
|
||||
|
@ -1770,12 +1755,10 @@ LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_DecodeFrame(HANDLE_AACDECODER self,
|
|||
&self->streamInfo.numChannels); /* self->streamInfo.numChannels
|
||||
may change here */
|
||||
/* apply DRC2/3 gain sequence */
|
||||
for (ch = 0; ch < self->streamInfo.numChannels; ch++) {
|
||||
FDK_drcDec_ProcessTime(self->hUniDrcDecoder, drcDelay,
|
||||
DRC_DEC_DRC2_DRC3, ch,
|
||||
reverseOutChannelMap[ch] - ch, 1,
|
||||
drcWorkBuffer, self->streamInfo.frameSize);
|
||||
}
|
||||
FDK_drcDec_ProcessTime(self->hUniDrcDecoder, drcDelay,
|
||||
DRC_DEC_DRC2_DRC3, 0, 0,
|
||||
self->streamInfo.numChannels, drcWorkBuffer,
|
||||
self->streamInfo.frameSize);
|
||||
|
||||
if (needsDeinterleaving) {
|
||||
FDK_interleave(
|
||||
|
|
Loading…
Reference in New Issue