188 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			188 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|  | // Copyright 2023-2024 Beken
 | ||
|  | //
 | ||
|  | // 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.
 | ||
|  | //
 | ||
|  | #pragma once
 | ||
|  | #include <common/bk_include.h>
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #define BK_ERR_AUD_DRV_BASE             BK_ERR_AUD_BASE
 | ||
|  | #define BK_ERR_AUD_DRV_NOT_INIT         (BK_ERR_AUD_BASE - 1) /**< AUD driver not init */
 | ||
|  | 
 | ||
|  | 
 | ||
|  | typedef struct { | ||
|  | 	bool adc_is_init; | ||
|  | 	bool dmic_is_init; | ||
|  | 	bool dtmf_is_init; | ||
|  | 	bool dac_is_init; | ||
|  | } aud_module_init_sta_t; | ||
|  | 
 | ||
|  | typedef enum { | ||
|  | 	AUD_MODULE_ADC = 0,     /**< ADC */ | ||
|  | 	AUD_MODULE_DMIC = 1,    /**< DMIC */ | ||
|  | 	AUD_MODULE_DTMF = 2,    /**< DTMF */ | ||
|  | 	AUD_MODULE_DAC = 3,     /**< DAC */ | ||
|  | 	AUD_MODULE_MAX          /**< AUD module id max */ | ||
|  | } aud_module_id_t; | ||
|  | 
 | ||
|  | typedef enum { | ||
|  | #if CONFIG_AUDIO_ADC
 | ||
|  | 	AUD_ISR_ADCL = 0,    /**< adcl_int_en */ | ||
|  | #endif
 | ||
|  | #if CONFIG_AUDIO_DMIC
 | ||
|  | 	AUD_ISR_DMIC = 2,    /**< dmic_int_en */ | ||
|  | #endif
 | ||
|  | #if CONFIG_AUDIO_DTMF
 | ||
|  | 	AUD_ISR_DTMF = 3,    /**< dtmf_int_en */ | ||
|  | #endif
 | ||
|  | #if CONFIG_AUDIO_DAC
 | ||
|  | 	AUD_ISR_DACL = 4,    /**< dacl_int_en */ | ||
|  | 	AUD_ISR_DACR = 5,    /**< dacr_int_en */ | ||
|  | #endif
 | ||
|  | 	AUD_ISR_MAX | ||
|  | } aud_isr_id_t; | ||
|  | 
 | ||
|  | typedef void (*aud_isr_t)(void); | ||
|  | 
 | ||
|  | typedef struct | ||
|  | { | ||
|  | #if CONFIG_AUDIO_ADC
 | ||
|  | 	aud_isr_t aud_adcl_fifo_handler; | ||
|  | #endif
 | ||
|  | #if CONFIG_AUDIO_DMIC
 | ||
|  | 	aud_isr_t aud_dmic_fifo_handler; | ||
|  | #endif
 | ||
|  | #if CONFIG_AUDIO_DTMF
 | ||
|  | 	aud_isr_t aud_dtmf_fifo_handler; | ||
|  | #endif
 | ||
|  | #if CONFIG_AUDIO_DAC
 | ||
|  | 	aud_isr_t aud_dacl_fifo_handler; | ||
|  | 	aud_isr_t aud_dacr_fifo_handler; | ||
|  | #endif
 | ||
|  | } aud_isr_handle_t; | ||
|  | 
 | ||
|  | 
 | ||
|  | typedef enum { | ||
|  | 	AUD_CLK_XTAL = 0,    /**< XTAL: 26MHz */ | ||
|  | 	AUD_CLK_APLL,        /**< APLL: 24.576MHz*/ | ||
|  | 	AUD_CLK_MAX | ||
|  | } aud_clk_t; | ||
|  | 
 | ||
|  | /* @brief Overview about this API header
 | ||
|  |  * | ||
|  |  */ | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief AUD API | ||
|  |  * @defgroup bk_api_aud AUD API group | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief     Init the AUD driver | ||
|  |  * | ||
|  |  * This API init the resoure common: | ||
|  |  *   - Init AUD driver control memory | ||
|  |  *   - Configure clock and power | ||
|  |  *   - Configure mic enable | ||
|  |  *   - Register AUD isr interrupt | ||
|  |  * | ||
|  |  * This API should be called before any other AUD APIs. | ||
|  |  * | ||
|  |  * @return | ||
|  |  *    - BK_OK: succeed | ||
|  |  *    - others: other errors. | ||
|  |  */ | ||
|  | bk_err_t bk_aud_driver_init(void); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief     Deinit the AUD driver | ||
|  |  * | ||
|  |  * This API free all resource related to AUD, power down AUD and mic. | ||
|  |  * | ||
|  |  * @return | ||
|  |  *    - BK_OK: succeed | ||
|  |  *    - others: other errors. | ||
|  |  */ | ||
|  | bk_err_t bk_aud_driver_deinit(void); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief     Set the audio module initialization status | ||
|  |  * | ||
|  |  * @param id audio module id | ||
|  |  * @param val audio module initialization status | ||
|  |  * | ||
|  |  * @return | ||
|  |  *    - BK_OK: succeed | ||
|  |  *    - others: other errors. | ||
|  |  */ | ||
|  | bk_err_t bk_aud_set_module_init_sta(aud_module_id_t id, bool val); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief     Get the audio module initialization status | ||
|  |  * | ||
|  |  * @param id audio module id | ||
|  |  * | ||
|  |  * @return | ||
|  |  *    - true: audio module already has been initialized | ||
|  |  *    - false: audio module has not been initialized. | ||
|  |  */ | ||
|  | bool bk_aud_get_module_init_sta(aud_module_id_t id); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief     Config audio clock | ||
|  |  * | ||
|  |  * @param clk audio clock source | ||
|  |  * | ||
|  |  * @return | ||
|  |  *    - BK_OK: succeed | ||
|  |  *    - others: other errors. | ||
|  |  */ | ||
|  | bk_err_t bk_aud_clk_config(aud_clk_t clk); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief     Deconfig audio clock | ||
|  |  * | ||
|  |  * @return | ||
|  |  *    - BK_OK: succeed | ||
|  |  *    - others: other errors. | ||
|  |  */ | ||
|  | bk_err_t bk_aud_clk_deconfig(void); | ||
|  | 
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief     Register audio isr | ||
|  |  * | ||
|  |  * This API register audio isr. | ||
|  |  * | ||
|  |  * @param isr_id | ||
|  |  * @param isr audio isr callback | ||
|  |  * | ||
|  |  * @return | ||
|  |  *    - BK_OK: succeed | ||
|  |  *    - others: other errors. | ||
|  |  */ | ||
|  | bk_err_t bk_aud_register_aud_isr(aud_isr_id_t isr_id, aud_isr_t isr); | ||
|  | 
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 |