在Lichee RV Dock上的不成功的烧录尝试

最近在学基于risc-v的简单操作系统,刚好手里有块Lichee RV Dock 的板子,所以在学了基础的"hello, world"程序后,想着能不能把这个程序烧录到板子上,简单的做个实验。

要完成这个任务,需要将程序烧录到sd卡上,板子通电后先执行bootloader程序,再跳转去执行sd卡上的程序,而bootloader程序是机器自带的,所以不用更改。要做的就是写好程序并烧录到sd卡上。听上去似乎挺简单的:)

程序在课程资料中已经给出,不同的是程序中以qemu模拟的risc-v平台为基础去编写的程序,而这个模拟平台和板子存在差异。主要表现在各种寄存器的物理地址上,所以我们需要根据板子的实际情况,更改代码中各个寄存器的地址。这个可以参考RISC RV Dock的用户手册,或者参考已有代码中的写法。

在这个实验中,仅涉及到UART寄存器,我们需要将字符串输入到UART寄存器,然后通过USB转TTL转接线在屏幕上显示这些内容。

关于寄存器的地址,手册上给出的信息如下:

我们需要用到其中的UART0寄存器,所以我们仅需将程序中UART地址代码 #define UART0 0x10000000L 改为 #define UART0 0x02500000L 即可,然后执行 make run 生成 .bin 文件。(bin文件中存放纯指令,而不像elf文件那样有额外的信息)

接下来的问题就是如何将.bin 程序烧录到sd卡中。虽然官方提供了烧录程序,能正常烧录官方提供的镜像文件 (参考Lichee RV 烧录系统) ,但却不能烧录我生成的bin文件(即使将它转化为了img文件)。我暂时也没有找到相关的方式,所以暂时先在这里做个记录,后面学到后再填坑。

不过我了解到了另一种方式,直接在DDR内存中跑编写的.bin文件,通过FEL程序将bin文件烧录到DDR上(可惜似乎不能用FEL程序烧录sd卡),相关教程见 d1下载xboot的过程,这个方式等我的USB转TTL线到达后再进行实践。

相关推荐
编程墨客11 小时前
STM32F103C8T6单片机内部执行原理及启动流程详解
stm32·单片机·嵌入式硬件
GateWorld11 小时前
RISC-V:开源芯浪潮下的技术突围与职业新赛道 (二) RISC-V架构深度解剖(上)
架构·risc-v·指令集精简·寄存器设计·特权架构·模块化扩展
qq_4112624213 小时前
整体无需占用任何硬件 UART,即可新增一条全双工软串口
单片机·嵌入式硬件
XINVRY-FPGA15 小时前
XCZU47DR-2FFVG1517I Xilinx FPGA AMD ZynqUltraScale+ RFSoC
人工智能·嵌入式硬件·fpga开发·信息与通信·信号处理·射频工程·fpga
Cyrus_柯15 小时前
单片机基础(STM32-DAY2(GPIO))
单片机·嵌入式硬件
努力的小帅16 小时前
STM32单片机_3
stm32·单片机·嵌入式硬件·学习·stm32c8t6
逼子格16 小时前
开关电源和线性电源Multisim电路仿真实验汇总——硬件工程师笔记
嵌入式硬件·硬件工程·硬件工程师·开关电源·multisim电路仿真·稳压电源·线性电源
SKYDROID云卓小助手17 小时前
无人设备遥控器之无线电频率篇
服务器·网络·单片机·嵌入式硬件·算法
逼子格19 小时前
振荡电路Multisim电路仿真实验汇总——硬件工程师笔记
笔记·嵌入式硬件·硬件工程·硬件工程师·硬件工程师真题·multisim电路仿真·震荡电流
Do vis82419 小时前
STM32第十九天 ESP8266-01S和电脑实现串口通信(2)
stm32·单片机·嵌入式硬件