如何自己生成fip.bin在Milkv-duo上跑freertos

2023-11-20 13:15
文章标签 生成 bin freertos duo milkv fip

本文主要是介绍如何自己生成fip.bin在Milkv-duo上跑freertos,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

(1)PLCT实验室实习生长期招聘:招聘信息链接
(2)本来是要跑RT-Thread的,搞了很久,一直没成功。哭死,后面mentor通电话,让我先跑一下freertos试试。有可能是因为RT-Thread Smart版本即使通过scons --menuconfig修改成标准版,也会在opensbi阶段会调用一些东西,而当前使用的duo-toolbox仓库,对这部分进行的精简,所以导致一直在sbi_call函数中卡死。
(3)不管问题到底是什么,先记录一下如何使用duo-toolbox仓库跑起freertos吧。一步一步来,哎,只能说,能力有限,还要准备期中考试(哭死)。

前期测试工作

接线说明

在这里插入图片描述
在这里插入图片描述

测试duo-toolbox仓库是否正常

(1)首先,我们先拉取duo-toolbox仓库,先拿通用的duo-toolbox仓库代码进行测试一下。
(2)需要注意,export是临时添加环境变量的,如果将终端关闭,下一次重新打开终端,需要再次添加环境变量。

git clone https://github.com/GeassCore/duo-toolbox.git
cd duo-toolbox
./init.sh
cd fip
export PATH=`pwd`/../host-tools/gcc/riscv64-linux-musl-x86_64/bin:$PATH
export PATH=`pwd`/../host-tools/gcc/riscv64-elf-x86_64/bin:$PATH
make fsbl-build

(3)将生成的fip/build路径下的fip.bin文件利用读卡器烧录进SD卡中。
注意:如果是已经上手了Milkv-duo同学可能会存在疑惑,怎么会只需要一个fip.bin文件呢?原因很简单,Milkv-duo是双核处理器,小核跑的时候,是使用的fip.bin文件中的代码,当跑大核的时候,是利用boot.sd文件中的代码。因为当前的duo-toolbox仓库是默认只跑小核心,所以无需boot.sd文件。而img文件就是fip.bin文件和boot.sd文件的打包。

在这里插入图片描述

(4)使用串口软件连接开发板,配置信息:波特率115200,数据位8,无校验位,1停止位,无流控。(注意,有些串口工具,例如MobaXterm就只需要配置一个波特率)
(5)测试结果如下,说明仓库配置完成。

在这里插入图片描述

测试duo-buildroot-sdk仓库跑freertos

(1)在comm_main.c中利用freertosxTaskCreate()函数创建一个my_task_test()的任务函数。

git clone https://github.com/milkv-duo/duo-buildroot-sdk.git
cd duo-buildroot-sdk
vim freertos/cvitek/task/comm/src/riscv64/comm_main.c
void my_task_test()
{int index = 0;for (;;) {printf("test the RTOS: %d\r\n", index);vTaskDelay(100);index++;}
}
void main_cvirtos(void)
{printf("create cvi task\n");xTaskCreate(my_task_test, "my_task", 1024 * 8, NULL, 1, NULL);vTaskStartScheduler();/* Start the tasks and timer running. *//* If all is well, the scheduler will now be running, and the followingline will never be reached.  If the following line does execute, thenthere was either insufficient FreeRTOS heap memory available for the idleand/or timer tasks to be created, or vTaskStartScheduler() was called fromUser mode.  See the memory management section on the FreeRTOS web site formore details on the FreeRTOS heap http://www.freertos.org/a00111.html.  Themode from which main() is called is set in the C start up code and must bea privileged mode (not user mode). */printf("cvi task end\n");for (;;);
}

(2)进入FreeRTOSConfig.h文件,关闭configUSE_TICK_HOOK这个宏。

vim freertos/cvitek/kernel/include/riscv64/FreeRTOSConfig.h
#define configUSE_TICK_HOOK             0

(3)编译文件,最终生成的镜像文件在duo-buildroot-sdk/out这个路径下。

./build_milkv.sh

在这里插入图片描述

(4)烧录镜像,利用Win32DiskImager软件进行烧录镜像

在这里插入图片描述

(5)上机测试结果如下,需要注意,当前仓库的小核freertos和大核Linux都是公用的串口0,那么就会出现抢占情况。出现下图,表示测试成功。

在这里插入图片描述

自己生成fip.bin文件进行测试

修改代码

修改串口驱动代码

(1)进行完上述测试工作之后,我们开始尝试自己生成一个fip.bin文件进行上机测试。这里进入duo-toolbox仓库路径。

在这里插入图片描述

(2)进入drv_uart.c文件,修改dw8250_uart_init()函数和dw8250_uart_putc()函数中的UART4_BASE变成UART0_BASE

vim debugloader/duoRVOS/drv_uart.c

