Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
内核栈
ARMv8
SMP
armv8 下start汇编中sp堆栈指针为什么设置为_start入口函数地址
发布于 2021-06-17 14:18:30 浏览:1487
订阅该版
如以下汇编代码,不明白为什么堆栈指针sp要设置为_start函数地址。 ``` ldr x1, =_start ··· mov sp, x1 // in EL1. Set sp to _start `.section ".text.entrypoint" .set EL1_stack, __el1_stack .global _start // This symbol is set to 0x80000 in ld script. That is the address that raspi3's firmware // loads 'kernel8.img' file in. _start: // read cpu id, stop slave cores mrs x1, mpidr_el1 // MPIDR_EL1: Multi-Processor Affinity Register and x1, x1, #3 cbz x1, .L__cpu_0 // .L prefix is the local label in ELF // cpu id > 0, stop // cpu id == 0 will also goto here after returned from entry() if possible .L__current_cpu_idle: wfe b .L__current_cpu_idle .L__cpu_0: // cpu id == 0 // set stack before our code /* Define stack pointer for current exception level */ // ldr x2, =EL1_stack // mov sp, x2 ldr x1, =_start // set up EL1 mrs x0, CurrentEL // CurrentEL Register. bit 2, 3. Others reserved and x0, x0, #12 // clear reserved bits // running at EL3? cmp x0, #12 // 1100b. So, EL3 bne .L__not_in_el3 // 11? !EL3 -> 5: // should never be executed, just for completeness. (EL3) mov x2, #0x5b1 msr scr_el3, x2 // SCR_ELn Secure Configuration Register mov x2, #0x3c9 msr spsr_el3, x2 // SPSR_ELn. Saved Program Status Register. 1111001001 adr x2, .L__not_in_el3 msr elr_el3, x2 eret // Exception Return: from EL3, continue from .L__not_in_el3 // running at EL2 or EL1 .L__not_in_el3: cmp x0, #4 // 0x04 0100 EL1 beq .L__in_el1 // EL1 -> 5: // in EL2 msr sp_el1, x1 // Set sp of EL1 to _start // enable CNTP for EL1 mrs x0, cnthctl_el2 // Counter-timer Hypervisor Control register orr x0, x0, #3 msr cnthctl_el2, x0 msr cntvoff_el2, xzr // enable AArch64 in EL1 mov x0, #(1 << 31) // AArch64 orr x0, x0, #(1 << 1) // SWIO hardwired on Pi3 msr hcr_el2, x0 mrs x0, hcr_el2 // change execution level to EL1 mov x2, #0x3c4 msr spsr_el2, x2 // 1111000100 adr x2, .L__in_el1 msr elr_el2, x2 eret // exception return. from EL2. continue from .L__in_el1 .L__in_el1: mov sp, x1 // in EL1. Set sp to _start // Set CPACR_EL1 (Architecture Feature Access Control Register) to avoid trap from SIMD or float point instruction mov x1, #0x00300000 // Don't trap any SIMD/FP instructions in both EL0 and EL1 msr cpacr_el1, x1 mrs x1, sctlr_el1 orr x1, x1, #(1 << 12) bic x1, x1, #(3 << 3) bic x1, x1, #(1 << 1) msr sctlr_el1, x1 // clear bss ldr x1, =__bss_start ldr w2, =__bss_size .L__clean_bss_loop: cbz w2, .L__jump_to_entry str xzr, [x1], #8 sub w2, w2, #1 cbnz w2, .L__clean_bss_loop // jump to C code, should not return .L__jump_to_entry: bl entry // for failsafe, halt this core too b .L__current_cpu_idle` ```
查看更多
小鳄鱼
2021-06-17
rt-thread脑残粉
* 我理解的是,在rtt启动之前有一段初始化硬件并跳转的代码,那部分的地址空间正好位于_start之前。因为arm的sp的向下增长,所以直接把_start的值赋值给了el1下的sp,这样就可以把那部分空间利用起来。 * 你反汇编看,_start应该是整个代码段的起始部分,所以这样设置问题不大。
2
个回答
默认排序
按发布时间排序
zhkag
2021-06-17
这家伙很懒,什么也没写!
> 不明白为什么堆栈指针sp要设置为_start函数地址 _start就是入口函数,相当于C语言中的main函数
撰写答案
登录
注册新账号
关注者
0
被浏览
1.5k
关于作者
xhwang
这家伙很懒,什么也没写!
提问
11
回答
4
被采纳
0
关注TA
发私信
相关问题
1
aarch64有计划支持SMP吗
2
SMP重新定义中断处理函数的问题
3
rt_tick_increase()在SMP时只增加当前核的TICK?
4
RISCV smp系统调度异常问题请教
5
qemu-vexpress-a9 在SMP情况下GDB无法调试
6
为什么在k210上使用多核smp总是会卡死
7
RT-Thread SMP核弹碰撞树莓派
8
请教多核SMP功能验证
9
明年开始玩SMP多核处理器
10
建议RT-Thread支持SMP
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
【24嵌入式设计大赛】基于RT-Thread星火一号的智慧家居系统
2
RT-Thread EtherKit开源以太网硬件正式发布
3
如何在master上的BSP中添加配置yml文件
4
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
5
RT-Thread 发布 EtherKit开源以太网硬件!
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
MicroPython
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
16
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
6
个答案
2
次被采纳
用户名由3_15位
13
个答案
1
次被采纳
本月文章贡献
程序员阿伟
9
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
RTT_逍遥
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部