当前位置: 首页 > news >正文

freertos任务调度关键函数理解


void xPortPendSVHandler( void )
{
/* This is a naked function. */
__asm volatile
(
//保存当前任务上下文
"    mrs r0, psp                            \n"  //读取进程栈指针(PSP)到r0
"    isb                                    \n"  //指令同步屏障,确保前面的指令执行完毕
"                                        \n"
"    ldr    r3, pxCurrentTCBConst            \n"  /* Get the location of the current TCB. */
"    ldr    r2, [r3]                        \n"  //保存r4-r11寄存器到当前任务栈(STMDB指令)
"                                        \n"  //只保存/恢复r4-r11是因为ARM架构下中断自动保存r0-r3,r12,lr,pc,xPSR  
"    stmdb r0!, {r4-r11}                    \n"  /* Save the remaining registers. */
"    str r0, [r2]                        \n"  /* Save the new top of stack into the first member of the TCB. */
"                                        \n"  //更新TCB中的栈顶指针 

"    stmdb sp!, {r3, r14}                \n"  //临时保存r3和r14寄存器
"    mov r0, %0                            \n"   
"    msr basepri, r0                        \n"  //提升中断优先级(basepri)保护临界区
"    bl vTaskSwitchContext                \n"  //调用vTaskSwitchContext选择新任务
"    mov r0, #0                            \n"
"    msr basepri, r0                        \n"  //恢复中断优先级 解除所有中断屏蔽 (BASEPRI=0 时允许所有优先级中断)
"    ldmia sp!, {r3, r14}                \n"  
"                                        \n"  /* Restore the context, including the critical nesting count. */
"    ldr r1, [r3]                        \n"  //从新任务的TCB获取栈指针 临界区嵌套计数可能是前面版本的注释,此处不适合.
"    ldr r0, [r1]                        \n"  /* The first item in pxCurrentTCB is the task top of stack. */
"    ldmia r0!, {r4-r11}                    \n"  // Pop the registers.   恢复r4-r11寄存器(LDMIA指令)
"    msr psp, r0                            \n"  //更新PSP为新任务的栈指针
"    isb                                    \n"  //指令同步屏障,确保前面的指令执行完毕
"    bx r14                                \n"  //通过BX指令返回到新任务的执行点
"                                        \n"  //会触发处理器的异常返回机制
//处理器会自动从栈中恢复xPSR、PC、LR、R12、R3-R0(这是异常进入时自动压栈的寄存器) 从R0开始...到PC结束
//根据EXC_RETURN值切换回线程模式并使用PSP
"    .align 4                            \n"
"pxCurrentTCBConst: .word pxCurrentTCB    \n"
::"i" ( configMAX_SYSCALL_INTERRUPT_PRIORITY )
);
}

中断时使用的是msp,任务x使用的是psp

对比linux来理解:

中断模式属于内核态,任务x属于用户态。

systick中断会触发xPortPendSVHandler,内核态使用msp,即使被其他高级别的中断再中断,也是使用msp,不会影响用户态的psp指针.

http://www.xdnf.cn/news/1153531.html

相关文章:

  • 动态规划——状压DP经典题目
  • 【Keil5-map文件】
  • FMEA-CP-PFD三位一体数字化闭环:汽车部件质量管控的速效引擎
  • simulink系列之模型接口表生成及自动连线脚本
  • Nestjs框架: 理解 RxJS响应式编程的核心概念与实践
  • 商业秘密视域下计算机软件的多重保护困境
  • 支付宝支付
  • day11 ADC
  • 论文略读: RASA: RANK-SHARING LOW-RANK ADAPTATION
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘sqlalchemy’问题
  • Linux内核设计与实现 - 第6章 内核数据结构
  • NX二次开发常用函数坐标转化UF_MTX4_csys_to_csys和UF_MTX4_vec3_multipl
  • 轻松学习C++:基本语法解析
  • 多线程 示例
  • leetcode_121 买卖股票的最佳时期
  • AWS Partner: Accreditation (Technical)
  • 轻松上手:从零开始启动第一个 Solana 测试节点
  • 综合实验--eNSP实验
  • TypeScript 泛型详解:从基础到实战应用
  • Linux中添加重定向(Redirection)功能到minishell
  • python网络爬虫之selenium库(二)
  • 【Web APIs】JavaScript 自定义属性操作 ② ( H5 自定义属性 )
  • 图片放大镜案例
  • Patch-wise Structural:一种引入局部统计特性的时序预测损失函数
  • CS231n-2017 Lecture3线性分类器、最优化笔记
  • QT窗口(7)-QColorDiag
  • [spring6: AspectJAdvisorFactory AspectJProxyFactory]-源码解析
  • Linux C 信号操作
  • “外卖大战”正在改变国内“大零售”
  • 图解系统-小林coding笔记