mirror of
https://github.com/esphome/esphome.git
synced 2025-03-06 10:48:18 +00:00
Allow esp-adf libraries to be used by any board
This commit is contained in:
parent
fce2eafda0
commit
161fbecfe1
@ -2,16 +2,17 @@ import os
|
|||||||
|
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
|
import esphome.final_validate as fv
|
||||||
|
|
||||||
from esphome.components import esp32
|
from esphome.components import esp32
|
||||||
|
|
||||||
from esphome.const import CONF_ID, CONF_BOARD
|
from esphome.const import CONF_ID, CONF_BOARD
|
||||||
|
|
||||||
CONFLICTS_WITH = ["i2s_audio"]
|
|
||||||
CODEOWNERS = ["@jesserockz"]
|
CODEOWNERS = ["@jesserockz"]
|
||||||
DEPENDENCIES = ["esp32"]
|
DEPENDENCIES = ["esp32"]
|
||||||
|
|
||||||
CONF_ESP_ADF_ID = "esp_adf_id"
|
CONF_ESP_ADF_ID = "esp_adf_id"
|
||||||
|
CONF_ESP_ADF = "esp_adf"
|
||||||
|
|
||||||
esp_adf_ns = cg.esphome_ns.namespace("esp_adf")
|
esp_adf_ns = cg.esphome_ns.namespace("esp_adf")
|
||||||
ESPADF = esp_adf_ns.class_("ESPADF", cg.Component)
|
ESPADF = esp_adf_ns.class_("ESPADF", cg.Component)
|
||||||
@ -23,13 +24,28 @@ SUPPORTED_BOARDS = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def _validate_board(config):
|
def _default_board(config):
|
||||||
board = config.get(CONF_BOARD, esp32.get_board())
|
config = config.copy()
|
||||||
if board not in SUPPORTED_BOARDS:
|
if board := config.get(CONF_BOARD) is None:
|
||||||
raise cv.Invalid(f"Board {board} is not supported by esp-adf")
|
board = esp32.get_board()
|
||||||
|
if board in SUPPORTED_BOARDS:
|
||||||
|
config[CONF_BOARD] = board
|
||||||
return config
|
return config
|
||||||
|
|
||||||
|
|
||||||
|
def final_validate_usable_board(platform: str):
|
||||||
|
def _validate(adf_config):
|
||||||
|
board = adf_config.get(CONF_BOARD)
|
||||||
|
if board not in SUPPORTED_BOARDS:
|
||||||
|
raise cv.Invalid(f"Board {board} is not supported by esp-adf {platform}")
|
||||||
|
return adf_config
|
||||||
|
|
||||||
|
return cv.Schema(
|
||||||
|
{cv.Required(CONF_ESP_ADF_ID): fv.id_declaration_match_schema(_validate)},
|
||||||
|
extra=cv.ALLOW_EXTRA,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
cv.Schema(
|
cv.Schema(
|
||||||
{
|
{
|
||||||
@ -37,7 +53,7 @@ CONFIG_SCHEMA = cv.All(
|
|||||||
cv.Optional(CONF_BOARD): cv.string_strict,
|
cv.Optional(CONF_BOARD): cv.string_strict,
|
||||||
}
|
}
|
||||||
),
|
),
|
||||||
_validate_board,
|
_default_board,
|
||||||
cv.only_with_esp_idf,
|
cv.only_with_esp_idf,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -62,7 +78,10 @@ async def to_code(config):
|
|||||||
cg.add_platformio_option(
|
cg.add_platformio_option(
|
||||||
"board_build.embed_txtfiles", "components/dueros_service/duer_profile"
|
"board_build.embed_txtfiles", "components/dueros_service/duer_profile"
|
||||||
)
|
)
|
||||||
board = config.get(CONF_BOARD, esp32.get_board())
|
|
||||||
|
if board := config.get(CONF_BOARD):
|
||||||
|
cg.add_define("USE_ESP_ADF_BOARD")
|
||||||
|
|
||||||
esp32.add_idf_sdkconfig_option(SUPPORTED_BOARDS[board], True)
|
esp32.add_idf_sdkconfig_option(SUPPORTED_BOARDS[board], True)
|
||||||
|
|
||||||
esp32.add_extra_script(
|
esp32.add_extra_script(
|
||||||
|
@ -12,10 +12,11 @@ namespace esp_adf {
|
|||||||
static const char *const TAG = "esp_adf";
|
static const char *const TAG = "esp_adf";
|
||||||
|
|
||||||
void ESPADF::setup() {
|
void ESPADF::setup() {
|
||||||
|
#ifdef USE_ESP_ADF_BOARD
|
||||||
ESP_LOGI(TAG, "Start codec chip");
|
ESP_LOGI(TAG, "Start codec chip");
|
||||||
|
|
||||||
audio_board_handle_t board_handle = audio_board_init();
|
audio_board_handle_t board_handle = audio_board_init();
|
||||||
audio_hal_ctrl_codec(board_handle->audio_hal, AUDIO_HAL_CODEC_MODE_BOTH, AUDIO_HAL_CTRL_START);
|
audio_hal_ctrl_codec(board_handle->audio_hal, AUDIO_HAL_CODEC_MODE_BOTH, AUDIO_HAL_CTRL_START);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
float ESPADF::get_setup_priority() const { return setup_priority::HARDWARE; }
|
float ESPADF::get_setup_priority() const { return setup_priority::HARDWARE; }
|
||||||
|
@ -3,9 +3,16 @@ import esphome.config_validation as cv
|
|||||||
from esphome.components import microphone
|
from esphome.components import microphone
|
||||||
from esphome.const import CONF_ID
|
from esphome.const import CONF_ID
|
||||||
|
|
||||||
from .. import CONF_ESP_ADF_ID, ESPADF, ESPADFPipeline, esp_adf_ns
|
from .. import (
|
||||||
|
CONF_ESP_ADF_ID,
|
||||||
|
ESPADF,
|
||||||
|
ESPADFPipeline,
|
||||||
|
esp_adf_ns,
|
||||||
|
final_validate_usable_board,
|
||||||
|
)
|
||||||
|
|
||||||
AUTO_LOAD = ["esp_adf"]
|
AUTO_LOAD = ["esp_adf"]
|
||||||
|
CONFLICTS_WITH = ["i2s_audio"]
|
||||||
DEPENDENCIES = ["esp32"]
|
DEPENDENCIES = ["esp32"]
|
||||||
|
|
||||||
ESPADFMicrophone = esp_adf_ns.class_(
|
ESPADFMicrophone = esp_adf_ns.class_(
|
||||||
@ -23,6 +30,8 @@ CONFIG_SCHEMA = cv.All(
|
|||||||
cv.only_with_esp_idf,
|
cv.only_with_esp_idf,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
FINAL_VALIDATE_SCHEMA = final_validate_usable_board("microphone")
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = cg.new_Pvariable(config[CONF_ID])
|
||||||
|
@ -3,9 +3,16 @@ import esphome.config_validation as cv
|
|||||||
from esphome.components import speaker
|
from esphome.components import speaker
|
||||||
from esphome.const import CONF_ID
|
from esphome.const import CONF_ID
|
||||||
|
|
||||||
from .. import CONF_ESP_ADF_ID, ESPADF, ESPADFPipeline, esp_adf_ns
|
from .. import (
|
||||||
|
CONF_ESP_ADF_ID,
|
||||||
|
ESPADF,
|
||||||
|
ESPADFPipeline,
|
||||||
|
esp_adf_ns,
|
||||||
|
final_validate_usable_board,
|
||||||
|
)
|
||||||
|
|
||||||
AUTO_LOAD = ["esp_adf"]
|
AUTO_LOAD = ["esp_adf"]
|
||||||
|
CONFLICTS_WITH = ["i2s_audio"]
|
||||||
DEPENDENCIES = ["esp32"]
|
DEPENDENCIES = ["esp32"]
|
||||||
|
|
||||||
ESPADFSpeaker = esp_adf_ns.class_(
|
ESPADFSpeaker = esp_adf_ns.class_(
|
||||||
@ -23,6 +30,8 @@ CONFIG_SCHEMA = cv.All(
|
|||||||
cv.only_with_esp_idf,
|
cv.only_with_esp_idf,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
FINAL_VALIDATE_SCHEMA = final_validate_usable_board("speaker")
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = cg.new_Pvariable(config[CONF_ID])
|
||||||
|
Loading…
x
Reference in New Issue
Block a user