小核引导RTOS

参考

  • 参考1. How does FSBL load the FreeRTOS on the small core and execute it?
  • 参考2. Duo now supports big and little cores?Come and play!Milk-V Duo, start!

日志

FSBL Jb2829:g362832ac6-dirty:2024-04-02T13:31:11+00:00				# 版本信息
st_on_reason=40f0003
st_off_reason=800e0003
P2S/0x1000/0xc00a400.
SD/0x9400/0x1000/0x1000/0.P2E.
DPS/0xa400/0x2000.
SD/0xa400/0x2000/0x2000/0.DPE.
DDR init.							# DDR 初始化
ddr_param[0]=0x78075562.
pkg_type=1
D2_4_1
DDR3-4G-BGA
Data rate=1866.
DDR BIST PASS
PLLS/OD.
C2S/0xc400/0x9fe00000/0x3600.2RET.:00/0x3600/0x3600/0.RSC.[M1S./208x2f8a0000]/P0rxe8 0s0y0s0t0e0m0 /i0nxi1tb 0d0o0n.eRT: [1.289126]CVIRTOS Build Date:Apr  2 2024  (Time :13:31:11) 		# FreeRTOS 启动;
RT: [1.295040]Post system init done
RT: [1.298355]create cvi task
RT: [1.301172][cvi_spinlock_init] succeess
RT: [1.305076]prvCmdQuRunTask run
SD/0xfa00/0x1b000/0x1b000/0.ME.
L2/0x2aa00.
SD/0x2aa00/0x200/0x200/0.L2/0x414d3342/0xcafedbb7/0x80200000/0x37400/0x37400
COMP/1.
SD/0x2aa00/0x37400/0x37400/0.DCP/0x80200020/0x1000000/0x81900020/0x37400/1.
DCP/0x73c7a/0.
Loader_2nd loaded.					# 第二阶段:Opensbi;
Switch RTC mode to xtal32k
Jump to monitor at 0x80000000.
OPENSBI: next_addr=0x80200020 arg1=0x80080000
OpenSBI v0.9

可知:

  1. FSBL Jb2829...,FSBL启动,打印版本信息;
  2. DDR初始化完成后,紧跟RTOS任务初始化打印,中间无引导小核的工作打印

所以可以先对FSBL有个大致认知,再确认RTOS启动过程。

编译框架

# fsbl/Makefile.DEFAULT_GOAL := all	# 如果没有指定.DEFAULT_GOAL,make会执行第一个在Makefile中定义的目标。
MAKEOVERRIDES =			# 不传递任何父make的变量给子make,保持子make实例的独立性ARCH ?=					# make 传参可带ARCH=xxx 指定架构;ifneq ($(origin CROSS_COMPILE),command line)ifeq ($(ARCH),riscv)	# 如果不是命令行 make ARCH=xxx 形式,指明由RiscV核心来完成引导启动工作CROSS_COMPILE := ${CROSS_COMPILE_GLIBC_RISCV64}BOOT_CPU ?= riscv
...
ifeq (${CHIP_ARCH},)		# 必带参数:CHIP_ARCH$(error CHIP_ARCH is undefined)
...
ifeq (${CROSS_COMPILE},)	# 必带参数:CROSS_COMPILE$(error CROSS_COMPILE is undefined)
...
HOSTCC		:=	gcc
export HOSTCCCC			:=	${CROSS_COMPILE}gcc
...							# 工具链配置
include ${MAKE_HELPERS_DIRECTORY}build_macros.mk	# Makefile 宏定义,如:assert_boolean、add_define_val
include ${MAKE_HELPERS_DIRECTORY}plat_helpers.mk	# Make 辅助实现
...
include ${PLAT_MAKEFILE_FULL}	# 在plat_makefiles.mk中定义,指向:plat/${CHIP_ARCH}/platform.mk文件,
# fsbl/plat/sg200x/platform.mk,工作:
# - 定义哪些源码文件加入编辑链接;
# - 定义链接脚本文件;all: fip bl2 blmacros		# 第一目标all,依赖于fip、bl2、blmaacros
...
include ${MAKE_HELPERS_DIRECTORY}fip.mk	# 目标:fip
$(eval $(call MAKE_BL,2))				# 目标:bl2
$(eval $(call MAKE_BL,macros))			# 目标:blmacros

