作者热门文章
- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
bogomips在linux内核中是如何计算的?得到这个值到底做了什么?
最佳答案
/*
* Standalone BogoMips program
*
* Based on code Linux kernel code in init/main.c and
* include/linux/delay.h
*
* For more information on interpreting the results, see the BogoMIPS
* Mini-HOWTO document.
*
* version: 1.3
* author: Jeff Tranter (Jeff_Tranter@Mitel.COM)
*/
#include <stdio.h>
#include <time.h>
#ifdef CLASSIC_BOGOMIPS
/* the original code from the Linux kernel */
static __inline__ void delay(int loops)
{
__asm__(".align 2,0x90\n1:\tdecl %0\n\tjns 1b": :"a" (loops):"ax");
}
#endif
#ifdef QNX_BOGOMIPS
/* version for QNX C compiler */
void delay(int loops);
#pragma aux delay = \
"l1:" \
"dec eax" \
"jns l1" \
parm nomemory [eax] modify exact nomemory [eax];
#endif
#ifdef PORTABLE_BOGOMIPS
/* portable version */
static void delay(int loops)
{
long i;
for (i = loops; i >= 0 ; i--)
;
}
#endif
int
main(void)
{
unsigned long loops_per_sec = 1;
unsigned long ticks;
printf("Calibrating delay loop.. ");
fflush(stdout);
while ((loops_per_sec <<= 1)) {
ticks = clock();
delay(loops_per_sec);
ticks = clock() - ticks;
if (ticks >= CLOCKS_PER_SEC) {
loops_per_sec = (loops_per_sec / ticks) * CLOCKS_PER_SEC;
printf("ok - %lu.%02lu BogoMips\n",
loops_per_sec/500000,
(loops_per_sec/5000) % 100
);
return 0;
}
}
printf("failed\n");
return -1;
}
关于linux - BogoMips 是如何在 linux 内核中计算的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6529893/
我一直在阅读我的 Samsung Galaxy (sgh-i897) 上的 cpuinfo 文件以检索 bogoMIPS 值。刚刚学习如何解释此类信息。 最初我在加载线程的主要 Activity 下执
bogomips在linux内核中是如何计算的?得到这个值到底做了什么? 最佳答案 /* * Standalone BogoMips program * * Bas
如果我有一个长时间运行的进程,它在完成工作时平均使用 10% 的 CPU,并且我并行运行它的两个副本,我可以预期它们总共使用 20% 的 CPU中央处理器。或者,如果我在速度两倍的不同 CPU 上运行
我想测试不同 Java 平台的速度,并考虑创建一个像 Linux BogoMips 一样工作的 JojoMips 基准例程。它会进行计算并提供如下数字:4346 JojoMips。虚拟机越快,Jojo
我是一名优秀的程序员,十分优秀!