startup_ch32v00x.S启动文件分析(上)

本文分析了CH32V003芯片的启动文件startup_ch32v00x.S,详细解读了初始化部分、复位处理和中断向量设置,涉及RISC-V指令集的选项使用,如.global、.align及汇编代码中的跳转和寄存器设置。
摘要由CSDN通过智能技术生成

startup_ch32v00x.S启动文件分析(上)

引言

CH32系列MCU是由南京沁恒(WCH)公司推出的一系列处理器芯片。引自官网:

CH32V、CH32X、CH32L系列MCU采用自研的青稞RISC-V内核,基于蓬勃发展的RISC-V开源指令集架构,针对低功耗和高速响应等应用优化扩展,免费配套IDE等开发工具软件,免除第三方内核技术的授权费和提成费,通过内置和组合USB、PD、低功耗蓝牙、以太网等专业接口外设,构建了既有全球未来生态又能自主可控、且极具长期竞争力的MCU产品线。

产品页 - 青稞RISC-V通用系列

本文通过对 CH32V003 芯片所使用的启动文件 startup_ch32v00x.S 进行分析,梳理RISC-V芯片的启动过程。

文件内容预览

点击跳转查看

逐句分析

Part1 - Init

从代码第一行看起。

.section .init, “ax”, @progbits
  • .section 标明本句为对段的定义。
  • .init是该段的名字。
  • "ax"标识段的权限,a代表运行时载入内存,x代表可执行。
  • @progbits标识了段的类型,表示“Section contains either initialized data and instructions or instructions only."。

.section完整语法文档

.globl _start

定义_start位置全局可见,用于作程序的起始地址。

.align 2

定义下一条指令/数据对齐方式。可确保下一条指令的地址为“2的x次方”的倍数。此处,2的2次方为4,因此下一条指令的地址将顺推至4的倍数。

注意与.balign伪指令的区分,其用于将下一条指令地址顺推至x的倍数。即.align 2等效于.balign 4。

_start:

程序起始位置。

.option norvc;

rvc、norvc是RISC-V架构特有的选项ÿ

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值