共3条
1/1 1 跳转至页
semGive究竟有多快??
今天在s3c4510b上的一个中断服务程序中实际测了一下semGive()所需要的时间。OS:vxowkrs平台.
代码如下:
void channelISR(void)
{
*(volatile UINT32 *)SNDS_IOPDATA = 0xf7; // P3 is low, disable alarm.
*(volatile UINT32 *)SNDS_IOPDATA = 0xff; // P3 is high, enable alarm.
semGive(z1510VideoDev[gChanNum].processId);
*(volatile UINT32 *)SNDS_IOPDATA = 0xf7; // P3 is low, disable alarm.
*(volatile UINT32 *)SNDS_IOPDATA = 0xff; // P3 is high, enable alarm.
}
s3c4510b工作在50MHz,为RISC体系,一条汇编指令理论上是20ns。结果用数字示波器一看:一次IO操作用了将近100ns,而一次semGive()则用了6us左右!如果是用消息队列则会长得多,我没有去测,感兴趣的朋友可以去试一试。[em21][em21]
关键词: semGive 竟有 多快
共3条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 | |
【FRDM-MCXN947评测】核间通信MUTEX被打赏50分 |