Implemented audio path management API in GDx and Mod17 audio drivers, removed old audio management API
This commit is contained in:
parent
21481072e7
commit
4411e0f3e8
|
|
@ -95,26 +95,6 @@ bool audio_checkPathCompatibility(const enum AudioSource p1Source,
|
|||
const enum AudioSource p2Source,
|
||||
const enum AudioSink p2Sink);
|
||||
|
||||
/**
|
||||
* Enable microphone.
|
||||
*/
|
||||
void audio_enableMic();
|
||||
|
||||
/**
|
||||
* Disable microphone.
|
||||
*/
|
||||
void audio_disableMic();
|
||||
|
||||
/**
|
||||
* Enable audio PA.
|
||||
*/
|
||||
void audio_enableAmp();
|
||||
|
||||
/**
|
||||
* Disable audio PA.
|
||||
*/
|
||||
void audio_disableAmp();
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -22,33 +22,57 @@
|
|||
#include <interfaces/gpio.h>
|
||||
#include <hwconfig.h>
|
||||
|
||||
|
||||
static const uint8_t pathCompatibilityMatrix[9][9] =
|
||||
{
|
||||
// MIC-SPK MIC-RTX MIC-MCU RTX-SPK RTX-RTX RTX-MCU MCU-SPK MCU-RTX MCU-MCU
|
||||
{ 0 , 0 , 0 , 1 , 0 , 1 , 1 , 0 , 1 }, // MIC-RTX
|
||||
{ 0 , 0 , 0 , 0 , 1 , 1 , 0 , 1 , 1 }, // MIC-SPK
|
||||
{ 0 , 0 , 0 , 1 , 1 , 0 , 1 , 1 , 0 }, // MIC-MCU
|
||||
{ 0 , 1 , 1 , 0 , 0 , 0 , 0 , 1 , 1 }, // RTX-SPK
|
||||
{ 1 , 0 , 1 , 0 , 0 , 0 , 1 , 0 , 1 }, // RTX-RTX
|
||||
{ 1 , 1 , 0 , 0 , 0 , 0 , 1 , 1 , 0 }, // RTX-MCU
|
||||
{ 0 , 1 , 1 , 0 , 1 , 1 , 0 , 0 , 0 }, // MCU-SPK
|
||||
{ 1 , 0 , 1 , 1 , 0 , 1 , 0 , 0 , 0 }, // MCU-RTX
|
||||
{ 1 , 1 , 0 , 1 , 1 , 0 , 0 , 0 , 0 } // MCU-MCU
|
||||
};
|
||||
|
||||
|
||||
void audio_init()
|
||||
{
|
||||
gpio_setMode(AUDIO_AMP_EN, OUTPUT);
|
||||
gpio_clearPin(AUDIO_AMP_EN); /* Audio PA off */
|
||||
gpio_clearPin(AUDIO_AMP_EN);
|
||||
}
|
||||
|
||||
void audio_terminate()
|
||||
{
|
||||
gpio_clearPin(AUDIO_AMP_EN); /* Audio PA off */
|
||||
}
|
||||
|
||||
void audio_enableMic()
|
||||
{
|
||||
/* No mic control on this family */
|
||||
}
|
||||
|
||||
void audio_disableMic()
|
||||
{
|
||||
/* No mic control on this family */
|
||||
}
|
||||
|
||||
void audio_enableAmp()
|
||||
{
|
||||
gpio_setPin(AUDIO_AMP_EN);
|
||||
}
|
||||
|
||||
void audio_disableAmp()
|
||||
{
|
||||
gpio_clearPin(AUDIO_AMP_EN);
|
||||
}
|
||||
|
||||
void audio_connect(const enum AudioSource source, const enum AudioSink sink)
|
||||
{
|
||||
if(sink == SINK_SPK)
|
||||
{
|
||||
gpio_setPin(AUDIO_AMP_EN);
|
||||
}
|
||||
}
|
||||
|
||||
void audio_disconnect(const enum AudioSource source, const enum AudioSink sink)
|
||||
{
|
||||
if(sink == SINK_SPK)
|
||||
{
|
||||
gpio_clearPin(AUDIO_AMP_EN);
|
||||
}
|
||||
}
|
||||
|
||||
bool audio_checkPathCompatibility(const enum AudioSource p1Source,
|
||||
const enum AudioSink p1Sink,
|
||||
const enum AudioSource p2Source,
|
||||
const enum AudioSink p2Sink)
|
||||
|
||||
{
|
||||
uint8_t p1Index = (p1Source * 3) + p1Sink;
|
||||
uint8_t p2Index = (p2Source * 3) + p2Sink;
|
||||
|
||||
return pathCompatibilityMatrix[p1Index][p2Index] == 1;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -156,37 +156,3 @@ bool audio_checkPathCompatibility(const enum AudioSource p1Source,
|
|||
|
||||
return pathCompatibilityMatrix[p1Index][p2Index] == 1;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
void audio_enableMic()
|
||||
{
|
||||
#if !defined(PLATFORM_MD9600) && !defined(MDx_ENABLE_SWD)
|
||||
gpio_setPin(MIC_PWR);
|
||||
#endif
|
||||
}
|
||||
|
||||
void audio_disableMic()
|
||||
{
|
||||
#if !defined(PLATFORM_MD9600) && !defined(MDx_ENABLE_SWD)
|
||||
gpio_clearPin(MIC_PWR);
|
||||
#endif
|
||||
}
|
||||
|
||||
void audio_enableAmp()
|
||||
{
|
||||
#ifndef PLATFORM_MD9600
|
||||
gpio_setPin(AUDIO_AMP_EN);
|
||||
#endif
|
||||
sleepFor(0, 10); /* 10ms anti-pop delay */
|
||||
gpio_clearPin(SPK_MUTE);
|
||||
}
|
||||
|
||||
void audio_disableAmp()
|
||||
{
|
||||
gpio_setPin(SPK_MUTE);
|
||||
#ifndef PLATFORM_MD9600
|
||||
gpio_clearPin(AUDIO_AMP_EN);
|
||||
#endif
|
||||
}
|
||||
|
|
|
|||
|
|
@ -20,9 +20,24 @@
|
|||
|
||||
#include <interfaces/audio.h>
|
||||
#include <interfaces/gpio.h>
|
||||
#include <interfaces/delays.h>
|
||||
#include <hwconfig.h>
|
||||
|
||||
|
||||
static const uint8_t pathCompatibilityMatrix[9][9] =
|
||||
{
|
||||
// MIC-SPK MIC-RTX MIC-MCU RTX-SPK RTX-RTX RTX-MCU MCU-SPK MCU-RTX MCU-MCU
|
||||
{ 0 , 0 , 0 , 1 , 0 , 1 , 1 , 0 , 1 }, // MIC-RTX
|
||||
{ 0 , 0 , 0 , 0 , 1 , 1 , 0 , 1 , 1 }, // MIC-SPK
|
||||
{ 0 , 0 , 0 , 1 , 1 , 0 , 1 , 1 , 0 }, // MIC-MCU
|
||||
{ 0 , 1 , 1 , 0 , 0 , 0 , 0 , 1 , 1 }, // RTX-SPK
|
||||
{ 1 , 0 , 1 , 0 , 0 , 0 , 1 , 0 , 1 }, // RTX-RTX
|
||||
{ 1 , 1 , 0 , 0 , 0 , 0 , 1 , 1 , 0 }, // RTX-MCU
|
||||
{ 0 , 1 , 1 , 0 , 1 , 1 , 0 , 0 , 0 }, // MCU-SPK
|
||||
{ 1 , 0 , 1 , 1 , 0 , 1 , 0 , 0 , 0 }, // MCU-RTX
|
||||
{ 1 , 1 , 0 , 1 , 1 , 0 , 0 , 0 , 0 } // MCU-MCU
|
||||
};
|
||||
|
||||
|
||||
void audio_init()
|
||||
{
|
||||
gpio_setMode(SPK_MUTE, OUTPUT);
|
||||
|
|
@ -40,22 +55,26 @@ void audio_terminate()
|
|||
gpio_clearPin(MIC_MUTE);
|
||||
}
|
||||
|
||||
void audio_enableMic()
|
||||
void audio_connect(const enum AudioSource source, const enum AudioSink sink)
|
||||
{
|
||||
gpio_setPin(MIC_MUTE);
|
||||
if(source == SOURCE_MIC) gpio_setPin(MIC_MUTE);
|
||||
if(sink == SINK_SPK) gpio_clearPin(SPK_MUTE);
|
||||
}
|
||||
|
||||
void audio_disableMic()
|
||||
void audio_disconnect(const enum AudioSource source, const enum AudioSink sink)
|
||||
{
|
||||
gpio_clearPin(MIC_MUTE);
|
||||
if(source == SOURCE_MIC) gpio_clearPin(MIC_MUTE);
|
||||
if(sink == SINK_SPK) gpio_setPin(SPK_MUTE);
|
||||
}
|
||||
|
||||
void audio_enableAmp()
|
||||
{
|
||||
gpio_clearPin(SPK_MUTE);
|
||||
}
|
||||
bool audio_checkPathCompatibility(const enum AudioSource p1Source,
|
||||
const enum AudioSink p1Sink,
|
||||
const enum AudioSource p2Source,
|
||||
const enum AudioSink p2Sink)
|
||||
|
||||
void audio_disableAmp()
|
||||
{
|
||||
gpio_setPin(SPK_MUTE);
|
||||
uint8_t p1Index = (p1Source * 3) + p1Sink;
|
||||
uint8_t p2Index = (p2Source * 3) + p2Sink;
|
||||
|
||||
return pathCompatibilityMatrix[p1Index][p2Index] == 1;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -111,23 +111,3 @@ bool audio_checkPathCompatibility(const enum AudioSource p1Source,
|
|||
|
||||
return pathCompatibilityMatrix[p1Index][p2Index] == 1;
|
||||
}
|
||||
|
||||
void audio_enableMic()
|
||||
{
|
||||
/* No mic control on this family */
|
||||
}
|
||||
|
||||
void audio_disableMic()
|
||||
{
|
||||
/* No mic control on this family */
|
||||
}
|
||||
|
||||
void audio_enableAmp()
|
||||
{
|
||||
/* No PA control on this family */
|
||||
}
|
||||
|
||||
void audio_disableAmp()
|
||||
{
|
||||
/* No PA control on this family */
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue