[004] [ESP32开发笔记] 音频开发框架ADF环境搭建——基于ESP-IDF

ESP32
开发笔记
ADF环境搭建
打补丁
常见错误与配置

1 ADF环境搭建

在ESP-IDF环境的基础上安装ESP-ADF环境

image-20220406212603129

安装成功后,会缺少几个库文件未安装,分别是内嵌的esp-idfesp-idf-libs(adf音频库)、esp-sr(adf语音识别库),因为这些库在esp-idf-master仓库下都是以分支branch链接形式存储的。

  • 需要单独安装的库

方法一

image-20220406213346244
image-20220406232619440

分别将这些文件复制到..\esp-adf\esp-idf..\esp-adf\components\esp-adf-libs..\esp-adf\components\esp-sr文件夹中。

方法二:用git命令克隆仓库:

  1. esp-adf-libs目录下执行:
git clone https://gitclone.com/github.com/espressif/esp-adf-libs
  1. esp-sr目录下执行:
git clone https://gitclone.com/github.com/espressif/esp-sr.git

git克隆的esp-sr库文件,经本人测试缺少一些文件,编译会报错,后面直接在官方仓库下载复制得以解决。

  1. esp-idf目录下执行:
git clone https://gitclone.com/github.com/espressif/esp-idf
  1. 以上仓库下载完成后,修改adf目录下.gitmodules的内容如下:
    image-20220406234259675
[submodule "esp-idf"]
	path = esp-idf
	url = https://gitclone.com/github.com/espressif/esp-idf
[submodule "components/esp-adf-libs"]
	path = components/esp-adf-libs
	url = https://gitclone.com/github.com/espressif/esp-adf-libs
[submodule "components/esp-sr"]
	path = components/esp-sr
	url = https://gitclone.com/github.com/espressif/esp-sr.git

当两个仓库下载完成后,在adf目录下cmd执行git submodule update --init,这一步将两个子模块切换到当前ADF要求的版本。

  • 添加环境变量

方法一:在 Command Promp中运行以下命令:

set ADF_PATH=D:\ESP-IDF\esp-adf

ADF_PATH为ADF库安装路径

方法二:进入git bash的vim编辑器输入以下命令:

export IDF_PATH="D:\ESP-IDF\esp-adf"

输入完成后按ESC键,然后输入 :wq 点击回车。

方法三:手动添加:
image-20220406234259675
如果不添加环境变量,可以直接使用库所在路径:

include(D:/ESP-IDF/esp-iot-solution/component.cmake)	
include($ENV{IOT_SOLUTION_PATH}/component.cmake)
  • 在ESP-IDF插件设置中添加ADF安装路径
    image-20220527015458010
  • 选择对应芯片型号的开发板HAL库(我的是ESP32-S2
    image-20220407191505343

编译demo测试:
image-20220406234259675


参考:

2 打补丁

因为我们默认选择了在 psram 上运行的音频任务堆栈,这意味着您需要应用补丁 $ADF_PATH/idf_patches/idf_v4.4_freertos.patch 来支持此功能。(4.4与IDF版本保证一致)

在esp-idf路径下鼠标右键git-bash-here输入:

git apply ./idf_v4.4_freertos.patch

3 常见错误与配置

  1. error:esp-adf/components/audio_board/lyrat_v4_3/board_pins_config.c
  1. esp-iot-solution代码框架:unknown type name ‘i2s_dac_mode_t’
  1. https链接需要进行证书的认证
    在这里插入图片描述
    在这里插入图片描述
  2. AAC解码失败,修改Menuconfig
    在这里插入图片描述
    要运行 AAC 解码器,系统任务滴答时间CONFIG_FREERTOS_HZ 应设置为 1000 Hz:
    在这里插入图片描述

END

猜你喜欢

转载自blog.csdn.net/kouxi1/article/details/125117170