2016-11-23 11:29:35 +00:00
|
|
|
/*
|
2018-05-31 03:56:06 +00:00
|
|
|
* Copyright (c) 2017-2018, The Linux Foundation. All rights reserved.
|
2016-11-23 11:29:35 +00:00
|
|
|
* Not a Contribution.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2011 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef QAHW_EFFECT_VIRTUALIZER_H_
|
|
|
|
#define QAHW_EFFECT_VIRTUALIZER_H_
|
|
|
|
|
|
|
|
#include <qahw_effect_api.h>
|
|
|
|
|
2018-05-31 03:56:06 +00:00
|
|
|
#ifdef __cplusplus
|
2016-11-23 11:29:35 +00:00
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define QAHW_EFFECT_VIRTUALIZER_LIBRARY "libqcompostprocbundle.so"
|
|
|
|
|
|
|
|
static const qahw_effect_uuid_t SL_IID_VIRTUALIZER_ = { 0x37cc2c00, 0xdddd, 0x11db, 0x8577,
|
|
|
|
{ 0x00, 0x02, 0xa5, 0xd5, 0xc5, 0x1b } };
|
2017-02-23 08:46:22 +00:00
|
|
|
static const qahw_effect_uuid_t * const SL_IID_VIRTUALIZER = &SL_IID_VIRTUALIZER_;
|
2016-11-23 11:29:35 +00:00
|
|
|
|
|
|
|
static const qahw_effect_uuid_t SL_IID_VIRTUALIZER_UUID_ = { 0x509a4498, 0x561a, 0x4bea, 0xb3b1,
|
|
|
|
{ 0x00, 0x02, 0xa5, 0xd5, 0xc5, 0x1b } };
|
2017-02-23 08:46:22 +00:00
|
|
|
static const qahw_effect_uuid_t * const SL_IID_VIRTUALIZER_UUID = &SL_IID_VIRTUALIZER_UUID_;
|
2016-11-23 11:29:35 +00:00
|
|
|
|
|
|
|
/* enumerated parameter settings for virtualizer effect */
|
|
|
|
/* to keep in sync with frameworks/base/media/java/android/media/audiofx/Virtualizer.java */
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
VIRTUALIZER_PARAM_STRENGTH_SUPPORTED,
|
|
|
|
VIRTUALIZER_PARAM_STRENGTH,
|
|
|
|
// used with EFFECT_CMD_GET_PARAM
|
|
|
|
// format:
|
|
|
|
// parameters int32_t VIRTUALIZER_PARAM_VIRTUAL_SPEAKER_ANGLES
|
|
|
|
// audio_channel_mask_t input channel mask
|
|
|
|
// audio_devices_t audio output device
|
|
|
|
// output int32_t* an array of length 3 * the number of channels in the mask
|
|
|
|
// where entries are the succession of the channel mask
|
|
|
|
// of each speaker (i.e. a single bit is selected in the
|
|
|
|
// channel mask) followed by the azimuth and the
|
|
|
|
// elevation angles.
|
|
|
|
// status int -EINVAL if configuration is not supported or invalid or not forcing
|
|
|
|
// 0 if configuration is supported and the mode is forced
|
|
|
|
// notes:
|
|
|
|
// - all angles are expressed in degrees and are relative to the listener,
|
|
|
|
// - for azimuth: 0 is the direction the listener faces, 180 is behind the listener, and
|
|
|
|
// -90 is to her/his left,
|
|
|
|
// - for elevation: 0 is the horizontal plane, +90 is above the listener, -90 is below.
|
|
|
|
VIRTUALIZER_PARAM_VIRTUAL_SPEAKER_ANGLES,
|
|
|
|
// used with EFFECT_CMD_SET_PARAM
|
|
|
|
// format:
|
|
|
|
// parameters int32_t VIRTUALIZER_PARAM_FORCE_VIRTUALIZATION_MODE
|
|
|
|
// audio_devices_t audio output device
|
|
|
|
// status int -EINVAL if the device is not supported or invalid
|
|
|
|
// 0 if the device is supported and the mode is forced, or forcing
|
|
|
|
// was disabled for the AUDIO_DEVICE_NONE audio device.
|
|
|
|
VIRTUALIZER_PARAM_FORCE_VIRTUALIZATION_MODE,
|
|
|
|
// used with EFFECT_CMD_GET_PARAM
|
|
|
|
// format:
|
|
|
|
// parameters int32_t VIRTUALIZER_PARAM_VIRTUALIZATION_MODE
|
|
|
|
// output audio_device_t audio device reflecting the current virtualization mode,
|
|
|
|
// AUDIO_DEVICE_NONE when not virtualizing
|
|
|
|
// status int -EINVAL if an error occurred
|
|
|
|
// 0 if the output value is successfully retrieved
|
2018-08-20 07:53:24 +00:00
|
|
|
VIRTUALIZER_PARAM_VIRTUALIZATION_MODE,
|
|
|
|
// Internal paramter specific to qahw.
|
|
|
|
// Used to get latency introduced by virtuaizer effect.
|
|
|
|
VIRTUALIZER_PARAM_LATENCY = 0x80000000
|
2016-11-23 11:29:35 +00:00
|
|
|
} qahw_virtualizer_params;
|
|
|
|
|
2018-05-31 03:56:06 +00:00
|
|
|
#ifdef __cplusplus
|
2016-11-23 11:29:35 +00:00
|
|
|
} // extern "C"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#endif /*QAHW_EFFECT_VIRTUALIZER_H_*/
|