目标fip

目标fip有如下涉及RTOS的内容

# fsbl/make_helpers/fip.mk
...
fip: fip-all
...
fip-all: fip-dep$(print_target)${Q}echo "  [GEN] fip.bin"${Q}. ${BUILD_PLAT}/blmacros.env && \${FIPTOOL} -v genfip \'${BUILD_PLAT}/fip.bin' \--MONITOR_RUNADDR="$${MONITOR_RUNADDR}" \--BLCP_2ND_RUNADDR="$${BLCP_2ND_RUNADDR}" \...--BL2='${BUILD_PLAT}/bl2.bin' \...--BLCP_2ND='${BLCP_2ND_PATH}' \--MONITOR='${MONITOR_PATH}' \--LOADER_2ND='${LOADER_2ND_PATH}' \		...

由实际编译过程打印有:

  • --BLCP_2ND='${SDK_TOP}/freertos/cvitek/install/bin/cvirtos.bin' \,RTOS定义为BLCP_2ND;

    其运行地址BLCP_2ND在源头在板型目录下的memmap.py文件中定义,如文件:build/boards/cv181x/cv1813h_milkv_duos_sd/memmap.py

    class MemoryMap:...DRAM_BASE = 0x80000000DRAM_SIZE = 512 * SIZE_1M# ==============# C906L FreeRTOS# ==============FREERTOS_SIZE = 2 * SIZE_1M# FreeRTOS is at the end of DRAMFREERTOS_ADDR = DRAM_BASE + DRAM_SIZE - FREERTOS_SIZEFSBL_C906L_START_ADDR = FREERTOS_ADDR
    

    可知:

    • Duos 内存起始地位:0x80000000;大小:512MB;
    • FreeRTOS镜像运行地址(非加载地址):0x9fe00000(内存倒数2MB位置);大小:2MB;

    转化路径:mempa.py – build/scripts/mmap.mk --> build/output/${PROJECT_FULLNAME}/cvi_board_memmap.h。

    关联方式:软链如上cvi_board_memmap.h文件链接到:fsbl/build/cvi_board_memmap.h;

  • --MONITOR='${SDK_TOP}/opensbi/build/platform/generic/firmware/fw_dynamic.bin' \,Opensbi定义为MONITOR;

    借鉴ATF,MilkV将Risc-V下的Opensbi等同于ATF中的BL31,也称为Monitor;

        # ==============================# OpenSBI | arm-trusted-firmware# ==============================# Monitor is at the begining of DRAMMONITOR_ADDR = DRAM_BASEATF_SIZE = 512 * SIZE_1KOPENSBI_SIZE = 512 * SIZE_1KOPENSBI_FDT_ADDR = MONITOR_ADDR + OPENSBI_SIZE
    

    可知:

    • Opensbi镜像运行地址:0x80000000;大小:512KB;
  • --LOADER_2ND='${SDK_TOP}/u-boot-2021.10/build/cv1813h_milkv_duos_sd/u-boot-raw.bin' \,U-boot定义为LOADER_2ND;

    借鉴ATF,MilkV将Risc-V下的U-boot等同于ATF中的BL32;

        # ===================# FSBL and u-boot-2021# ===================CVI_UPDATE_HEADER_SIZE = SIZE_1KUIMAG_SIZE = 16 * SIZE_1M# kernel image loading bufferUIMAG_ADDR = DRAM_BASE + 24 * SIZE_1M...# u-boot's run address and entry pointCONFIG_SYS_TEXT_BASE = DRAM_BASE + 2 * SIZE_1M
    

    可知:

    • U-boot运行地址:0x8020000(内存偏移2MB);大小:2MB;

