博客
关于我
【总结】从认知硬件的中断机制到加深对系统设计中断信号(异常)与任务调度的理解。
阅读量:430 次
发布时间:2019-03-06

本文共 714 字,大约阅读时间需要 2 分钟。

最近(2021年01月31日)理了一遍自己作为软工走进嵌入式底层后,对硬件的认知提升过程,现在记录下来,方便后人理解和认知。

按时间顺序理解:

在还不知道中断这个概念时,我只知道进程和线程的系统调度存在,主要是关于时间片轮和银行家调度算法的实现,描述软件上多任务调度的规划,涉及CPU调度的优先级和上下文切换(寄存器列表置换)。

开始接触MCU硬件后,认识到中断的存在。它在硬件启动时导入预定异常中断函数,供软件链接。当发生异常时,根据优先度决定是否打断当前任务,这种打断是CPU在执行指令时自行决定的,类似于C语言中的sigh信号或系统IO通信。

从micropython中的异常机制了解nlr和setjump的上下文切换寄存器操作,程序可借用CPU资源调度,关键在于地址跳转和寄存器置换。

结合Linux嵌入式芯片的异常向量表,硬件检查指令异常,触发中断,保存寄存器现场,交给软件定义的中断触发接收函数处理,完成硬件到软件的异常中断设计。

不细说芯片具体实现,记录异常与中断软件设计描述,基础认知可参考相关文章。

通过这篇文章,理解系统需要硬件接口实现中断和异常程序设计。反向思考,软中断如何实现,设计结构。

异常向量表是CPU检查的对象,软件进程表检查的对象,程序外部信号或按键为软中断,优先级决定中断处理。硬件硬中断是中断来源之一。

不再区分软硬件,统一理解流程中断实现。多进程多线程通过高优先级定时器中断信号调度上下文切换,决定挂起当前代码段,切换线程队列数据。

建议从一开始写状态机全异步实现,避免基于该机制需自己思考优先级管理和并行资源加锁同步。

补充:进程独立内存区域,线程与进程共用内存区域,推荐阅读相关文章。

转载地址:http://ribyz.baihongyu.com/

你可能感兴趣的文章
OWASP漏洞原理<最基础的数据库 第二课>
查看>>
OWL本体语言
查看>>
P with Spacy:自定义文本分类管道
查看>>
Spring自动装配Bean
查看>>
P-DQN:离散-连续混合动作空间的独特算法
查看>>
P1035 I need help
查看>>
P1073 最优贸易
查看>>
P1207 双重回文数
查看>>
p1229
查看>>
P1273 有线电视网(树形dp)
查看>>
spring编程常见错误二 (学习笔记)
查看>>
P1364 医院设置
查看>>
P1614 爱与愁的心痛
查看>>
spring缓存注解@Cacheable、@CacheEvict、@CachePut使用
查看>>
P1865 A % B Problem
查看>>
P1908 逆序对
查看>>
P2158 [SDOI2008]仪仗队
查看>>
P2161 [SHOI2009]Booking 会场预约
查看>>
P2260 [清华集训2012]模积和
查看>>
P2x与P3x的区别
查看>>