Merge commit '9d3950389b53452338fab25f2255623ac159b259' into HEAD
This commit is contained in:
commit
cf68701c39
3 changed files with 83 additions and 8 deletions
|
@ -582,11 +582,22 @@ audio_io_handle_t AudioPolicyManagerBase::getOutput(AudioSystem::stream_type str
|
|||
flags = (AudioSystem::output_flags)(flags | AUDIO_OUTPUT_FLAG_DIRECT);
|
||||
}
|
||||
|
||||
IOProfile *profile = getProfileForDirectOutput(device,
|
||||
samplingRate,
|
||||
format,
|
||||
channelMask,
|
||||
(audio_output_flags_t)flags);
|
||||
// Do not allow offloading if one non offloadable effect is enabled. This prevents from
|
||||
// creating an offloaded track and tearing it down immediately after start when audioflinger
|
||||
// detects there is an active non offloadable effect.
|
||||
// FIXME: We should check the audio session here but we do not have it in this context.
|
||||
// This may prevent offloading in rare situations where effects are left active by apps
|
||||
// in the background.
|
||||
IOProfile *profile = NULL;
|
||||
if (((flags & AUDIO_OUTPUT_FLAG_COMPRESS_OFFLOAD) == 0) ||
|
||||
!isNonOffloadableEffectEnabled()) {
|
||||
profile = getProfileForDirectOutput(device,
|
||||
samplingRate,
|
||||
format,
|
||||
channelMask,
|
||||
(audio_output_flags_t)flags);
|
||||
}
|
||||
|
||||
if (profile != NULL) {
|
||||
AudioOutputDescriptor *outputDesc = NULL;
|
||||
|
||||
|
@ -1299,6 +1310,20 @@ status_t AudioPolicyManagerBase::setEffectEnabled(EffectDescriptor *pDesc, bool
|
|||
return NO_ERROR;
|
||||
}
|
||||
|
||||
bool AudioPolicyManagerBase::isNonOffloadableEffectEnabled()
|
||||
{
|
||||
for (size_t i = 0; i < mEffects.size(); i++) {
|
||||
const EffectDescriptor * const pDesc = mEffects.valueAt(i);
|
||||
if (pDesc->mEnabled && (pDesc->mStrategy == STRATEGY_MEDIA) &&
|
||||
((pDesc->mDesc.flags & EFFECT_FLAG_OFFLOAD_SUPPORTED) == 0)) {
|
||||
ALOGV("isNonOffloadableEffectEnabled() non offloadable effect %s enabled on session %d",
|
||||
pDesc->mDesc.name, pDesc->mSession);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
bool AudioPolicyManagerBase::isStreamActive(int stream, uint32_t inPastMs) const
|
||||
{
|
||||
nsecs_t sysTime = systemTime();
|
||||
|
@ -1472,6 +1497,16 @@ bool AudioPolicyManagerBase::isOffloadSupported(const audio_offload_info_t& offl
|
|||
return false;
|
||||
}
|
||||
|
||||
// Do not allow offloading if one non offloadable effect is enabled. This prevents from
|
||||
// creating an offloaded track and tearing it down immediately after start when audioflinger
|
||||
// detects there is an active non offloadable effect.
|
||||
// FIXME: We should check the audio session here but we do not have it in this context.
|
||||
// This may prevent offloading in rare situations where effects are left active by apps
|
||||
// in the background.
|
||||
if (isNonOffloadableEffectEnabled()) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// See if there is a profile to support this.
|
||||
// AUDIO_DEVICE_NONE
|
||||
IOProfile *profile = getProfileForDirectOutput(AUDIO_DEVICE_NONE /*ignore device */,
|
||||
|
@ -1497,7 +1532,8 @@ AudioPolicyManagerBase::AudioPolicyManagerBase(AudioPolicyClientInterface *clien
|
|||
mPhoneState(AudioSystem::MODE_NORMAL),
|
||||
mLimitRingtoneVolume(false), mLastVoiceVolume(-1.0f),
|
||||
mTotalEffectsCpuLoad(0), mTotalEffectsMemory(0),
|
||||
mA2dpSuspended(false), mHasA2dp(false), mHasUsb(false), mHasRemoteSubmix(false)
|
||||
mA2dpSuspended(false), mHasA2dp(false), mHasUsb(false), mHasRemoteSubmix(false),
|
||||
mSpeakerDrcEnabled(false)
|
||||
{
|
||||
mpClientInterface = clientInterface;
|
||||
|
||||
|
@ -1505,8 +1541,6 @@ AudioPolicyManagerBase::AudioPolicyManagerBase(AudioPolicyClientInterface *clien
|
|||
mForceUse[i] = AudioSystem::FORCE_NONE;
|
||||
}
|
||||
|
||||
initializeVolumeCurves();
|
||||
|
||||
mA2dpDeviceAddress = String8("");
|
||||
mScoDeviceAddress = String8("");
|
||||
mUsbCardAndDevice = String8("");
|
||||
|
@ -1518,6 +1552,9 @@ AudioPolicyManagerBase::AudioPolicyManagerBase(AudioPolicyClientInterface *clien
|
|||
}
|
||||
}
|
||||
|
||||
// must be done after reading the policy
|
||||
initializeVolumeCurves();
|
||||
|
||||
// open all output streams needed to access attached devices
|
||||
for (size_t i = 0; i < mHwModules.size(); i++) {
|
||||
mHwModules[i]->mHandle = mpClientInterface->loadHwModule(mHwModules[i]->mName);
|
||||
|
@ -2839,6 +2876,11 @@ const AudioPolicyManagerBase::VolumeCurvePoint
|
|||
{1, -29.7f}, {33, -20.1f}, {66, -10.2f}, {100, 0.0f}
|
||||
};
|
||||
|
||||
const AudioPolicyManagerBase::VolumeCurvePoint
|
||||
AudioPolicyManagerBase::sSpeakerSonificationVolumeCurveDrc[AudioPolicyManagerBase::VOLCNT] = {
|
||||
{1, -35.7f}, {33, -26.1f}, {66, -13.2f}, {100, 0.0f}
|
||||
};
|
||||
|
||||
// AUDIO_STREAM_SYSTEM, AUDIO_STREAM_ENFORCED_AUDIBLE and AUDIO_STREAM_DTMF volume tracks
|
||||
// AUDIO_STREAM_RING on phones and AUDIO_STREAM_MUSIC on tablets.
|
||||
// AUDIO_STREAM_DTMF tracks AUDIO_STREAM_VOICE_CALL while in call (See AudioService.java).
|
||||
|
@ -2849,6 +2891,11 @@ const AudioPolicyManagerBase::VolumeCurvePoint
|
|||
{1, -24.0f}, {33, -18.0f}, {66, -12.0f}, {100, -6.0f}
|
||||
};
|
||||
|
||||
const AudioPolicyManagerBase::VolumeCurvePoint
|
||||
AudioPolicyManagerBase::sDefaultSystemVolumeCurveDrc[AudioPolicyManagerBase::VOLCNT] = {
|
||||
{1, -34.0f}, {33, -24.0f}, {66, -15.0f}, {100, -6.0f}
|
||||
};
|
||||
|
||||
const AudioPolicyManagerBase::VolumeCurvePoint
|
||||
AudioPolicyManagerBase::sHeadsetSystemVolumeCurve[AudioPolicyManagerBase::VOLCNT] = {
|
||||
{1, -30.0f}, {33, -26.0f}, {66, -22.0f}, {100, -18.0f}
|
||||
|
@ -2927,6 +2974,18 @@ void AudioPolicyManagerBase::initializeVolumeCurves()
|
|||
sVolumeProfiles[i][j];
|
||||
}
|
||||
}
|
||||
|
||||
// Check availability of DRC on speaker path: if available, override some of the speaker curves
|
||||
if (mSpeakerDrcEnabled) {
|
||||
mStreams[AUDIO_STREAM_SYSTEM].mVolumeCurve[DEVICE_CATEGORY_SPEAKER] =
|
||||
sDefaultSystemVolumeCurveDrc;
|
||||
mStreams[AUDIO_STREAM_RING].mVolumeCurve[DEVICE_CATEGORY_SPEAKER] =
|
||||
sSpeakerSonificationVolumeCurveDrc;
|
||||
mStreams[AUDIO_STREAM_ALARM].mVolumeCurve[DEVICE_CATEGORY_SPEAKER] =
|
||||
sSpeakerSonificationVolumeCurveDrc;
|
||||
mStreams[AUDIO_STREAM_NOTIFICATION].mVolumeCurve[DEVICE_CATEGORY_SPEAKER] =
|
||||
sSpeakerSonificationVolumeCurveDrc;
|
||||
}
|
||||
}
|
||||
|
||||
float AudioPolicyManagerBase::computeVolume(int stream,
|
||||
|
@ -3653,6 +3712,11 @@ uint32_t AudioPolicyManagerBase::stringToEnum(const struct StringToEnum *table,
|
|||
return 0;
|
||||
}
|
||||
|
||||
bool AudioPolicyManagerBase::stringToBool(const char *value)
|
||||
{
|
||||
return ((strcasecmp("true", value) == 0) || (strcmp("1", value) == 0));
|
||||
}
|
||||
|
||||
audio_output_flags_t AudioPolicyManagerBase::parseFlagNames(char *name)
|
||||
{
|
||||
uint32_t flag = 0;
|
||||
|
@ -3958,6 +4022,9 @@ void AudioPolicyManagerBase::loadGlobalConfig(cnode *root)
|
|||
} else if (strcmp(ATTACHED_INPUT_DEVICES_TAG, node->name) == 0) {
|
||||
mAvailableInputDevices = parseDeviceNames((char *)node->value) & ~AUDIO_DEVICE_BIT_IN;
|
||||
ALOGV("loadGlobalConfig() mAvailableInputDevices %04x", mAvailableInputDevices);
|
||||
} else if (strcmp(SPEAKER_DRC_ENABLED_TAG, node->name) == 0) {
|
||||
mSpeakerDrcEnabled = stringToBool((char *)node->value);
|
||||
ALOGV("loadGlobalConfig() mSpeakerDrcEnabled = %d", mSpeakerDrcEnabled);
|
||||
}
|
||||
node = node->next;
|
||||
}
|
||||
|
|
|
@ -236,7 +236,9 @@ protected:
|
|||
static const VolumeCurvePoint sSpeakerMediaVolumeCurve[AudioPolicyManagerBase::VOLCNT];
|
||||
// volume curve for sonification strategy on speakers
|
||||
static const VolumeCurvePoint sSpeakerSonificationVolumeCurve[AudioPolicyManagerBase::VOLCNT];
|
||||
static const VolumeCurvePoint sSpeakerSonificationVolumeCurveDrc[AudioPolicyManagerBase::VOLCNT];
|
||||
static const VolumeCurvePoint sDefaultSystemVolumeCurve[AudioPolicyManagerBase::VOLCNT];
|
||||
static const VolumeCurvePoint sDefaultSystemVolumeCurveDrc[AudioPolicyManagerBase::VOLCNT];
|
||||
static const VolumeCurvePoint sHeadsetSystemVolumeCurve[AudioPolicyManagerBase::VOLCNT];
|
||||
static const VolumeCurvePoint sDefaultVoiceVolumeCurve[AudioPolicyManagerBase::VOLCNT];
|
||||
static const VolumeCurvePoint sSpeakerVoiceVolumeCurve[AudioPolicyManagerBase::VOLCNT];
|
||||
|
@ -491,12 +493,15 @@ protected:
|
|||
|
||||
audio_io_handle_t selectOutputForEffects(const SortedVector<audio_io_handle_t>& outputs);
|
||||
|
||||
bool isNonOffloadableEffectEnabled();
|
||||
|
||||
//
|
||||
// Audio policy configuration file parsing (audio_policy.conf)
|
||||
//
|
||||
static uint32_t stringToEnum(const struct StringToEnum *table,
|
||||
size_t size,
|
||||
const char *name);
|
||||
static bool stringToBool(const char *value);
|
||||
static audio_output_flags_t parseFlagNames(char *name);
|
||||
static audio_devices_t parseDeviceNames(char *name);
|
||||
void loadSamplingRates(char *name, IOProfile *profile);
|
||||
|
@ -550,6 +555,8 @@ protected:
|
|||
audio_devices_t mAttachedOutputDevices; // output devices always available on the platform
|
||||
audio_devices_t mDefaultOutputDevice; // output device selected by default at boot time
|
||||
// (must be in mAttachedOutputDevices)
|
||||
bool mSpeakerDrcEnabled;// true on devices that use DRC on the DEVICE_CATEGORY_SPEAKER path
|
||||
// to boost soft sounds, used to adjust volume curves accordingly
|
||||
|
||||
Vector <HwModule *> mHwModules;
|
||||
|
||||
|
|
|
@ -34,6 +34,7 @@
|
|||
#define ATTACHED_OUTPUT_DEVICES_TAG "attached_output_devices"
|
||||
#define DEFAULT_OUTPUT_DEVICE_TAG "default_output_device"
|
||||
#define ATTACHED_INPUT_DEVICES_TAG "attached_input_devices"
|
||||
#define SPEAKER_DRC_ENABLED_TAG "speaker_drc_enabled"
|
||||
|
||||
// hw modules descriptions
|
||||
#define AUDIO_HW_MODULE_TAG "audio_hw_modules"
|
||||
|
|
Loading…
Reference in a new issue