基于博流BL606P音视频开发板的智能音箱系统开发方案

发布时间:2023-10-20  

编辑语:

芯片开放社区(OCC)面向广大开发者推出应用实战系列内容,通过分享开发者实战开发案例,总结应用开发经验,梳理开发中的常见问题及解决方案,为后续参与的开发者提供更多参考与借鉴。


本文是关于开发者 乔帮主分享了在Docker环境下,基于博流BL606P音视频开发板,进行智能音箱系统搭建的完成过程。按照文中步骤操作后,你将得到一个可以进行对话的智能音箱。

01背景

平头哥给我提供了一套博流BL606P音视频开发板评测:

2a9f7a16-0448-11ee-90ce-dac502259ad0.jpg2ac89590-0448-11ee-90ce-dac502259ad0.jpg

这套BL606P开发板是由博流科技研发,基于平头哥的XTC906和E907,集成度较高,非常适合用于智能音箱系统。

开发套件提供了主控板、按键板,还提供了4欧3W的喇叭,还有按键板连接线和支撑柱,开箱连接好就能用了。

2afc4d2c-0448-11ee-90ce-dac502259ad0.jpg

2b4353f2-0448-11ee-90ce-dac502259ad0.jpg

另外,这块板子上,还板载调试器,使用Type-C连接电脑后,就能够直接进行调试和固件烧录了,不需要单独配调试器。

我这边一向习惯使用Docker来搭建Linux开发环境,所以这次也不例外。不过,要进行固件烧录,目前还得借助Windows上运行的T-Head-DebugServer。

02Docker搭建基础环境

首先我们要搭建一个基于Ubuntu18.04版本的基础环境,并安装好基础工具包,以及设置好Python3作为默认Python环境。

以下是具体的步骤:


# 主机
# docker启动
mkdir projects
docker run -v $(pwd)/projects:/root/projects --name BL606P -it ubuntu:18.04

#docker内
# 基本工具安装
cd /root
apt update && apt -y install sudo vim

# apt更新安装基础工具包
sudo apt update
sudo apt upgrade
sudo apt install build-essential git curl lsof ping unzip

# 安装ppa
sudo apt install -y software-properties-common
sudo add-apt-repository ppa:deadsnakes/ppa #看到Enter就回车

# 安装python3.7
sudo apt install python3.7

# 更新指向
sudo update-alternatives --install /usr/bin/python python /usr/bin/python3.6 1
sudo update-alternatives --install /usr/bin/python python /usr/bin/python3.7 2

sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.6 1
sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.7 2

sudo update-alternatives --config python
sudo update-alternatives --config python3

sudo apt autoremove

# 安装pip
sudo apt install python3-dev
sudo apt install python3-pip
sudo update-alternatives --install /usr/bin/pip pip /usr/bin/pip3 1
sudo apt install python3-dev

# 检查Python安装结果:
python -V && python3 -V


最终输出如下,说明基础环境设置成功:

2b6dc34e-0448-11ee-90ce-dac502259ad0.jpg

03YoC工具链安装

XT系列芯片的SDK编译,在Linux下使用yoc工具来进行,通过Python的包管理工具,可以很方便地安装。

具体步骤如下:


# 安装yoctools
sudo pip install yoctools -U

# 安装工具链
sudo yoc toolchain --riscv -f
ls /usr/local/thead/riscv64-unknown-elf

# 查看yoc版本
yoc -V


最终输出结果如下,说明安装成功:

2b8c5e76-0448-11ee-90ce-dac502259ad0.jpg

2ba760b8-0448-11ee-90ce-dac502259ad0.jpg

04开发板的连接

将BL606P开发板连接到Windows电脑上之前,需要做好跳线设置。

参考官方提供的原理图:

2bbe06c4-0448-11ee-90ce-dac502259ad0.jpg

然后对照开发板的跳线进行设置:

2be68a86-0448-11ee-90ce-dac502259ad0.jpg

本质上,就是把GPIO16-19,连接到TCK、TDI、TMS、TDO,这样Type-C连接到电脑后,就能够直接对接到调试端口了。

然后使用Type-C,将开发板的UART接口,连接到Windows电脑:

2c1cae5e-0448-11ee-90ce-dac502259ad0.jpg右边的Type-C接口,只是用于供电的,不能用于调试通信。

05安装 T-Head-DebugServer 调试工具

Windows安装T-Head-DebugServer

Windows可以直接下载 T-Head-DebugServer-windows 版本进行安装即可。下载地址:https://occ.t-head.cn/community/download?id=4133634465765330944

T-Head-DebugServer默认需要1025端口,所以启动前,先检查该端口是否被占用,可在Windows黑窗口执行下面的命令检查:


