#include<stdio.h>
unsigned int veax
unsigned int vebx
unsigned int vedx
unsigned int vecx
//执行CPUID指令
void cpuid(unsigned int veax1)
{
_asm{
mov eax,veax1
cpuid
mov veax,eax
mov vebx,ebx
mov vecx,ecx
mov vedx,edx
}
}
//做移位 *** 作,把寄存器中的ASCII码,以字符形式输出
void LeftMove(unsigned int var)
{
printf("%c",var)
for(int i=0i<3i++)
{
var=(var>>
printf("%c",var)
}
}
//做移位 *** 作,把寄存器中的值以“%d”形式输出
void LM(unsigned int var)
{
printf("%d",var)
for(int i=0i<3i++)
{
var=(var>>
printf("%d",var)
}
}
//得到CPU的生产厂商(当EAX值为0时),依次存放在EBX,EDX,ECX中
void getCpuName()
{
cpuid(0)
LeftMove(vebx)
LeftMove(vedx)
LeftMove(vecx)
printf("\
"
}
//得到CPU的商标,当EAX中的值为0x80000003和0x80000004时分别返回16个字符,组成商标
//依次存放在EAX,EBX,ECX,EDX中
void getCpuBrand()
{
for(int j=0j<2j++)
{
cpuid(0x80000003+j)
LeftMove(veax)
LeftMove(vebx)
LeftMove(vecx)
LeftMove(vedx)
}
printf("\
"
}
//获得CPU的特性,参数是eax = 1,返回值放在edx和ecx,通过验证edx或者ecx的某一个bit,
//可以获得CPU的一个特性是否被支持。比如说,edx的bit 32代表是否支持MMX,
//edx的bit 28代表是否支持Hyper-Threading,ecx的bit 7代表是否支持speed sted。
void getCpuFeature()
{//由于特性太多,无法一一编写,需要的时候再写,方法是一样的。
}
//获得CPU序列号,获得序列号需要两个步骤,首先用eax = 1做参数,返回的eax中存储序列号的高两个WORD。
//用eax = 3做参数,返回ecx和edx按从低位到高位的顺序存储前4个WORD。
void getCpuSeris()
{
cpuid(1)
LM(veax)
cpuid(3)
LM(vecx)
LM(vedx)
printf("\
"
}
void main()
{
getCpuName()
getCpuBrand()
getCpuSeris()
}
参考下面的文章:利用利用CPUID 汇编指令(机器码:0FH A2H, 如果你的编译器不支持CPUID 指令,只有emit 机器码了), 该指令可以被如下CPU识别:
Intel 486 以上的CPU,
Cyrix M1 以上的CPU,
AMD Am486 以上的CPU
(1) 取CPU OEM 字符串, 判断CPU 厂商
先让EAX=0, 再调用CPUID
Inel的CPU将返回:
EBX:756E6547H 'Genu'
EDX:49656E69H 'ineI'
ECX:6C65746EH 'ntel'
EBX,EDX,ECX 将连成"GenuineIntel", 真正的Intel。
Cyrix 的CPU 将返回:
EBX:43797269H
EDX:78496E73H
ECX:74656164H
"CyrixInstead","Cyrix 来代替"。
AMD 的CPU 将返回:
EBX:41757468H
EDX:656E7469H
ECX:63414D44H
"AuthenticAMD", 可信的AMD。
在Windows98中,用右键单击"我的电脑",选择" 属性- 常规"在计算机描述 处就可看见CPU OEM 字符串。
(2)CPU 到底是几86, 是否支持MMX
先让EAX=1,再调用CPUID
EAX的8到11位就表明是几86
3 - 386
4 - i486
5 - Pentium
6 - Pentium Pro Pentium II
2 - Dual Processors
EDX 的第0位:有无FPU
EDX的第23位:CPU是否支持IA MMX,很重要啊 !如果你想用那57条新增的指 令,先检查这一位吧,否则就等着看Windows 的"该程序执行了非法指令,将被关 闭" 吧。
(3) 专门检测是否P6架构
先让EAX=1,再调用CPUID
如果AL=1,就是Pentium Pro 或Pentium II
(4) 专门检测AMD的CPU信息
先让EAX=80000001H,再调用CPUID
如果EAX=51H, 是AMD K5
如 果EAX=66H, 是K6
EDX第0 位: 是否有FPU( 多余的 !谁用过没FPU的K5,K6?)
EDX 第23 位,CPU是否支持MMX,
程序如下:
//------CPUID Instruction Demo Program------------
#include
#include
#pragma hdrstop
//------------------------------------------------
#pragma inline
#pragma argsused
int main(int argc, char **argv)
{
char OEMString[13]
int iEAXValue,iEBXValue,iECXValue,iEDXValue
_asm {
mov eax,0
cpuid
mov DWORD PTR OEMString,ebx
mov DWORD PTR OEMString+4,edx
mov DWORD PTR OEMString+8,ecx
mov BYTE PTR OEMString+12,0
}
cout<<"This CPU 's OEM String is:"<<OEMString<<endl
_asm {
mov eax,1
cpuid
mov iEAXValue,eax
mov iEBXValue,ebx
mov iECXValue,ecx
mov iEDXValue,edx
}
if(iEDXValue&0x800000)
cout <<"This is MMX CPU"<<endl
else
cout <<"None MMX Support."<<endl
int iCPUFamily=(0xf00 &iEAXValue) >>8
cout <<"CPU Family is:"<<iCPUFamily<<endl
_asm{
mov eax,2
CPUID
}
if(_AL==1)
cout <<"Pentium Pro or Pentium II Found"
getch()
return 0
}
最后,最好学会自己去搜索你需要的信息,
我上面的答案也是搜索来的。
关键字“C语言 CPU 信息”
这个一般不能做到。
一般的C语言编译器会限制程序的资源使用量(如CPU不超过40%),超过设定时,编译出来的程序会提示“未响应”而停止工作,不会造成电脑满负荷工作的情况。
实现满负荷工作可以用一些拷机软件,比如Super PI,来测试处理器的性能。
但对于时间的记录,可以运用<time.h>的函数来实现,用法如下:
time_t start,endstart =time(NULL)//or time(&start)
//计时中
end =time(NULL)
printf("time=%d\n",difftime(end,start))
这里的输出单位为秒。如要精确到毫秒的计时,可以调用clock():
clock_t start,endstart = clock()
//计时中
end = clock()
printf("time=%f\n",(double)end-start)/CLK_TCK)
这里end和start得到的是计算机时钟的tick数,换算成毫秒需要除以常数CLK_TCK,换算成秒除以常数CLK_TCKCLOCKS_PER_SEC。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)