ioctl和执行时间

时间:2010-09-20 12:12:30

标签: c linux multithreading embedded linux-kernel

我有一个运行两个线程的程序 - 它们使用消息队列进行通信。

在一个线程中,我调用ioctl()来访问硬件解密器。代码如下:

void Decrypt
{

...
..
...

if(<condition 1>)
{.
...
...
retVal = ioctl(...);
comesInHere1++;
}

if(<condition 2>)
{
...
...
retVal = ioctl(...);
comesInHere2++;
}

comeInHere1和comeInHere2用于计算它在特定if循环中的次数。

整个程序需要80 ms才能执行。但是如果我注释掉测试变量(ifInHere1,if循环中的comeInHere2),执行时间会增加8毫秒到88毫秒!

怎么可能?我现在无法将变量注释掉,因为它增加了所用的时间,无法保留它们 - 将在代码审查中被杀死:)

请让我知道

由于

1 个答案:

答案 0 :(得分:1)

缓存?通过添加更多数据,您可能会将代码移动到不同的缓存行,这些缓存行会以某种方式放在一起,从而导致颠簸。您可以通过在不同系统上运行并在每个线程中专门使用的变量之间添加填充数据来进行实验。

如果将处理序列化到单个内核会发生什么?