netstat -aon | findstr LISTEN | findstr 1025


如果输出端口被占用了,上述命令会输出对应的PID信息,可以到任务管理器中查看是什么进程占用了,停止它即可。

其他成功后,界面如下:

2c382116-0448-11ee-90ce-dac502259ad0.jpg

上述界面输出的最后一行,显示了用于远程连接的地址和端口,需要记好,在Docker的Linux环境下面需要使用。


target remote 192.168.1.47:8025


Linux安装:T-Head-DebugServer

Docker环境中的Linux系统上,需要下载 T-Head-DebugServer-linux-x86_64 版本,在上述地址下载,解压后,直接执行解压得到的shell文件安装即可:

2c693d46-0448-11ee-90ce-dac502259ad0.jpg

在Linux环境中,也可以检查1025端口是否被占用,对应的指令如下:


lsof -i:1025


安装好以后,再执行下面的命令启动T-Head-DebugServer:


DebugServerConsole -setclk 8 -port 1025


06测试基础功能开发

上述环境搭建好以后,可以使用官方提供的HelloWorld进行测试,使用如下的步骤,在Docker中的Linux环境下,下载编译HelloWorld工程:


mkdir ~/test
cd ~/test
yoc init
yoc install helloworld
cd solutions/helloworld
make SDK=sdk_chip_bl606p_e907


在上述命令中,使用yoc工具,可以很方便地管理和下载源码。

最后一步完成编译,输出如下:

2ca45368-0448-11ee-90ce-dac502259ad0.jpg

经过上面的步骤, HelloWorld已经编译完毕,可以用于烧录测试了。

在第四节【安装 T-Head-DebugServer 调试工具】中,得到了远程调试的地址和端口,要在Docker中的Linux环境下进行烧录,只需要将gdb烧录配置文件中地址和端口,修改为远程调试端口即可,具体命令如下:


sed -i 's#localhost8025#' gdbinitflash


然后,再执行下面的命令进行烧录:


make flashall SDK=sdk_chip_bl606p_e907


烧录过程中,Windows上的T-Head-DebugServer会有如下的信息输出:

2cc02a5c-0448-11ee-90ce-dac502259ad0.jpg

其中"Get connection from 192.168.1.100",表示来自这个IP的远程调试连接,也就是Docker中的Linux连上来了。

make flashall烧录命令执行成功后,具体输出如下:

2ce843fc-0448-11ee-90ce-dac502259ad0.jpg

现在,可以关闭 Windows上的T-Head-DebugServer 工具,然后使用串口工具连接开发板,波特率使用 2000000,然后重启开发板,就能收到如下的输出信息:

2d1dd918-0448-11ee-90ce-dac502259ad0.jpg

看到【hello world】,说明我们的基础开发烧录运行搞定,下面可以开始进行智能音箱功能的开发烧录测试了。

07智能音箱系统搭建

平头哥为bl606提供了SDK_longyuan,用于智能音箱系统的基础开发,类似上面的HelloWorld,也使用yoc工具进行操作,具体步骤如下:


cd ~/test
yoc install smart_speaker_v2
cd solutions/helloworld
cp package_bl606p_mind.yaml package.yaml
make clean && make


但是在最后make编译的过程中,会出现找不到ao.h文件的问题:

2d473e0c-0448-11ee-90ce-dac502259ad0.jpg

经过一番了解,正确获取该工程的步骤应该如下:


mkdir ~/longyuan
cd ~/longyuan
yoc init
yoc install sdk_longyuan
cd solutions/smart_speaker_v2
cp package_bl606p_mind.yaml package.yaml
make clean && make


编译成功后,输出如下:

2d722edc-0448-11ee-90ce-dac502259ad0.jpg

然后,进行烧录,具体步骤如下:


sed -i 's#localhost8025#' gdbinitflash
make erasechip #擦除
make flashall  #烧录全量镜像
make flash     #仅烧录应用镜像


类似HelloWorld,第一步是设置远程调试地址,所以需要先关闭串口工具,并打开Windows上的T-Head-DebugServer 工具,再执行上面的烧录指令。

烧录完成后,输出如下:

2d928bd2-0448-11ee-90ce-dac502259ad0.jpg

烧录完成后,再次关闭Windows上的T-Head-DebugServer 工具,然后使用串口工具连接到开发板,重启开发板后,会进入基础shell环境,并提示进行WiFi连接设置,此时要使用如下的指令:


kv set wifi_ssid0 OpenBSD
kv set wifi_psk0 13581882013
reboot


再次重启成功后,喇叭就会发声,网络连接成功,天猫精灵欢迎。

按照正常逻辑,此时就可以说【天猫精灵】唤醒,进行对话了。

