Corrected cpu script for non-64bit semprons, updated check for pentium-m archs. Also dropped some cflags judged unsafe or counter-productive.

This commit is contained in:
grinvader
2005-10-27 12:25:35 +00:00
parent 5a67f4d561
commit 543ef5256d
2 changed files with 30 additions and 30 deletions

View File

@@ -306,18 +306,18 @@ if test x$enable_cpucheck != xno; then
} }
} }
int main(int argc, char *argv[]) int main()
{ {
char *cpu = 0, model_name[216], flags[216]; char model_name[216], flags[216], cpu_family[216];
char cpu_family[216], vendor_id[216], model[216]; char vendor_id[216], model[216], *cpu = 0;
FILE *fp; FILE *fp;
*model_name = 0; *model_name = 0;
*flags = 0;
*cpu_family = 0; *cpu_family = 0;
*vendor_id = 0; *vendor_id = 0;
*model = 0; *model = 0;
strcpy(flags, " ");
if ((fp = fopen("/proc/cpuinfo", "r"))) if ((fp = fopen("/proc/cpuinfo", "r")))
{ {
@@ -328,8 +328,11 @@ if test x$enable_cpucheck != xno; then
{ {
if (!strncmp(key, "model name", strlen("model name")) && !*model_name) if (!strncmp(key, "model name", strlen("model name")) && !*model_name)
{ strcpy(model_name, arg); } { strcpy(model_name, arg); }
else if (!strncmp(key, "flags", strlen("flags")) && !*flags) else if (!strncmp(key, "flags", strlen("flags")) && !flags[1])
{ strcpy(flags, arg); } {
strcat(flags, arg);
strcat(flags, " ");
}
else if (!strncmp(key, "cpu family", strlen("cpu family")) && !*cpu_family) else if (!strncmp(key, "cpu family", strlen("cpu family")) && !*cpu_family)
{ strcpy(cpu_family, arg); } { strcpy(cpu_family, arg); }
else if (!strncmp(key, "vendor_id", strlen("vendor_id")) && !*vendor_id) else if (!strncmp(key, "vendor_id", strlen("vendor_id")) && !*vendor_id)
@@ -356,7 +359,7 @@ if test x$enable_cpucheck != xno; then
cpuid(0x80000000, maxei, unused, unused, unused); cpuid(0x80000000, maxei, unused, unused, unused);
if(maxei >= 0x80000001) if (maxei >= 0x80000001)
{ {
cpuid(0x80000001, unused, unused, ecx, edx); cpuid(0x80000001, unused, unused, ecx, edx);
add_flags(flags, edx, 32); add_flags(flags, edx, 32);
@@ -379,7 +382,7 @@ if test x$enable_cpucheck != xno; then
add_flags(flags, edx, 128); add_flags(flags, edx, 128);
} }
if(maxei >= 0x80000002) if (maxei >= 0x80000002)
{ {
for (i = 0x80000002; i <= 0x80000004; i++) for (i = 0x80000002; i <= 0x80000004; i++)
{ {
@@ -389,35 +392,32 @@ if test x$enable_cpucheck != xno; then
strncat(model_name, (char *)&ecx, 4); strncat(model_name, (char *)&ecx, 4);
strncat(model_name, (char *)&edx, 4); strncat(model_name, (char *)&edx, 4);
} }
while (isspace(*model_name))
{ memmove(model_name, model_name+1, strlen(model_name)); }
} }
} }
if (!strcmp(vendor_id, "AuthenticAMD") || strstr(model_name, "AMD")) if (!strcmp(vendor_id, "AuthenticAMD") || strstr(model_name, "AMD"))
{ {
if (strstr(flags, "mmx")) if (strstr(flags, " mmx "))
{ {
#if __GNUC__ > 2 #if __GNUC__ > 2
if (strstr(flags, "3dnow")) if (strstr(flags, " 3dnow "))
{ {
if (strstr(flags, "3dnowext")) if (strstr(flags, " 3dnowext "))
{ {
#if __GNUC__ > 3 || __GNUC_MINOR__ > 0 #if __GNUC__ > 3 || __GNUC_MINOR__ > 0
if (strstr(flags, "sse")) if (strstr(flags, " sse "))
{ {
#if __GNUC__ > 3 || __GNUC_MINOR__ > 3 #if __GNUC__ > 3 || __GNUC_MINOR__ > 3
if (strstr(flags, "sse2") && strstr(flags, "lm")) //Need two checks to protect Semprons if (strstr(flags, " sse2 ") && strstr(flags, " lm ")) //Need two checks to protect Semprons
{ {
if (strstr(model_name, "Opteron")) { cpu = "opteron"; } if (strstr(model_name, " Opteron ")) { cpu = "opteron"; }
else { cpu = (strstr(model_name, "Athlon(tm) 64")) ? "athlon64" : "k8"; } else { cpu = (strstr(model_name, "Athlon(tm) 64")) ? "athlon64" : "k8"; }
} //Athlon64, also athlon-fx } //Athlon64, also athlon-fx
#endif #endif
if (!cpu) if (!cpu)
{ {
if (strstr(model_name, "Athlon(tm) 4")) { cpu = "athlon-4"; } if (strstr(model_name, "Athlon(tm) 4")) { cpu = "athlon-4"; }
else { cpu = (strstr(model_name, "Athlon(tm) MP")) ? "athlon-mp" : "athlon-xp"; } else { cpu = (strstr(model_name, "Athlon(tm) MP")) ? "athlon-mp" : cpu = "athlon-xp"; }
} }
} }
@@ -443,22 +443,22 @@ if test x$enable_cpucheck != xno; then
else if (!strcmp(vendor_id, "GenuineIntel") || strstr(model_name, "Intel")) else if (!strcmp(vendor_id, "GenuineIntel") || strstr(model_name, "Intel"))
{ {
#if __GNUC__ > 2 #if __GNUC__ > 2
if (strstr(flags, "mmx")) if (strstr(flags, " mmx "))
{ {
if (strstr(flags, "sse")) if (strstr(flags, " sse "))
{ {
if (strstr(flags, "sse2")) if (strstr(flags, " sse2 "))
{ {
#if __GNUC__ > 3 || __GNUC_MINOR__ > 2 #if __GNUC__ > 3 || __GNUC_MINOR__ > 2
if (strstr(flags, "pni")) if (strstr(flags, " pni "))
{ {
cpu = (strstr(flags, "lm")) ? "nocona" : "prescott"; cpu = (strstr(flags, " lm ")) ? "nocona" : "prescott";
} }
#endif #endif
if (!cpu) if (!cpu)
{ {
if (strstr(model_name, "Pentium(R) M") || strstr(model_name, "Celeron(R) M")) if (!strcmp(cpu_family, "6"))
{ {
#if __GNUC__ > 3 || __GNUC_MINOR__ > 3 #if __GNUC__ > 3 || __GNUC_MINOR__ > 3
cpu = "pentium-m"; cpu = "pentium-m";
@@ -492,12 +492,12 @@ if test x$enable_cpucheck != xno; then
#if __GNUC__ > 2 #if __GNUC__ > 2
else if (strstr(model_name, "VIA")) else if (strstr(model_name, "VIA"))
{ {
if (strstr(flags, "mmx")) if (strstr(flags, " mmx "))
{ {
#if __GNUC__ > 3 || __GNUC_MINOR__ > 2 #if __GNUC__ > 3 || __GNUC_MINOR__ > 2
if (strstr(flags, "3dnow")) { cpu = "c3"; } if (strstr(flags, " 3dnow ")) { cpu = "c3"; }
#if __GNUC__ > 3 || __GNUC_MINOR__ > 3 #if __GNUC__ > 3 || __GNUC_MINOR__ > 3
else if (strstr(flags, "sse")) { cpu = "c3-2"; } else if (strstr(flags, " sse ")) { cpu = "c3-2"; }
#endif #endif
#endif #endif
} }
@@ -505,9 +505,9 @@ if test x$enable_cpucheck != xno; then
else if (strstr(model_name, "WinChip")) else if (strstr(model_name, "WinChip"))
{ {
#if __GNUC__ > 3 || __GNUC_MINOR__ > 2 #if __GNUC__ > 3 || __GNUC_MINOR__ > 2
if (strstr(flags, "mmx")) if (strstr(flags, " mmx "))
{ {
cpu = (strstr(flags, "3dnow")) ? "winchip2" : "winchip-c6"; cpu = (strstr(flags, " 3dnow ")) ? "winchip2" : "winchip-c6";
} }
#endif #endif
} }

View File

@@ -124,7 +124,7 @@ else
if test x$release = xyes; then if test x$release = xyes; then
AC_MSG_RESULT(yes) AC_MSG_RESULT(yes)
CFLAGS="$CFLAGS -O3 -pipe -fomit-frame-pointer -ffast-math -fprefetch-loop-arrays -frename-registers -fforce-addr -s" CFLAGS="$CFLAGS -O3 -fomit-frame-pointer -ffast-math -fprefetch-loop-arrays -fforce-addr -s"
NFLAGS="$NFLAGS -O99999999" NFLAGS="$NFLAGS -O99999999"
else else
AC_MSG_RESULT(no) AC_MSG_RESULT(no)