找回密码
 注册
关于网站域名变更的通知
查看: 289|回复: 1
打印 上一主题 下一主题

飞凌嵌入式RK3562J技术分享 | AMP双系统下的裸核中断嵌套初体验

[复制链接]

该用户从未签到

跳转到指定楼层
1#
 楼主| 发表于 2024-7-29 10:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
多核异构系统是⼀种使同⼀颗SoC芯片中不同核心分别独立运行不同平台的计算系统。通过合理的处理器核心及外设资源划分,使⼀颗SoC芯片能够独立运行Linux系统和实时性系统,在满足系统软件功能和硬件外设丰富性要求的同时,也满足系统的实时性要求,具有突出的性价比优势和产品体积优势。

6 \" y. {! ]' [4 J+ x- o4 z; }4 U1 N' J* U- p% G
1. 瑞芯微多核异构系统
“瑞芯微多核异构系统”是瑞芯微提供的⼀套通用多核异构系统解决方案。
4 _8 ^" {( k0 S4 ?, K
在运行平台方面:
Linux提供标准的Linux Kernel,RTOS提供开源的RT-Thread ,Bare-metal提供基于RK HAL硬件抽象层的裸机开发库。同时,瑞芯微多核异构系统支持客户自行适配更多的运行平台,例如可以基于RK HAL硬件抽象层适配指定的RTOS等。

% x1 f4 x: B; |+ O
在处理器核心方面:
瑞芯微多核异构系统支持SoC中同构的ARM Cortex-A核心独立运行。也支持SoC中异构的ARM Cortex-M或RISC-V核心独立运行。瑞芯微多核异构系统通过合理的处理器核心资源划分,将适当的任务分配到最适合的核心进行处理,从而使SoC发挥出更优秀的性能和能效表现。
目前,瑞芯微多核异构系统采用无监督的AMP方案。不使用虚拟化管理,从而在运行实时性系统时获得更快的中断响应,以满足电力、工控等行业应用中严苛的硬实时性要求。

2 w0 b. T' c* N" T: q. t2. RK3562J处理器核心及AMP支持情况
处理器核心
# _3 f" }+ I# O& o( ?" K
AMP支持情况
1 H$ F1 F2 U  F$ N7 q2 y

) Q5 j( y7 H9 E; A) O! `+ E
( H: S; j  _# L! z
3. 中断嵌套机制
中断嵌套是一种有效的中断处理机制,它允许系统根据中断的优先级来响应和处理中断,从而确保关键任务能够及时得到处理,具有实时性高、灵活性好、响应快速等特点,但传统的Linux系统为了简化设计、提高系统的稳定性和可预测性、减少资源竞争和死锁等风险、以及提高兼容性和可维护性,不支持中断嵌套。这种设计选择使得Linux内核在许多应用场景中表现出色,但对于高实时性场景下的应用就显得力不从心了。

8 \! ?6 n5 i) H7 J+ h% q' D  P5 u7 q/ x
" \& {! b! v; U8 |8 m, T( {6 U
& f  ~+ c4 H, U4 X0 E
4. 案例实践分享
开发板型号:OK3562J-C
资料版本:OK3562-C_Linux 5.10.198_用户资料_R1

8 @: j. j3 u. e, S! n
测试思路:
使用两个GPIO,分别为GPIO4B1和GPIO0B0,其中GPIO4B1设置为输出,GPIO设置为输入并且中断配置为下降沿触发。硬件上短接GPIO4B1和GPIO0B0。
使用Timer4定时器每秒产生一个定时器中断,在中断处理函数中控制GPIO4B1产生一个下降沿并延时,如果出现了GPIO0B0中断处理函数中的打印信息则证明成功发生了中断抢占。

2 m' ?7 ^( ^, q0 v
测试步骤:
(1)编写测试程序fltest_irq_preempt.c开启TIEMR4和GPIO0B0的中断并且将GPIO0B0配置为下降沿触发,在定时器中断处理函数中将GPIO4B1拉高拉低,使之触发GPIO0B0的中断,在GPIO0B0的中断处理函数中打印一句话来表明当前进入了GPIO0B0的中断;
(2)修改中断路由,添加TIMER4和GPIO0的中断并使之绑定给CPU3,并设置TIMER4的中断优先级高于GPIO0;
(3)重新编译镜像并烧写;
(4)在uboot菜单中打开AMP并重启OK3562J-C开发板,此时RTOS调试串口打印如下:
& V! }6 y7 }  P( m: u. t
按tab键可以打印出当前的所有命令:
可以看到我们的命令已经注册成功了。

2 n0 F& q) u6 a1 R4 y
现在执行我们刚刚编写的fl_irq_test这条命令,即可看到效果:
可以看到GPIO0B0的中断抢占了当前的TIMER4中断。

% J7 |: D5 ^0 H; W
我们将二者的优先级调换一下再重新编译烧写,然后再次执行该程序,可以看到GPIO0B0的中断在TIMER4中断结束之后才被处理,未发生抢占。

, ~, _/ O. O! G! u. T7 Q
" A) j$ B# `: H! b- e3 b5 c9 h2 o3 l# X

该用户从未签到

2#
发表于 2024-7-29 10:26 | 只看该作者
流程很详细
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-23 13:09 , Processed in 0.125000 second(s), 22 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表