共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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| STM32C0116DK开发探索记(3)被打赏¥30元 | |
| STM32C0116DK开发探索记(2)被打赏¥24元 | |
| STM32C0116DK开发探索记(1)被打赏¥29元 | |
| 谨防极海G32M3101电机评估板易跌落的陷阱被打赏¥24元 | |
| 【全网首拆】M5STACK ATOM系列开发板拆解 / AtomS3R-CAM摄像头更换方法(提高10倍像素)被打赏¥26元 | |
| 基于MCP23S17的输入输出功能模块控制被打赏¥20元 | |
| 【S32K3XX】SPD 软件包使用Link文件修改被打赏¥22元 | |
| Switch-Case局部变量定义问题被打赏¥23元 | |
| 基于米尔TIAM62L开发板的串口通信及应用被打赏¥20元 | |
| PCF8574功能模块及其使用被打赏¥20元 | |
我要赚赏金
