全志V853芯片 在Tina下RISC-V核E907启动方式的选择
Posted 神棍地海棠
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了全志V853芯片 在Tina下RISC-V核E907启动方式的选择相关的知识,希望对你有一定的参考价值。
1.主题
Tina V85x E907启动方式选择
2.问题背景
Tina V85x 平台E907支持2种启动方式,分别是boot0启动和内核启动。
Tina V85x SDK默认配置一般是不启动E907,为方便用户配置开发,下面以V853 perf1方案为例,介绍具体的操作步骤。
3.解决办法
一、boot0启动
要修改E907为boot0启动,需要修改以下几处
- boot_package_nor.cfg
文件:config/chips/v853/configs/default/boot_package_nor.cfg
修改:去掉riscv.fex的注释,将E907固件打包进系统
-;item=melis-elf, riscv.fex
+item=melis-elf, riscv.fex
- 设备树
文件:lichee/brandy-2.0/spl/board/sun8iw21p1/common.mk
修改:注释掉 e907_rproc@0 节点和 rpbuf_controller@0 节点的 iommus = <&mmu_aw 5 1>; 属性
--- a/configs/perf1/board.dts
+++ b/configs/perf1/board.dts
@@ -58,7 +58,7 @@
mboxes = <&msgbox 0>;
mbox-names = "mbox-chan";
- iommus = <&mmu_aw 5 1>;
+ //iommus = <&mmu_aw 5 1>;
fw-region = <&e907_fw>;
memory-mappings =
@@ -74,7 +74,7 @@
compatible = "allwinner,rpbuf-controller";
remoteproc = <&e907_rproc>;
ctrl_id = <0>; /* index of /dev/rpbuf_ctrl */
- iommus = <&mmu_aw 5 1>;
+ //iommus = <&mmu_aw 5 1>;
status = "okay";
;
- boot0代码
文件:lichee/brandy-2.0/spl/board/sun8iw21p1/common.mk
修改:添加boot0启动E907功能
-CFG_RISCV_E907=y
-CFG_SUNXI_ELF=y
+#CFG_RISCV_E907=y
+#CFG_SUNXI_ELF=y
- 内核配置
需要 m kernel_menuconfig 打开以下配置(默认已打开)
CONFIG_REMOTEPROC=y
CONFIG_SUNXI_RPROC=y
CONFIG_RPMSG=y
CONFIG_RPMSG_VIRTIO=y
CONFIG_SUNXI_RPMSG_HEARBEAT=y
CONFIG_RPBUF=y
CONFIG_RPBUF_DEV=y
CONFIG_RPBUF_CONTROLLER_SUNXI=y
按以上步骤修改完成后,需重新编译打包固件即可
mp -j32
二、内核启动
- 打包固件
方法1: 将编译出来的固件复制到 target/allwinner/v853-perf1/busybox-init-base-files/lib/firmware 目录下
方法2: 使用adb将固件推到小机端的/lib/firmware目录
- 内核配置
需要 m kernel_menuconfig 打开以下配置(默认已打开)
CONFIG_REMOTEPROC=y
CONFIG_SUNXI_RPROC=y
CONFIG_RPMSG=y
CONFIG_RPMSG_VIRTIO=y
CONFIG_SUNXI_RPMSG_HEARBEAT=y
CONFIG_RPBUF=y
CONFIG_RPBUF_DEV=y
CONFIG_RPBUF_CONTROLLER_SUNXI=y
三、验证
echo 固件名 > /sys/kernel/debug/remoteproc/remoteproc0/firmware
停止E907
echo stop > /sys/kernel/debug/remoteproc/remoteproc0/state
启动E907
echo start > /sys/kernel/debug/remoteproc/remoteproc0/state
可以通过观察E907的默认串口来观察是否正常启动.
四、2种启动方式区别
1、boot0启动较早,适用于需要快起的方案;kernel启动较晚
2、boot0启动的E907不能使用IOMMU,kernel阶段启动能够使用IOMMU
3、boot0启动的固件要打包进bootpackage,每次更换都要重新烧录固件;kernel启动用的固件能放在文件系统,很方便使用adb进行替换
以上是关于全志V853芯片 在Tina下RISC-V核E907启动方式的选择的主要内容,如果未能解决你的问题,请参考以下文章
全志V853芯片放开快启方案打印及在快起方式下配置isp led的方法
全志R128芯片 在FreeRTOS下如何查看并更改RISC-V 和 ARM 两个CPU核的默认运行频率?
全志 Tina Linux RISC-V E907核心开发指南支持百问网V85x系列开发板100ask-v853-pro v851s等
全志 Tina Linux RISC-V E907核心开发指南支持百问网V85x系列开发板100ask-v853-pro v851s等
全志 Tina Linux LCD显示屏调试指南 支持MIPI DSI RGB LVDS I8080 SPI等接口,开发板支持百问网T113 D1-H哪吒 DongshanPI-D1s V853
全志 Tina Linux LCD显示屏调试指南 支持MIPI DSI RGB LVDS I8080 SPI等接口,开发板支持百问网T113 D1-H哪吒 DongshanPI-D1s V853