DshanMCU-R128s2 烧写固件

2023-12-22 16:47:25

编译系统源码后,打包后生成的系统文件称之为固件。固件一般为.img格式。把固件下载到开发板或者产品上的过程称之为烧写固件

烧录模式

R128 有两种烧录模式,分别为 USB 烧录与UART烧录。烧录模式以芯片 RST 时 PA1,PA2 引脚高低电平控制。

R128 Module 默认配置为 USB 烧录,PA2 已经在模组通过下拉电阻下拉。

PA1PA2模式
11非法模式
10正常启动
01UART 下载
00USB 下载

USB 烧写

R128 支持使用 USB 烧写系统。对于 Windows 用户可以使用 PhoenixSuit 进行烧写。是最常用的烧写工具,通过数据线将PC和开发板连接,把固件烧到开发板上。PhoenixSuit 支持分区烧写,适用于开发和小规模生产使用。

PhoenixSuit - Windows

  • 打开PhoenixSuit

  • 点击浏览,选择固件

  • 点击全盘擦除升级

image1

  • 使用 USB 数据线连接 USB OTG (USB转串口也可以连接,用于烧录查错)

image2

  • 按住 FEL 键,然后点击 RESET 键重置开发板

image3

  • RESET 点击后 PhoenixSuit 会自动进入烧录模式,开始下载

image4

  • 烧录完成

image5

PhoenixSuit 单独分区烧录

在开发的时候,会遇到只需要烧录单独分区的情况,例如只修改了 RV 核心的固件,不需要全盘下载。就可以选择单独分区烧录功能。

  • 选择单或多分区下载,PhoenixSuit 会解析固件并生成分区表
  • 选择需要下载的核心的固件

image6

PhoenixSuit - Linux

Linux 版本 PhoenixSuit 支持的发行版本包括 Ubuntu、Fedora、Redhat 及 CentOS 等几个常见的发行版本。目前驱动已经可以支持 4.11.0 版本以上内核,建议安装内核版本号大于4.11.0 的 Linux 发行版本。

安装 PhoenixSuit - Linux
  • 下载 PhoenixSuit 到 Linux 中,解压

image7

  • 安装依赖 dkms,对于 Ubuntu 可以用 sudo apt install dkms dctrl_tools 来安装

!image8

  • 打开终端,输入 sudo ./PhoenixSuit.run 来运行安装程序。

image9

  • 使用 USB 数据线连接 USB OTG (USB转串口也可以连接,用于烧录查错)

image3

  • 按住 FEL 键,然后点击 RESET 键重置开发板使其进入下载模式

image2

  • 安装完成后可以用 lsusb 查看 USB 设备,找到 ID 1f3a:efe8,找到即安装完成。

image10

烧录
  • 使用命令 sudo ./PhoenixSuit rtos_xxx_uart0_16Mnor.img 下载烧录 rtos_xxx_uart0_16Mnor.img

image11

  • 显示 Clos image OK! 时,按住 FEL 引脚,点击 RESET 键使芯片进入下载模式

image

  • 开始烧录

image12

  • 烧录完成

image13

虚拟机 Linux 烧录
  • 如果使用的是虚拟机连接开发板烧录,先运行 sudo ./PhoenixSuit rtos_xxx_uart0_16Mnor.img 下载烧录 rtos_xxx_uart0_16Mnor.img,先进入下载模式。

image11

  • 选择设备-USB,选择 Onda 设备连接虚拟机

image14

  • 开始烧录,但是运行到 Dev Plugout The Device Path is /dev/aw_efex0 会卡住

image15

  • 此时需要重新到 设备-USB 重新连接 USB 设备,这是因为芯片烧录时需要重置USB,导致USB编号变化,虚拟机不会自动连接。

image16

  • 开始下载

image13

  • 如果长时间没有重新连接 USB 设备,PhoenixSuit 会超时自动退出,报错如下