在这里插入图片描述
在这里插入图片描述

修改kernel.c代码

(1)进入kernel.c文件,将start_kernel()函数调整如下。

vim debugloader/duoRVOS/kernel.c
void start_kernel(void)
{uint32_t sw = 0;sys_clock_init();board_pinmux_config();sdelay(1000000);dw8250_uart_init();dw8250_uart_putc('h');dw8250_uart_putc('e');dw8250_uart_putc('h');dw8250_uart_putc('e');
//    sys_led_ctrl(1);
//    sys_jtag_init();sdelay(1000000);/*while (1){sdelay(1000000);
//        sw =!sw;
//        sys_led_ctrl(sw);dw8250_uart_putc('a');}*/void (*entry)() = (void *)0x80210000;sdelay(1000000);entry();
}

修改Makefile和fip.mk

(1)进入Makefile文件,将LOADER_2ND_PATH=$ {TOP_DIR}/u-boot/build/u-boot-raw.bin修改为LOADER_2ND_PATH=$ {TOP_DIR}/os.bin

vim fip/Makefile

在这里插入图片描述

(2)修改fip.mkMONITOR_PATH =../opensbi/build/platform/generic/firmware/fw_dynamic.binMONITOR_PATH = ../sbi.bin

vim fip/fsbl/make_helpers/fip.mk

在这里插入图片描述

合成fip.bin

生成os.bin

(1)进入duo-buildroot-sdk仓库的freertos/cvitek/install/bin/目录下。将cvirtos.bin复制一份,改名为rtos.bin。再将rtos.bin文件复制到duo-toolbox仓库的debugloader/duoRVOS路径下。

cd freertos/cvitek/install/bin/
cp cvirtos.bin rtos.bin
mv rtos.bin ${duo-toolbox_DIR}/debugloader/duoRVOS

在这里插入图片描述

(2)进入duo-toolbox仓库的debugloader/duoRVOS/路径中,执行make指令即可。

cd ${duo-toolbox_DIR}/debugloader/duoRVOS/
make

生成sbi.bin

(1)进入duo-toolbox仓库的debugloader/sbi/路径中,执行./build.sh编译脚本,最后在fw_bin文件夹中生成sbi.bin

cd ${duo-toolbox_DIR}/debugloader/sbi/
./build.sh

在这里插入图片描述

合成fip.bin

(1)进入duo-toolbox仓库的fip文件夹中。将上述生成的os.binsbi.bin复制当fip文件夹中。执行编译脚本,最终在build文件夹中生成fip.bin文件。

cd ${duo-toolbox_DIR}/fip/
mv ../debugloader/sbi/fw_bin/sbi.bin .
mv ../debugloader/duoRVOS/os.bin .
make fsbl-build

在这里插入图片描述

测试

(1)最终生成的文件是91KB

在这里插入图片描述

(2)上机测试。
<1>如果测试过程中,发现没有打印hehe,表示没有进入${duo-toolbox_DIR}/debugloader/duoRVOS/kernel.c 中的start_kernel()函数,或者是串口驱动初始化有问题。
<2>如果打印了hehe,但是发现没有create cvi task的打印,表面成功进入了start_kernel()函数,但是没有成功引导进入freertos,那么尝试重新编译测试duo-toolbox仓库,测试完成之后,重新将freertos/cvitek/install/bin/目录下 cvirtos.bin修改名字为rtos.bin,然后替换${duo-toolbox_DIR}/debugloader/duoRVOS/中的rtos.bin重新编译。

在这里插入图片描述

参考文章

(1)知乎(燕十三):milk-v duo 编译流程二之小核 FreeRTOS 编译
(2)微信公众号(电气电子小倒腾):简单尝试Milk-V Duo的小核运行FreeRTOS
(3)Github的duo-toolbox仓库readme文件
(4)C站(风正豪):Milk-V Duo快速上手
(5)斑梨电子Milk-V Duo镜像烧写教程

感谢人员

(1)感谢PLCT的王俊强老师的指导。
(2)感谢PLCT的实习生许东代韵涛两位大佬的帮助。

这篇关于如何自己生成fip.bin在Milkv-duo上跑freertos的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/394864

相关文章

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

poj 3723 kruscal,反边取最大生成树。

题意: 需要征募女兵N人,男兵M人。 每征募一个人需要花费10000美元,但是如果已经招募的人中有一些关系亲密的人,那么可以少花一些钱。 给出若干的男女之间的1~9999之间的亲密关系度,征募某个人的费用是10000 - (已经征募的人中和自己的亲密度的最大值)。 要求通过适当的招募顺序使得征募所有人的费用最小。 解析: 先设想无向图,在征募某个人a时,如果使用了a和b之间的关系

Thymeleaf:生成静态文件及异常处理java.lang.NoClassDefFoundError: ognl/PropertyAccessor

我们需要引入包: <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>sp

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系