Added some rudimentary AMD CPU identification, courtesy of Brennan Cleveland.

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@8964 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2004-09-15 01:54:50 +00:00
parent bb32d497e9
commit 1b41fce458

View File

@ -8,19 +8,20 @@
extern char *__progname;
static cpuid_info CPU_Data;
void
usage()
{
printf("usage: cpuinfo [-option]\n\n"
"Prints information about your CPU.\n"
" -i CPU identification\n"
" -f supported processor features\n"
" -t TLB and cache info\n"
" -d dump registers from CPUID calls\n");
printf("usage: %s [-option]\n\n"
"Prints information about your CPU.\n"
" -i CPU identification\n"
" -f supported processor features\n"
" -t TLB and cache info\n"
" -d dump registers from CPUID calls\n", __progname);
exit(0);
}
@ -112,7 +113,7 @@ opt_identify(cpuid_info *info, int vendor_tag)
// the 'vendorid' field of the info struct is not null terminated,
// so it is copied into a properly terminated local string buffer
memcpy(vendorID, info->eax_0.vendorid, 12);
printf("%12s '%s'\n", "Vendor ID:", vendorID);
printf("%12s '%s'\n", "Vendor ID:", vendorID);
switch (vendor_tag) {
case 'uneG': // "GenuineIntel"
@ -324,8 +325,8 @@ Intel_features(cpuid_info *info)
void
insert (int *a, int elem, int max_index)
{
insert(int *a, int elem, int max_index)
{
// inserts a new element into an ordered integer array
// using (what else) the trusty old binary search algorithm...
// assumes the array has sufficient space to do this
@ -354,7 +355,7 @@ insert (int *a, int elem, int max_index)
// insert the new guy
a[lo] = elem;
}
}
void
@ -403,7 +404,6 @@ Intel_TLB_cache(cpuid_info *info)
while (n < tabsize)
indexOf[tab[n++].descriptor] = i++;
// pass loop: insert relevant table indexes into the slot array
i = 0;
for (pass = 0; ; ++pass) {
@ -438,7 +438,6 @@ Intel_TLB_cache(cpuid_info *info)
insert(slot, indexOf[db], i++);
}
// reset slot index for output loop
i = 0;
@ -470,30 +469,97 @@ Intel_TLB_cache(cpuid_info *info)
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
// AMD specs
// Brennan says: I'm just digging around and trying to find AMD documentation
// on product signatures and CPU types...not easy to find. This is a dirty hack
// until I can find proper docs...
static const char *
AMD_brand_string(int family, int model, int processor_signature)
{
int sig = processor_signature;
switch (family) {
//K5 and K6 models
case 0x5:
if(model >= 0x0 && model <= 0x3) {
return "AMD K5";
}
else if(model == 0x8){
return "AMD K6-2";
}
else if(model == 0x9) {
return "AMD K6-III";
}
else {
return "AMD K6";
}
//Athlon and Duron models, very general
case 0x6:
//Hack. I own one, so I know this is the processor signature!
if(sig == 1634) {
return "AMD Mobile Athlon";
}
else if(model == 0x1 || model == 0x2 || model == 0x4) {
return "AMD Athlon";
}
else if(model == 0x3 ||model == 0x7) {
return "AMD Duron";
}
else if(model == 0x6){
return "AMD Duron/AMD Athlon XP/AMD Athlon MP";
}
case 0xf:
if(model == 0x5) {
return "AMD Athlon 64";
}
if(model == 0x6) {
return "AMD Opteron";
}
//This is the new 266FSB Duron model
else if(model == 0x8) {
return "AMD Duron (266 FSB)";
}
default:
return "Unknown AMD Processor";
}
}
void
AMD_identify(cpuid_info *info)
{
printf("Sorry! Info about AMD cpu's not implemented yet :(\n");
int type, family, model, sig;
const char *id_string;
get_cpuid(info, 1, 0);
type = info->eax_1.type;
family = info->eax_1.family;
model = info->eax_1.model;
sig = info->regs.eax;
id_string = AMD_brand_string(family, model, sig);
printf("%s, Model: %d\n", id_string, model);
printf("Family: %d\n", family);
printf("Signature: %d\n", sig);
}
void
AMD_features(cpuid_info *info)
{
printf("Sorry! Info about AMD cpu's not implemented yet :(\n");
printf("Sorry! Info about AMD CPU's not implemented yet :(\n");
}
void
AMD_TLB_cache(cpuid_info *info)
{
printf("Sorry! Info about AMD cpu's not implemented yet :(\n");
printf("Sorry! Info about AMD CPU's not implemented yet :(\n");
}
@ -506,21 +572,21 @@ AMD_TLB_cache(cpuid_info *info)
void
Cyrix_identify(cpuid_info *info)
{
printf("Sorry! Info about Cyrix cpu's not implemented yet :(\n");
printf("Sorry! Info about Cyrix CPU's not implemented yet :(\n");
}
void
Cyrix_features(cpuid_info *info)
{
printf("Sorry! Info about Cyrix cpu's not implemented yet :(\n");
printf("Sorry! Info about Cyrix CPU's not implemented yet :(\n");
}
void
Cyrix_TLB_cache(cpuid_info *info)
{
printf("Sorry! Info about Cyrix cpu's not implemented yet :(\n");
printf("Sorry! Info about Cyrix CPU's not implemented yet :(\n");
}