image17

  • 如果刚才长时间没有重新连接,超时后连接上 USB 设备,重新运行sudo ./PhoenixSuit rtos_xxx_uart0_16Mnor.img 下载命令。会出现 Errpr!!!: PnpFesIn Error! 这是因为烧录启动时的 USB 模式不匹配导致的,之前的操作导致USB进入了 FFFF 模式。此时需要按住 FEL 引脚,点击 RESET 键使芯片进入下载模式重新下载(下载模式会显示 02B3

image18

PhoenixSuit - MacOS

  • 下载解压 PhoneixSuit_MacOS.zip
  • 在 Mac 电脑中进入终端,将目录切到工具目录下
  • 执行命令 chmod 777 ./phoenixsuit 赋予运行权限
  • 使用命令 ./phoenixsuit rtos_xxx_uart0_16Mnor.img 下载烧录 rtos_xxx_uart0_16Mnor.img
  • 设备重新到 boot 的时候会自动进行烧写
  • 烧写成功,设备重启

image19

USB 烧写的流程

R128 系统的烧写流程如下:

  • 片内引导 BROM 初始化芯片,识别到 PA1,PA2 脚为 USB 烧录模式,初始化 USB
  • 上位机通过 USB 烧写 BOOT0 到 SRAM 中,并运行 BOOT0
  • BOOT0 初始化 PSRAM,返回完成信号等待上位机下载 BOOT1(U-Boot)
  • 上位机收到信号,下载 BOOT1(U-Boot)到 PSRAM 中,并引导运行 BOOT1(U-Boot)
  • BOOT1(U-Boot) 初始化系统资源,初始化内部 SPI NOR,USB2.0 等资源,等待上位机下载
  • 上位机下发固件,进入烧写模式,烧写固件
USB 烧录 log
[0]fes begin commit:61c5f1c6
[2]set pll end
[3]board init ok
[5]fake dram ok
[7]heap: 0x40a0000 size:0xe000
[9]lpsram init
[11]lspsram init aps64
[13]lspsram dqs:0x011b01b0
[18]psram chip APS64 init ok!, freq 1920000000
[22]Init psram controller ok
[24]hpsram init
[26]DRAM DQS gate is PD mode.
[29]DRAM BOOT DRIVE INFO 001: V2.00
[32]DRAM CLK = 800 MHZ
[34]dram_tpr11 = 0x0 , dram_tpr12 =0x0
[38]dram_tpr9 = 0x2222
[68]DRAM simple test OK.
[70]DRAM SIZE =8 MB
[82]fes1 done


U-Boot 2018.05-g024e8cd (Jul 04 2023 - 03:57:33 +0000) Allwinner Technology

[01.080]CPU:   Allwinner Family
[01.083]Model: sun20iw2
[01.086]DRAM:  8 MiB
[01.096]Relocation Offset is: 00799000
[01.131]secure enable bit: 0
[01.135]CPU=384 MHz,PLL6=192 Mhz,AHB=192 Mhz, APB1=96Mhz  MBus=4125Mhz
[01.142]sunxi flash type@0 not support fast burn key
[01.146]flash init start
[01.149]workmode = 16,storage type = 0
try card 0
set card number 0
get card number 0
[01.157][mmc]: mmc driver ver uboot2018:2021-07-19 14:09:00
[01.166][mmc]: get sdc_type fail and use default host:tm1.
[01.209][mmc]: can't find node "mmc0",will add new node
[01.214][mmc]: fdt err returned <no error>
[01.218][mmc]: Using default timing para
[01.221][mmc]: SUNXI SDMMC Controller Version:0x50310
[01.235][mmc]: mmc 0 cmd timeout 100 status 100
[01.240][mmc]: smc 0 err, cmd 8,  RTO
[01.243][mmc]: mmc 0 close bus gating and reset
[01.248][mmc]: mmc 0 cmd timeout 100 status 100
[01.253][mmc]: smc 0 err, cmd 55,  RTO
[01.256][mmc]: mmc 0 close bus gating and reset
[01.265][mmc]: mmc 0 cmd timeout 100 status 100
[01.269][mmc]: smc 0 err, cmd 1,  RTO
[01.272][mmc]: mmc 0 close bus gating and reset
[01.277][mmc]: Card did not respond to voltage select!
[01.282][mmc]: mmc_init: -95, time 56
[01.285][mmc]: mmc_init: mmc init fail, err -95
MMC init failed
try emmc fail
spi sunxi_slave->max_hz:50000000
sr3:0x68 --> 0x68
SF: Detected w25q128 with flag 0x301 with page size 256 Bytes, erase size 4 KiB, total 16 MiB
not boot mode, unlock all
[01.360]Loading Environment from SUNXI_FLASH... OK
[01.369]try to burn key
[01.372]out of usb burn from boot: not need burn key
Hit any key to stop autoboot:  0
sunxi work mode=0x10
run usb efex
delay time 2500
weak:otg_phy_config
usb init ok
set address 0xe
set address 0xe ok
SUNXI_EFEX_ERASE_TAG
erase_flag = 0x12
origin_erase_flag = 0x1
FEX_CMD_fes_verify_status
FEX_CMD_fes_verify last err=0
the 0 mbr table is ok
*************MBR DUMP***************
total mbr part 9

part[0] name      :env
part[0] classname :DISK
part[0] addrlo    :0x20
part[0] lenlo     :0x8
part[0] user_type :32768
part[0] keydata   :0
part[0] ro        :0

part[1] name      :env-redund
part[1] classname :DISK
part[1] addrlo    :0x28
part[1] lenlo     :0x8
part[1] user_type :32768
part[1] keydata   :0
part[1] ro        :0

part[2] name      :arm-lpsram
part[2] classname :DISK
part[2] addrlo    :0x30
part[2] lenlo     :0x960
part[2] user_type :32768
part[2] keydata   :0
part[2] ro        :0

part[3] name      :rv-lpsram
part[3] classname :DISK
part[3] addrlo    :0x990
part[3] lenlo     :0xfa0
part[3] user_type :32768
part[3] keydata   :0
part[3] ro        :0

part[4] name      :dsp-hpsram
part[4] classname :DISK
part[4] addrlo    :0x1930
part[4] lenlo     :0x640
part[4] user_type :32768
part[4] keydata   :0
part[4] ro        :0

part[5] name      :rtos-xip
part[5] classname :DISK
part[5] addrlo    :0x1f70
part[5] lenlo     :0x1388
part[5] user_type :32768
part[5] keydata   :0
part[5] ro        :0

part[6] name      :arm-b
part[6] classname :DISK
part[6] addrlo    :0x32f8
part[6] lenlo     :0x960
part[6] user_type :32768
part[6] keydata   :0
part[6] ro        :0

part[7] name      :config
part[7] classname :DISK
part[7] addrlo    :0x3c58
part[7] lenlo     :0x20
part[7] user_type :32768
part[7] keydata   :0
part[7] ro        :0

part[8] name      :UDISK
part[8] classname :DISK
part[8] addrlo    :0x3c78
part[8] lenlo     :0x0
part[8] user_type :33024
part[8] keydata   :0
part[8] ro        :0

need erase flash: 18
The Chip Erase size is: 16M ...
SUNXI_EFEX_MBR_TAG
mbr size = 0x4000
write primary GPT success
spinor: skip backup GPT
[43.156]update partition map
FEX_CMD_fes_verify_status
FEX_CMD_fes_verify last err=0
FEX_CMD_fes_verify_value, start 0x20, size high 0x0:low 0x1000
FEX_CMD_fes_verify_value 0x8c999e79
FEX_CMD_fes_verify_value, start 0x28, size high 0x0:low 0x1000
FEX_CMD_fes_verify_value 0x8c999e79
FEX_CMD_fes_verify_value, start 0x30, size high 0x0:low 0x121e48
FEX_CMD_fes_verify_value 0xe3775740
FEX_CMD_fes_verify_value, start 0x1930, size high 0x0:low 0x7a168
FEX_CMD_fes_verify_value 0x3b80dabd
FEX_CMD_fes_verify_value, start 0x1f70, size high 0x0:low 0x23c230
FEX_CMD_fes_verify_value 0x8bdd937b
FEX_CMD_fes_verify_value, start 0x32f8, size high 0x0:low 0xe8338
FEX_CMD_fes_verify_value 0x3e12775c
FEX_CMD_fes_verify_value, start 0x3c58, size high 0x0:low 0x3c00
FEX_CMD_fes_verify_value 0xe5de21c
flash sectors: 0x8000
FEX_CMD_fes_verify_value, start 0x3c78, size high 0x0:low 0x7e5400
FEX_CMD_fes_verify_value 0x4536d51f
bootfile_mode=4
SUNXI_EFEX_BOOT1_TAG
boot1 size = 0x8000, max size = 0x80000
uboot size = 0x124000
storage type = 3
skip toc1
FEX_CMD_fes_verify_status
FEX_CMD_fes_verify last err=0
bootfile_mode=4
SUNXI_EFEX_BOOT0_TAG
boot0 size = 0xc080
storage type = 3
burn first boot0 ok!
burn boot0 redund ok!
FEX_CMD_fes_verify_status
FEX_CMD_fes_verify last err=0
sunxi_efex_next_action=2
exit usb
next work 2
SUNXI_UPDATE_NEXT_ACTION_REBOOT
free spi flash

UART 烧写

R128 支持使用 UART 烧写系统。

请注意:R128 Module 在硬件上下拉了 PA2 引脚,默认配置为USB下载模式。如果希望使用 UART 下载需要摘除 PA2 下拉电阻,或者外部上拉 PA2 到 3V3

image20

PA2 下拉电阻为 47K,可以直接上拉 PA2 到 3V3 进入UART下载模式

image21

UART 下载设置

  • 打开 PhoenixMC 点击 刷新 ,注意在下载过程中请断开各类串口监视器,不能占用串口,否则刷新找不到对应串口。
  • 配置串口波特率,一般选择 1500000 即可

如果选择太高的波特率会导致通讯错误,板载的 CH340C 仅支持最大2000000波特率

image22

  • 点击 刷新 选择对应的串口
  • 点击调试进入调试界面

image23

如果出现 Open uart error! 则表示没有关闭串口助手或者选择错了串口。

image24

  • 配置 Flash 长度,例如 R128 内置 16M NOR Flash,这里就填入 0x1000000 也就是 16M 长度
  • 烧写前先擦除 Flash
  • 点击写入

image25

  • 选择 16M 固件,注意这个固件后缀名是 .bin ,不是 USB 烧写的 .img 文件

注意:USB 烧写使用的是专有格式,需要 PhoenixSuit 解析并烧录,UART 烧写使用的是通用格式,为内置 SPI NOR 的镜像文件。

image26

  • 提示文件较小,点击确定即可

image27

  • 开始烧写

image28

  • 烧写完成,下载结束

image29

UART mBoot 通讯协议

HostMain-CMDSub-CMDCMD ValueDescriptionRemarks
PC0x000x000x00Read 1 byte
PC0x000x010x01Write 1 byte
PC0x000x020x02Read 2 bytes
PC0x000x030x03Write 2 bytes
PC0x000x040x04Read 4 bytes
PC0x000x050x05Write 4 bytes
PC0x000x060x06Read 8 bytes
PC0x000x070x07Write 8 bytes
PC0x010x000x08Read n bytes
PC0x010x010x09Write n bytes
PC0x020x000x10Change the UART transmission condition
PC0x020x010x11Enable/Disable JTAG
PC0x020x020x12reboot
PC0x020x030x13Set PC pointer
PC0x020x040x14Enable/disable MCU transmission and validation
PC0x020x050x15Obtain baud rate list
PC0x020x060x16Modify the buffer
PC0x000x000x18Obtain flash information
PC0x010x010x19Chip erase
PC0x010x020x1ARead n sectors
PC0x010x030x1BWrite n sectors
PC0x010x040x1CObtain flash information
PC0x010x050x1DChip erase
PC0x010x060x1ERead n sectors
PC0x010x070x1FWrite n sectors
MCU0x000x00Send message to PC

烧录速度对比

烧录方式擦除速度烧录速度
USB30s38s
UART (1500000)60s205s
UART (115200)60s1466s

文章来源:https://blog.csdn.net/thisway_diy/article/details/135153195
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。