实际使用时,说【天猫精灵】唤醒后,马上就死机了,反复尝试都是直接崩溃了。

又经过一番了解,原来,需要降级编译链才行。

具体步骤如下:

从https://occ.t-head.cn/community/download?id=4049193882418745344下载Xuantie-900-gcc-elf-newlib-x86_64-V2.4.0-20220428.tar.gz到~/

解压工具链:


cd ~
tar xzvf Xuantie-900-gcc-elf-newlib-x86_64-V2.4.0-20220428.tar.gz


设置工具链路径:


export PATH="/root/Xuantie-900-gcc-elf-newlib-x86_64-V2.4.0/bin:/root/Xuantie-900-gcc-elf-newlib-x86_64-V2.4.0/riscv64-unknown-elf/bin:$PATH"


设置完成,重新上面的编译烧录步骤,并再次设置WiFi连接,一切就正常了。

08智能音箱系统体验

完成后的智能音箱,可以脱离调试环境了,使用专用电源供电,或者使用Type-C供电,就能使用了。

使用【天猫精灵】唤醒,发出滴滴咚声后,就可以进行自然语言对话了。

说出【天猫精灵】唤醒,会出现如下的输出:

2dc57bc8-0448-11ee-90ce-dac502259ad0.png最后的WAKEUP表示唤醒。

再说出【告诉我现在时间】,就可看到和听到回复了:

2e1f173c-0448-11ee-90ce-dac502259ad0.png

现在,就可以愉快地玩耍了。

09智能音箱系统体验

虽然在智能音箱系统搭建的过程中,遇到了一些小问题,不过总的来说,还是比较顺畅的。

博流提供了完成的BL6060开发套件,平头哥提供了可以用于二次开发的系统源码,最终实现的智能音箱,使用起来也非常流畅,回复也基本感觉不到延迟,体验很好。

基于此基础上,以此为原型,实现更多功能,进行产品的开发,可以非常的快捷方便。


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    开放,也就是R9 Nano迷你小钢炮的继任者。 你对新3A平台期待吗? 责任编辑:mooreelite......
    多媒体音箱的连接方法_多媒体音箱怎么用;  多媒体音箱的连接方法   1、把红色线小音箱的插头插入主音箱的右声道红色音频输出孔(正常情况都是红右、白左)。   2、把白色线小音箱的插头插入主音箱......
    速度快,光谱特性及r值一致性好等特点外,在高温,多湿的恶劣环境下,还能保持高度的稳定性和可靠性,可广泛应用于照相机,太阳能庭院灯,草坪灯,验钞机,石英钟,音乐杯,礼品盒,迷你小夜灯,光声控开关,路灯......
    豪威集团推出12.6V 7A全集成同步升压转换器WD31089Q,助力蓝牙音箱使用体验升级;忙碌的生活,来点音乐才能调节气氛。便携式蓝牙音箱因为简单易用、方便携带、受到消费者的青睐。对于这种随身小音箱......
    现多种音效。应用这颗芯片分频变得非常简单,可以通过EQ的调整弥补喇叭腔体的不足,通过DRC可以防止破音,还有混音,人声增强,低音增强等多种工具可以使用。这颗芯片最大的亮点是内置小音频低频增强算法,让音箱在中小音......
    频低频增强算法,让音箱在中小音量播放时,仍能输出足够的低频。为家庭影院、车载音频、蓝牙音箱等要求严格且注重成本的产品提供了一个成本效益非常高的中大功率输出级解决方案。 ACM8629概述 ACM8629一款......
    频低频增强算法,让音箱在中小音量播放时,仍能输出足够的低频。为家庭影院、车载音频、蓝牙音箱等要求严格且注重成本的产品提供了一个成本效益非常高的中大功率输出级解决方案。 ACM8629概述 ACM8629......
    整弥补喇叭腔体的不足,通过DRC可以防止破音,还有混音,人声增强,低音增强等多种工具可以使用。这颗芯片最大的亮点是内置小音频低频增强算法,让音箱在中小音量播放时,仍能输出足够的低频。为家庭影院、车载音频、蓝牙音箱......
    表面灰尘可使用蘸温水的毛巾擦拭,切记等水分全干后再开机。开机时把音量开到小然后在开机,开机在调音。关机的时候永阳先调小音量再关电源。长时间大音量放声之后,音箱会变得很热,此时关机,避免事故发生。切记......
    惠普发布两款迷你机:造型别致;迷你机是近年来颇为火爆的一种产品类型,惠普也趁着IFA大会发布了两款新品,造型都相当的别致、有创意。 首先是“Pavilion Wave”,圆润三角形截面设计,顶部还有个抛物面式的音箱......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>