forked from xiaozhi/xiaozhi-esp32
feat: add support for ESP32-P4-Function-EV-Board (#1210)
* feat: add support for ESP32-P4-Function-EV-Board with configuration and display handling * detect wake word model from index.json * update wait time before entering wifi configure mode * feat: Enhance ESP32-P4 Function EV Board support with LCD and touch initialization * feat: Update ESP32-P4 Function EV Board configuration for improved touch and SD card support * feat: add touch I2C configuration and improve initialization structure * Remove ESP hosted configuration from defaults Removed ESP hosted configuration options. * chore: update documentation for improved clarity * refactor: remove obsolete files for ESP32-P4-Function-EV-Board and add updated configurations * refactor: reintroduce ESP32-P4-Function-EV-Board implementation with updated configurations * refactor: restore esp32_p4_function_ev_board dependency with updated version --------- Co-authored-by: n2flowjs-bot <n2flowjs@gmail.com> Co-authored-by: Terrence <terrence@tenclass.com>
This commit is contained in:
@@ -303,6 +303,8 @@ elseif(CONFIG_BOARD_TYPE_ESP32P4_WIFI6_Touch_LCD_XC)
|
||||
set(BUILTIN_TEXT_FONT font_puhui_basic_30_4)
|
||||
set(BUILTIN_ICON_FONT font_awesome_30_4)
|
||||
set(DEFAULT_EMOJI_COLLECTION twemoji_64)
|
||||
elseif(CONFIG_BOARD_TYPE_ESP32P4_Function_EV_Board)
|
||||
set(BOARD_TYPE "esp-p4-function-ev-board")
|
||||
elseif(CONFIG_BOARD_TYPE_BREAD_COMPACT_WIFI_LCD)
|
||||
set(BOARD_TYPE "bread-compact-wifi-lcd")
|
||||
set(BUILTIN_TEXT_FONT font_puhui_basic_16_4)
|
||||
|
||||
@@ -290,6 +290,9 @@ choice BOARD_TYPE
|
||||
config BOARD_TYPE_ESP32P4_WIFI6_Touch_LCD_XC
|
||||
bool "Waveshare ESP32-P4-WIFI6-Touch-LCD-3.4C or ESP32-P4-WIFI6-Touch-LCD-4C"
|
||||
depends on IDF_TARGET_ESP32P4
|
||||
config BOARD_TYPE_ESP_P4_Function_EV_Board
|
||||
bool "ESP-P4-Function-EV-Board"
|
||||
depends on IDF_TARGET_ESP32P4
|
||||
config BOARD_TYPE_TUDOUZI
|
||||
bool "土豆子"
|
||||
depends on IDF_TARGET_ESP32S3
|
||||
|
||||
@@ -107,6 +107,10 @@ bool CustomWakeWord::Initialize(AudioCodec* codec, srmodel_list_t* models_list)
|
||||
|
||||
// 初始化 multinet (命令词识别)
|
||||
mn_name_ = esp_srmodel_filter(models_, ESP_MN_PREFIX, language_.c_str());
|
||||
if (mn_name_ == nullptr) {
|
||||
ESP_LOGW(TAG, "Language '%s' multinet not found, falling back to any multinet model", language_.c_str());
|
||||
mn_name_ = esp_srmodel_filter(models_, ESP_MN_PREFIX, NULL);
|
||||
}
|
||||
if (mn_name_ == nullptr) {
|
||||
ESP_LOGE(TAG, "Failed to initialize multinet, mn_name is nullptr");
|
||||
ESP_LOGI(TAG, "Please refer to https://pcn7cs20v8cr.feishu.cn/wiki/CpQjwQsCJiQSWSkYEvrcxcbVnwh to add custom wake word");
|
||||
|
||||
35
main/boards/esp-p4-function-ev-board/README.md
Normal file
35
main/boards/esp-p4-function-ev-board/README.md
Normal file
@@ -0,0 +1,35 @@
|
||||
# ESP-P4-Function-EV-Board
|
||||
|
||||
Board support for ESP-P4-Function-EV-Board. Wi‑Fi uses ESP‑Hosted via the on‑board ESP32‑C6. LCD is supported via the official MIPI‑DSI LCD adapter.
|
||||
|
||||
## Features
|
||||
- Wi‑Fi: `esp_wifi_remote` + `esp_hosted` (SDIO) with ESP32‑C6 co‑processor
|
||||
- Display: 7" MIPI‑DSI LCD (1024×600) via adapter; can also run headless
|
||||
- Audio: Can run with dummy codec; board includes ES8311 + PA if needed
|
||||
|
||||
## Configure
|
||||
In `menuconfig`: Xiaozhi Assistant -> Board Type -> ESP-P4-Function-EV-Board
|
||||
|
||||
Ensure these are set (auto-set when building via config.json):
|
||||
- `CONFIG_SLAVE_IDF_TARGET_ESP32C6=y`
|
||||
- `CONFIG_ESP_HOSTED_P4_DEV_BOARD_FUNC_BOARD=y`
|
||||
- `CONFIG_ESP_HOSTED_SDIO_HOST_INTERFACE=y`
|
||||
- `CONFIG_ESP_HOSTED_SDIO_4_BIT_BUS=y`
|
||||
|
||||
## LCD Connection (from Espressif user guide)
|
||||
- Connect the LCD adapter board J3 to the board’s MIPI DSI connector (reverse ribbon).
|
||||
- Wire `RST_LCD` (adapter J6) to `GPIO27` (board J1).
|
||||
- Wire `PWM` (adapter J6) to `GPIO26` (board J1).
|
||||
- Optionally power the LCD adapter via its USB or provide `5V` and `GND` from the board.
|
||||
|
||||
These pins are pre-configured in `config.h` as `PIN_NUM_LCD_RST=GPIO27` and `DISPLAY_BACKLIGHT_PIN=GPIO26`. Resolution is set to 1024×600.
|
||||
|
||||
## Build (example)
|
||||
```powershell
|
||||
idf.py set-target esp32p4
|
||||
idf.py menuconfig
|
||||
idf.py build
|
||||
```
|
||||
|
||||
Tip: In menuconfig, choose Xiaozhi Assistant -> Board Type -> ESP-P4-Function-EV-Board.
|
||||
If building a release via scripts, the `config.json` in this folder appends the required Hosted options.
|
||||
11
main/boards/esp-p4-function-ev-board/config.h
Normal file
11
main/boards/esp-p4-function-ev-board/config.h
Normal file
@@ -0,0 +1,11 @@
|
||||
#ifndef _BOARD_CONFIG_H_
|
||||
#define _BOARD_CONFIG_H_
|
||||
|
||||
#include "bsp/esp32_p4_function_ev_board.h" // Library for board configs and pins
|
||||
|
||||
#define AUDIO_INPUT_SAMPLE_RATE 24000
|
||||
#define AUDIO_OUTPUT_SAMPLE_RATE 24000
|
||||
|
||||
#define DISPLAY_BACKLIGHT_OUTPUT_INVERT false
|
||||
|
||||
#endif // _BOARD_CONFIG_H_
|
||||
16
main/boards/esp-p4-function-ev-board/config.json
Normal file
16
main/boards/esp-p4-function-ev-board/config.json
Normal file
@@ -0,0 +1,16 @@
|
||||
{
|
||||
"target": "esp32p4",
|
||||
"builds": [
|
||||
{
|
||||
"name": "esp-p4-function-ev-board",
|
||||
"sdkconfig_append": [
|
||||
"CONFIG_SLAVE_IDF_TARGET_ESP32C6=y",
|
||||
"CONFIG_ESP_HOSTED_P4_DEV_BOARD_FUNC_BOARD=y",
|
||||
"CONFIG_ESP_HOSTED_SDIO_HOST_INTERFACE=y",
|
||||
"CONFIG_ESP_HOSTED_SDIO_4_BIT_BUS=y",
|
||||
"CONFIG_SPI_FLASH_SUPPORT_GD_CHIP=y",
|
||||
"CONFIG_BSP_LCD_TYPE_1024_600=y"
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
129
main/boards/esp-p4-function-ev-board/esp-p4-function-ev-board.cc
Normal file
129
main/boards/esp-p4-function-ev-board/esp-p4-function-ev-board.cc
Normal file
@@ -0,0 +1,129 @@
|
||||
#include "wifi_board.h"
|
||||
#include "audio/codecs/es8311_audio_codec.h"
|
||||
// Display
|
||||
#include "display/display.h"
|
||||
#include "display/lcd_display.h"
|
||||
// Backlight
|
||||
// PwmBacklight is declared in backlight headers pulled by display/lcd_display includes via lvgl stack
|
||||
|
||||
#include "application.h"
|
||||
#include "button.h"
|
||||
#include "config.h"
|
||||
|
||||
#include <wifi_station.h>
|
||||
#include <esp_log.h>
|
||||
#include <inttypes.h>
|
||||
#include <driver/i2c_master.h>
|
||||
#include <esp_lvgl_port.h>
|
||||
// SD card
|
||||
#include <esp_vfs_fat.h>
|
||||
#include <sdmmc_cmd.h>
|
||||
#include <driver/sdmmc_host.h>
|
||||
#include <driver/sdspi_host.h>
|
||||
// SD power control (on-chip LDO)
|
||||
#include "sd_pwr_ctrl_by_on_chip_ldo.h"
|
||||
|
||||
// MIPI-DSI / LCD vendor includes (library may replace some)
|
||||
#include "esp_lcd_panel_ops.h"
|
||||
#include "esp_lcd_mipi_dsi.h"
|
||||
#include "esp_ldo_regulator.h"
|
||||
#include "esp_lcd_ek79007.h"
|
||||
#include "esp_lcd_touch_gt911.h"
|
||||
|
||||
// Library includes
|
||||
#include "bsp/esp32_p4_function_ev_board.h"
|
||||
#include "bsp/touch.h"
|
||||
|
||||
#define TAG "ESP32P4FuncEV"
|
||||
|
||||
class ESP32P4FunctionEvBoard : public WifiBoard
|
||||
{
|
||||
private:
|
||||
i2c_master_bus_handle_t codec_i2c_bus_ = nullptr;
|
||||
Button boot_button_;
|
||||
LcdDisplay *display_ = nullptr;
|
||||
esp_lcd_touch_handle_t tp_ = nullptr;
|
||||
|
||||
void InitializeI2cBuses()
|
||||
{
|
||||
ESP_ERROR_CHECK(bsp_i2c_init());
|
||||
codec_i2c_bus_ = bsp_i2c_get_handle();
|
||||
}
|
||||
|
||||
// Touch I2C bus initialization is not required for this board (handled elsewhere)
|
||||
void InitializeTouchI2cBus()
|
||||
{
|
||||
// No implementation needed
|
||||
}
|
||||
|
||||
void InitializeLCD()
|
||||
{
|
||||
bsp_display_config_t config = {
|
||||
.hdmi_resolution = BSP_HDMI_RES_NONE,
|
||||
.dsi_bus = {
|
||||
.phy_clk_src = MIPI_DSI_PHY_CLK_SRC_DEFAULT,
|
||||
.lane_bit_rate_mbps = 1000,
|
||||
},
|
||||
};
|
||||
|
||||
bsp_lcd_handles_t handles;
|
||||
ESP_ERROR_CHECK(bsp_display_new_with_handles(&config, &handles));
|
||||
|
||||
display_ = new MipiLcdDisplay(handles.io, handles.panel, 1024, 600, 0, 0, true, true, false);
|
||||
}
|
||||
|
||||
void InitializeButtons()
|
||||
{
|
||||
boot_button_.OnClick([this]()
|
||||
{
|
||||
auto& app = Application::GetInstance();
|
||||
if (app.GetDeviceState() == kDeviceStateStarting && !WifiStation::GetInstance().IsConnected()) {
|
||||
ResetWifiConfiguration();
|
||||
}
|
||||
app.ToggleChatState(); });
|
||||
}
|
||||
|
||||
void InitializeTouch()
|
||||
{
|
||||
ESP_ERROR_CHECK(bsp_touch_new(NULL, &tp_));
|
||||
}
|
||||
|
||||
public:
|
||||
|
||||
ESP32P4FunctionEvBoard() : boot_button_(0)
|
||||
{
|
||||
InitializeI2cBuses();
|
||||
// Audio is initialized by Es8311AudioCodec
|
||||
InitializeLCD();
|
||||
InitializeButtons();
|
||||
InitializeTouch();
|
||||
GetBacklight()->RestoreBrightness();
|
||||
}
|
||||
|
||||
~ESP32P4FunctionEvBoard()
|
||||
{
|
||||
// Clean up display pointer
|
||||
delete display_;
|
||||
display_ = nullptr;
|
||||
// If other resources need cleanup, add here
|
||||
}
|
||||
|
||||
virtual AudioCodec *GetAudioCodec() override
|
||||
{
|
||||
static Es8311AudioCodec audio_codec(
|
||||
codec_i2c_bus_, (i2c_port_t)BSP_I2C_NUM, AUDIO_INPUT_SAMPLE_RATE, AUDIO_OUTPUT_SAMPLE_RATE,
|
||||
BSP_I2S_MCLK, BSP_I2S_SCLK, BSP_I2S_LCLK, BSP_I2S_DOUT, BSP_I2S_DSIN,
|
||||
BSP_POWER_AMP_IO, ES8311_CODEC_DEFAULT_ADDR, true, false);
|
||||
return &audio_codec;
|
||||
}
|
||||
|
||||
virtual Display *GetDisplay() override { return display_; }
|
||||
|
||||
virtual Backlight *GetBacklight() override
|
||||
{
|
||||
static PwmBacklight backlight(BSP_LCD_BACKLIGHT, DISPLAY_BACKLIGHT_OUTPUT_INVERT);
|
||||
return &backlight;
|
||||
}
|
||||
};
|
||||
|
||||
DECLARE_BOARD(ESP32P4FunctionEvBoard);
|
||||
@@ -100,7 +100,14 @@ SpiLcdDisplay::SpiLcdDisplay(esp_lcd_panel_io_handle_t panel_io, esp_lcd_panel_h
|
||||
|
||||
// Set the display to on
|
||||
ESP_LOGI(TAG, "Turning display on");
|
||||
ESP_ERROR_CHECK(esp_lcd_panel_disp_on_off(panel_, true));
|
||||
{
|
||||
esp_err_t __err = esp_lcd_panel_disp_on_off(panel_, true);
|
||||
if (__err == ESP_ERR_NOT_SUPPORTED) {
|
||||
ESP_LOGW(TAG, "Panel does not support disp_on_off; assuming ON");
|
||||
} else {
|
||||
ESP_ERROR_CHECK(__err);
|
||||
}
|
||||
}
|
||||
|
||||
ESP_LOGI(TAG, "Initialize LVGL library");
|
||||
lv_init();
|
||||
@@ -165,6 +172,7 @@ SpiLcdDisplay::SpiLcdDisplay(esp_lcd_panel_io_handle_t panel_io, esp_lcd_panel_h
|
||||
SetupUI();
|
||||
}
|
||||
|
||||
|
||||
// RGB LCD实现
|
||||
RgbLcdDisplay::RgbLcdDisplay(esp_lcd_panel_io_handle_t panel_io, esp_lcd_panel_handle_t panel,
|
||||
int width, int height, int offset_x, int offset_y,
|
||||
|
||||
@@ -5,6 +5,7 @@ dependencies:
|
||||
espressif/esp_lcd_gc9a01: ==2.0.1
|
||||
espressif/esp_lcd_st77916: ^1.0.1
|
||||
espressif/esp_lcd_axs15231b: ^1.0.0
|
||||
|
||||
espressif/esp_lcd_st7701:
|
||||
version: ^1.1.4
|
||||
rules:
|
||||
@@ -22,7 +23,7 @@ dependencies:
|
||||
78/esp-ml307: ~3.3.6
|
||||
78/xiaozhi-fonts: ~1.5.4
|
||||
espressif/led_strip: ~3.0.1
|
||||
espressif/esp_codec_dev: ~1.4.0
|
||||
espressif/esp_codec_dev: ~1.5
|
||||
espressif/esp-sr: ~2.1.5
|
||||
espressif/button: ~4.1.3
|
||||
espressif/knob: ^1.0.0
|
||||
@@ -65,6 +66,10 @@ dependencies:
|
||||
version: '*'
|
||||
rules:
|
||||
- if: target in [esp32p4]
|
||||
espressif/esp32_p4_function_ev_board:
|
||||
version: "^5.0.3"
|
||||
rules:
|
||||
- if: target in [esp32p4]
|
||||
espressif/esp_lcd_ili9881c:
|
||||
version: ^1.0.1
|
||||
rules:
|
||||
|
||||
Reference in New Issue
Block a user