启动流程

​ 由上一章节可知追寻着BLCP_2ND的引用位置即可知晓RTOS如何加载启动。
----待继续补充 240403

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/791213.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

typescript的工作流

先coding code.ts代码,由tsc编译code.ts生成code.js格式 npm install —save-dev lite-server 是用来安装轻量级的服务器,只是用来开发的一个服务器,真正到生产环境中时可能会使用类似于Apache的server或者汤姆猫一类的服务器,安…

编程生活day6--回文子串、蛇形填充数组、笨小猴、单词排序

回文子串 题目描述 给定一个字符串,输出所有长度至少为2的回文子串。 回文子串即从左往右输出和从右往左输出结果是一样的字符串,比如:abba,cccdeedccc都是回文字符串。 输入 一个字符串,由字母或数字组成。长度5…

spring-boot集成websocket

引入Maven依赖包 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId><version>跟随spingboot版本</version> </dependency>后端代码 /*** 开启WebSocket支持*…

【嵌入式开发 Linux 常用命令系列 8 -- shell 命令 basename 介绍】

请阅读【嵌入式开发学习必备专栏 】 文章目录 shell 命令 basenamedf 命令 shell 命令 basename 在 shell 脚本中&#xff0c;可以使用 basename 命令来获取文件的基本名称&#xff08;不带路径的部分&#xff09;。以下是如何将文件名赋值给变量的示例&#xff1a; file_pat…

STM32CubeMX配置步骤详解四 —— 基础配置(1)

接前一篇文章&#xff1a;STM32CubeMX配置步骤详解三 —— 安装 本文内容主要参考&#xff1a; STM32CUBEMX配置教程&#xff08;一&#xff09;基础配置-CSDN博客 特此致谢&#xff01; 三、STM32CubeMX基础配置 前边几回讲解了STM32CubeMX的下载及安装。当前STM32CubeMX已…

【leetcode面试经典150题】6.轮转数组(C++)

【leetcode面试经典150题】专栏系列将为准备暑期实习生以及秋招的同学们提高在面试时的经典面试算法题的思路和想法。本专栏将以一题多解和精简算法思路为主&#xff0c;题解使用C语言。&#xff08;若有使用其他语言的同学也可了解题解思路&#xff0c;本质上语法内容一致&…

LeetCode575——分糖果

题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 这道题比较简单&#xff0c;但我还是花费了将近四个小时的时间去解答&#xff0c;AC的那一刻&#xff0c;终于全身舒畅&#xff0c;这道题的思路就是先求出糖果的种数&#xff0c;然后我们从题中可以得出&#x…

MySQL数据库 数据库基本操作(二):表的增删查改(上)

1. CRUD CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写,就是数据库基本操作中针对表的一系列操作. 2. 新增(create) -->insert 语法: insert into 表名 [列名1,列名2…] values (val1,val2…) [注意] 列名可以没有,如果没有列名…

【Redis】Redis的使用

登录redis [roottest2 ~]# redis-cli 127.0.0.1:6379> 或[roottest2 ~]# redis-cli -h 192.168.67.12 -p 6379 192.168.67.12:6379> redis-benchmark 测试工具 redis-benchmark 是官方自带的Redis性能测试工具&#xff0c;可以有效的测试Redis服务的性能 基本的测试语…

C# 实现子进程跟随主进程关闭

文章目录 前言一、如何实现&#xff1f;1、创建作业对象&#xff08;1&#xff09;、创建对象&#xff08;2&#xff09;、设置销毁作业时&#xff0c;关闭拥有的进程 2、子进程加入作业对象3、销毁作业对象&#xff08;1&#xff09;、手动销毁&#xff08;2&#xff09;、所在…

从零起步:开启你的IT职业之旅

简介&#xff1a; 信息技术&#xff08;IT&#xff09;行业以其快速发展和广阔的就业前景吸引着全球众多职场新人。但对于零基础的求职者而言&#xff0c;挺进这一行业似乎是条充满挑战的道路。进入IT行业可能看起来是一项艰巨的挑战&#xff0c;尤其是对于那些没有任何相关经…

面试算法-134-最长递增子序列

题目 给你一个整数数组 nums &#xff0c;找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列&#xff0c;删除&#xff08;或不删除&#xff09;数组中的元素而不改变其余元素的顺序。例如&#xff0c;[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的 子序列 。 示例…

redis乱码\xac\xed\x00\x05t\x00H解决

发现数据库乱码&#xff1a; 这数据库是来自rdids队列list实现的一个简单队列&#xff0c;停止使用该list的服务&#xff0c;查看里面的值&#xff0c;发现 乱码\xac\xed\x00\x05t\x00H&#xff0c;如下图&#xff1a; 很明发送数据端的问题&#xff0c;检查代码&#xff1a; …

20240403在ubuntu20.04下解压缩gz压缩包

20240403在ubuntu20.04下解压缩gz压缩包.txt 2024/4/3 15:17 缘起&#xff1a;使用友善之臂FriendlyElec的NanoPi NEO Core开发板 https://wiki.friendlyelec.com/wiki/index.php/NanoPi_NEO/zh#.E8.BF.90.E8.A1.8CFriendlyCore NanoPi NEO/zh http://wiki.friendlyelec.com/w…

每日一题 --- 滑动窗口最大值[力扣][Go]

滑动窗口最大值 题目&#xff1a;239. 滑动窗口最大值 给你一个整数数组 nums&#xff0c;有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回 滑动窗口中的最大值 。 示例 1&#xff1…

人工智能会拥有反思能力吗?

一、背景 人工智能是否能拥有真正的反思能力&#xff0c;目前仍在探索和发展之中。虽然现有的AI系统可以在一定程度上进行自我学习、自我调整和优化&#xff0c;但是它们的“反思”还远未达到人类意义上的深度和全面性。 传统的人工智能系统依赖于预设的算法和模型&#xff0c…

微信小程序怎么制作?制作一个微信小程序需要多少钱?

随着移动互联网的快速发展&#xff0c;微信小程序已成为连接用户与服务的重要桥梁。它以其便捷性和易用性&#xff0c;为各类企业和个人提供了一个全新的展示和交易平台。那么&#xff0c;如何制作一个微信小程序&#xff1f;又需要投入多少资金呢&#xff1f;本文将为您提供全…

C++实现二叉搜索树的增删查改(非递归玩法)

文章目录 一、二叉搜索树的概念结构和时间复杂度二、二叉搜索树的插入三、二叉搜索树的查找四、二叉搜索树的删除&#xff08;最麻烦&#xff0c;情况最多&#xff0c;一一分析&#xff09;3.1首先我们按照一般情况下写&#xff0c;不考虑特殊情况下4.1.1左为空的情况&#xff…

【HTML】简单制作一个动态3D正方体

目录 前言 开始 HTML部分 JS部分 CSS部分 效果图 总结 前言 无需多言&#xff0c;本文将详细介绍一段代码&#xff0c;具体内容如下&#xff1a; 开始 首先新建文件夹&#xff0c;创建两个文本文档&#xff0c;其中HTML的文件名改为[index.html]&#xff0c;JS的文件名改…

数据仓库——聚集

数据仓库基础笔记思维导图已经整理完毕&#xff0c;完整连接为&#xff1a; 数据仓库基础知识笔记思维导图 聚集 在对性能不断探索的过程中&#xff0c;聚集是最强大最、有效的数据处理工具。通过仔细规划和集成&#xff0c;聚集将队数据仓库性能产生巨大影响。无需针对特定的…