关于TI sysbios 的SWI

TI SysBIOS 中的SWI(Software Interrupts)线程优先级位于Task和HWI之间,适合低频、实时性要求不高的场景。SWI运行时不可被阻塞,但可被更高优先级的SWI或HWI抢占。SWI函数仅执行一次,但通过trigger variable和swi_inc(),可以在函数内部根据触发次数执行对应任务。swi_gettrigger()用于获取触发次数,在SWI完成并移出等待列表后立即重置,确保即使多次post,SWI函数也仅执行一次。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SWI线程类型优先级高于Task,但低于HWI。SWI适用于发生几率比较低,但实时性要求低于HWI的场景。

SWI同HWI一样一旦运行起来就不能被block(阻塞)。也就是说SWI线程运行过程中不可以有类似semaphore或者gate之类的东西阻塞它,等待其他线程的同步信号,但能被高优先级的SWI或HWI抢占。

同HWI一样,如果同一个SWI在从posted SWI list中移出去之前被post多次,相应的SWI函数只执行一次。当SWI被posted后就放置在posted Swi list中等待运行,开始运行后被移出。


但是,每一个SWI都会有一个trigger variable,利用swi_inc()可以做到触发多少次,执行相应的任务多少次,虽然SWI function只执行一次,但在SWI function 里面可以通过swi_gettrigger()函数读取trigger variable 的值,然后运行相应次数的任务。(swi_gettrigger()只能在swi function里被call)

swi_gettrigger()函数获取的当SWI被从挂起等待运行的swi list中移出后锁存住的trigger value。当SWI 被remove后,它的trigger value 立即被reset。同样的SWI又可以重新被post,等待运行,但相应的swi function 只能被执行一次,不论后面被post多少次。


如图所示,当mySWI执行完成后,如果没有比它优先级高的SWI或者HWI,且mySWI在再次运行之前没有被post多次,当前运行结束后会再次执行mySWI,这是swi_gettrigger()获取到的只是1,也就实现了mySWI被post多少次mySwiFxn()里的while循环多少次。





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值