Files
snapclient/components/audio_board/lyrat_mini_v1_1/board.c
Karl Osterseher 713cda5816 add support for lyrat mini 1.1 board
- update Readme

Signed-off-by: Karl Osterseher <karli_o@gmx.at>
2023-12-27 20:33:09 +01:00

183 lines
6.2 KiB
C

/*
* ESPRESSIF MIT License
*
* Copyright (c) 2019 <ESPRESSIF SYSTEMS (SHANGHAI) CO., LTD>
*
* Permission is hereby granted for use on all ESPRESSIF SYSTEMS products, in
* which case, it is free of charge, to any person obtaining a copy of this
* software and associated documentation files (the "Software"), to deal in the
* Software without restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
* the Software, and to permit persons to whom the Software is furnished to do
* so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
#include "board.h"
#include "audio_mem.h"
#include "esp_log.h"
// #include "periph_sdcard.h"
// #include "led_indicator.h"
// #include "periph_adc_button.h"
static const char *TAG = "AUDIO_BOARD";
static audio_board_handle_t board_handle = 0;
audio_board_handle_t audio_board_init(void) {
if (board_handle) {
ESP_LOGW(TAG, "The board has already been initialized!");
return board_handle;
}
board_handle =
(audio_board_handle_t)audio_calloc(1, sizeof(struct audio_board_handle));
AUDIO_MEM_CHECK(TAG, board_handle, return NULL);
board_handle->audio_hal = audio_board_codec_init();
board_handle->adc_hal = audio_board_adc_init();
return board_handle;
}
audio_hal_handle_t audio_board_adc_init(void) {
audio_hal_codec_config_t audio_codec_cfg = AUDIO_CODEC_DEFAULT_CONFIG();
audio_hal_handle_t adc_hal =
audio_hal_init(&audio_codec_cfg, &AUDIO_CODEC_ES7243_DEFAULT_HANDLE);
AUDIO_NULL_CHECK(TAG, adc_hal, return NULL);
return adc_hal;
}
audio_hal_handle_t audio_board_codec_init(void) {
audio_hal_codec_config_t audio_codec_cfg = AUDIO_CODEC_DEFAULT_CONFIG();
audio_hal_handle_t codec_hal =
audio_hal_init(&audio_codec_cfg, &AUDIO_CODEC_ES8311_DEFAULT_HANDLE);
AUDIO_NULL_CHECK(TAG, codec_hal, return NULL);
return codec_hal;
}
// display_service_handle_t audio_board_led_init(void)
//{
// led_indicator_handle_t led =
// led_indicator_init((gpio_num_t)get_green_led_gpio());
// display_service_config_t display = {
// .based_cfg = {
// .task_stack = 0,
// .task_prio = 0,
// .task_core = 0,
// .task_func = NULL,
// .service_start = NULL,
// .service_stop = NULL,
// .service_destroy = NULL,
// .service_ioctl = led_indicator_pattern,
// .service_name = "DISPLAY_serv",
// .user_data = NULL,
// },
// .instance = led,
// };
//
// return display_service_create(&display);
// }
//
// display_service_handle_t audio_board_blue_led_init(void)
//{
// led_indicator_handle_t led =
// led_indicator_init((gpio_num_t)get_blue_led_gpio());
// display_service_config_t display = {
// .based_cfg = {
// .task_stack = 0,
// .task_prio = 0,
// .task_core = 0,
// .task_func = NULL,
// .service_start = NULL,
// .service_stop = NULL,
// .service_destroy = NULL,
// .service_ioctl = led_indicator_pattern,
// .service_name = "DISPLAY_serv",
// .user_data = NULL,
// },
// .instance = led,
// };
//
// return display_service_create(&display);
// }
//
// esp_err_t audio_board_key_init(esp_periph_set_handle_t set)
//{
// esp_err_t ret = ESP_OK;
// periph_adc_button_cfg_t adc_btn_cfg = PERIPH_ADC_BUTTON_DEFAULT_CONFIG();
// adc_arr_t adc_btn_tag = ADC_DEFAULT_ARR();
// adc_btn_tag.total_steps = 6;
// int btn_array[7] = {190, 600, 1000, 1375, 1775, 2195, 3100};
// adc_btn_tag.adc_level_step = btn_array;
// adc_btn_cfg.arr = &adc_btn_tag;
// adc_btn_cfg.arr_size = 1;
// esp_periph_handle_t adc_btn_handle =
// periph_adc_button_init(&adc_btn_cfg); AUDIO_NULL_CHECK(TAG,
// adc_btn_handle, return ESP_ERR_ADF_MEMORY_LACK); ret =
// esp_periph_start(set, adc_btn_handle); return ret;
// }
//
// esp_err_t audio_board_sdcard_init(esp_periph_set_handle_t set,
// periph_sdcard_mode_t mode)
//{
// if (mode != SD_MODE_1_LINE) {
// ESP_LOGE(TAG, "Current board only support 1-line SD mode!");
// return ESP_FAIL;
// }
// gpio_config_t sdcard_pwr_pin_cfg = {
// .pin_bit_mask = 1UL << SDCARD_PWR_CTRL,
// .mode = GPIO_MODE_OUTPUT,
// .pull_up_en = GPIO_PULLUP_DISABLE,
// .pull_down_en = GPIO_PULLDOWN_DISABLE,
// .intr_type = GPIO_INTR_DISABLE,
// };
//
// gpio_config(&sdcard_pwr_pin_cfg);
// gpio_set_level(SDCARD_PWR_CTRL, 0);
//
// periph_sdcard_cfg_t sdcard_cfg = {
// .root = "/sdcard",
// .card_detect_pin = get_sdcard_intr_gpio(), // GPIO_NUM_34
// .mode = mode
// };
// esp_periph_handle_t sdcard_handle = periph_sdcard_init(&sdcard_cfg);
// esp_err_t ret = esp_periph_start(set, sdcard_handle);
// int retry_time = 5;
// bool mount_flag = false;
// while (retry_time --) {
// if (periph_sdcard_is_mounted(sdcard_handle)) {
// mount_flag = true;
// break;
// } else {
// vTaskDelay(500 / portTICK_PERIOD_MS);
// }
// }
// if (mount_flag == false) {
// ESP_LOGE(TAG, "Sdcard mount failed");
// return ESP_FAIL;
// }
// return ret;
// }
audio_board_handle_t audio_board_get_handle(void) { return board_handle; }
esp_err_t audio_board_deinit(audio_board_handle_t audio_board) {
esp_err_t ret = ESP_OK;
ret |= audio_hal_deinit(audio_board->audio_hal);
ret |= audio_hal_deinit(audio_board->adc_hal);
audio_free(audio_board);
board_handle = NULL;
return ret;
}