Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
SMP
SMP模式下中断何时被使能?
发布于 2022-07-28 20:55:40 浏览:670
订阅该版
在SMP模式下,rtthread_startup开头关掉了中断,进入main之后读取CPSR发现中断是是能的,看起来rt_hw_context_switch_to中打开的?具体是在哪里呢?
查看更多
whj467467222
认证专家
2022-07-28
开源,分享,交流,共同进步
先说结论:在发生第一次线程切换完成的同时,将中断打开了。 PSR(program status register)如下图所示: ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20220728/aa739d432fd8b432256edf2dcfe8a618.png) I 是 IRQ 的缩写,表示是否禁用(屏蔽)IRQ中断,为1禁止. CPSR 表示当前状态,SPSR 表示已经保存的状态。 在创建每一个线程的时候,会有一个伪造栈的过程,见以下代码(有删减) ``` rt_uint8_t *rt_hw_stack_init(void *tentry, void *parameter, rt_uint8_t *stack_addr, void *texit) { rt_uint32_t *stk; stack_addr += sizeof(rt_uint32_t); stack_addr = (rt_uint8_t *)RT_ALIGN_DOWN((rt_uint32_t)stack_addr, 8); stk = (rt_uint32_t *)stack_addr; *(--stk) = (rt_uint32_t)tentry; /* entry point */ *(--stk) = (rt_uint32_t)texit; /* lr */ *(--stk) = 0xdeadbeef; /* r12 */ *(--stk) = 0xdeadbeef; /* r11 */ *(--stk) = 0xdeadbeef; /* r10 */ *(--stk) = 0xdeadbeef; /* r9 */ *(--stk) = 0xdeadbeef; /* r8 */ *(--stk) = 0xdeadbeef; /* r7 */ *(--stk) = 0xdeadbeef; /* r6 */ *(--stk) = 0xdeadbeef; /* r5 */ *(--stk) = 0xdeadbeef; /* r4 */ *(--stk) = 0xdeadbeef; /* r3 */ *(--stk) = 0xdeadbeef; /* r2 */ *(--stk) = 0xdeadbeef; /* r1 */ *(--stk) = (rt_uint32_t)parameter; /* r0 : argument */ /* cpsr */ if ((rt_uint32_t)tentry & 0x01) *(--stk) = SVCMODE | 0x20; /* thumb mode */ else *(--stk) = SVCMODE; /* arm mode */ /* return task's current stack address */ return (rt_uint8_t *)stk; } ``` 可以看到伪造栈现场的时候将 CPSR 这里仅仅设置了模式为 SVC,某些情况可能设置为 thumb 模式,但是可以确定的是 IRQ 的标志位 I 肯定为 0 也就说如果这个值被加载到系统 CPSR 寄存器当中,那么 IRQ 中断使能就会被打开。 在第一次切换线程的时候会进行依次调用一下函数: ``` rt_hw_context_switch_to: ldr sp, [r0] @ get new task stack pointer #ifdef RT_USING_SMP mov r0, r1 bl rt_cpus_lock_status_restore #endif /*RT_USING_SMP*/ b rt_hw_context_switch_exit .global rt_hw_context_switch_exit rt_hw_context_switch_exit: ldmfd sp!, {r1} msr spsr_cxsf, r1 /* original mode */ ldmfd sp!, {r0-r12,lr,pc}^ /* irq return */ ``` 可以看到第一次切换线程使用的函数是 `switch_to` 这里首先获取到了栈顶的位置,然后调用 `switch_exit` 这里直接获取到了栈顶保存的第一个数据,根据之前伪造的栈线程可知,这里获取到的第一次数据,就是伪造栈精心设置的 CPSR, 这个 CPSR 的值保存在了 R1 当中,`msr spsr_cxsf, r1` 这一条指令就将 R1 里面保存的值,写入了 SPSR,最后一句 `ldmfd sp!, {r0-r12,lr,pc}^` 这个时候就将伪造栈的所有寄存器从内存写入到真实的寄存器当中,这个时候 也就进入了第一个线程,这个打开中断的状态寄存器也就加载到了 CPSR,这个线程也就是你的 `main` 这个时候中断是不是就打开了呢?
1
个回答
默认排序
按发布时间排序
撰写答案
登录
注册新账号
关注者
0
被浏览
670
关于作者
kyliuxing
这家伙很懒,什么也没写!
提问
9
回答
0
被采纳
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
【RT-Thread】【ci】【scons】将ci.attachconfig.yml和scons结合使用
2
Rt-thread中OTA下载后,bootloader不搬程序
3
ulog 日志 LOG_HEX 输出时间改为本地日期时间
4
在RT-Thread Studio中构建前执行python命令
5
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
热门标签
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
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
cubemx
PWM
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
出出啊
1518
个答案
343
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
5
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部