# Automatic configuration of the UCW Library
# (c) 2005 Martin Mares <mj@ucw.cz>
+# (c) 2006 Robert Spalek <robert@ucw.cz>
### OS ###
if (Get("OS") eq "Linux") {
Set("CONFIG_LINUX");
+} elsif (Get("OS") eq "Darwin") {
+ Set("CONFIG_DARWIN");
} else {
Fail "Don't know how to run on this operating system.";
}
# GCC version
Test("GCCVER", "Checking for GCC version", sub {
my $gcc = Get("CC");
- my $ver = `$gcc --version | sed '2,\$d; s/^\\(.* \\)\\?\\([0-9]*\\.[0-9]*\\).*/\\2/'`;
+ my $ver = `$gcc --version | sed '2,\$d; s/^\\(.* \\)*\\([0-9]*\\.[0-9]*\\).*/\\2/'`;
chomp $ver;
Fail "Unable to determine GCC version" if $? || $ver eq "";
return $ver;
}
});
-sub parse_cpuinfo() {
- IsSet("CONFIG_EXACT_CPU") && IsSet("CONFIG_LINUX") && open X, "/proc/cpuinfo" || undef;
+sub parse_cpuinfo_linux() {
+ open X, "/proc/cpuinfo" || undef;
my %pc = ();
while (<X>) {
chomp;
/^([^\t]+)\t+:\s*(.*)$/ and $pc{$1}=$2;
}
close X;
+ return ($pc{'vendor_id'},
+ $pc{'cpu family'},
+ $pc{'model'});
+}
+
+sub parse_cpuinfo_darwin() {
+ @cpu = (`sysctl -n machdep.cpu.vendor`,
+ `sysctl -n machdep.cpu.family`,
+ `sysctl -n machdep.cpu.model`);
+ chomp @cpu;
+ return @cpu;
+}
- my $vendor = $pc{'vendor_id'} || "";
- my $family = $pc{'cpu family'} || 0;
- my $model = $pc{'model'} || 0;
- return ($vendor, $family, $model);
+sub parse_cpuinfo() {
+ my @cpu;
+ if (IsSet("CONFIG_EXACT_CPU")) {
+ if (IsSet("CONFIG_LINUX")) {
+ @cpu = parse_cpuinfo_linux();
+ } elsif (IsSet("CONFIG_DARWIN")) {
+ @cpu = parse_cpuinfo_darwin();
+ }
+ }
+ $cpu[0] = "" if !defined $cpu[0];
+ $cpu[1] = 0 if !defined $cpu[1];
+ $cpu[2] = 0 if !defined $cpu[2];
+ return @cpu;
}
Test("CPU_ARCH", "Checking for CPU architecture", sub {
my $mach = Get("ARCH");
+ my $arch = "";
if ($mach eq "i386") {
Set("CPU_I386");
UnSet("CPU_64BIT_POINTERS");
UnSet("CPU_BIG_ENDIAN");
Set("CPU_ALLOW_UNALIGNED");
Set("CPU_STRUCT_ALIGN" => 4);
- my $arch = "";
if (my ($vendor, $family, $model) = parse_cpuinfo()) {
# Try to understand CPU vendor, family and model [inspired by MPlayer's configure script]
if ($vendor eq "AuthenticAMD") {
elsif ($model >= 3) { $arch = "prescott"; }
else { $arch = "pentium4"; }
} elsif ($family == 6 && $gccver >= 3003) {
- if (($model == 9 || $model == 13) && $gccver >= 3004) { $arch = "pentium-m"; }
+ if ($model == 15) { $arch = "prescott"; }
+ elsif (($model == 9 || $model == 13) && $gccver >= 3004) { $arch = "pentium-m"; }
elsif ($model >= 7) { $arch = "pentium3"; }
elsif ($model >= 3) { $arch = "pentium2"; }
}
}
Log (($arch ne "") ? "(using /proc/cpuinfo) " : "(don't understand /proc/cpuinfo) ");
}
- return $arch ? $arch : "i386";
+ return $arch;
} elsif ($mach eq "amd64") {
Set("CPU_AMD64");
Set("CPU_64BIT_POINTERS");
}
Log (($arch ne "") ? "(using /proc/cpuinfo) " : "(don't understand /proc/cpuinfo) ");
}
- return $arch ? $arch : "x86-64";
+ return $arch;
} else {
- return undef;
+ return "";
}
});
-if (!IsSet("CPU_ARCH")) { Warn "CPU type not recognized, using defaults, keep fingers crossed."; }
-
### Compiler and its Options ###
-# C flags: tell the compiler we're speaking C99
-Set("CLANG" => "-std=gnu99");
+# C flags: tell the compiler we're speaking C99, and disable common symbols
+Set("CLANG" => "-std=gnu99 -fno-common");
# C optimizations
Set("COPT" => '-O2');
-Append("COPT", '-march=$(CPU_ARCH)') if IsSet("CPU_ARCH");
+if (Get("CPU_ARCH") eq "") {
+ Warn "CPU type not recognized, using defaults, keep fingers crossed.";
+} else {
+ Append("COPT", '-march=$(CPU_ARCH)');
+}
# C optimizations for highly exposed code
Set("COPT2" => '-O3');
Append("LOPT" => "-s");
}
+if (IsSet("CONFIG_DARWIN")) {
+ # gcc-4.0 on Darwin doesn't set this in the gnu99 mode
+ Append("CLANG" => "-fnested-functions");
+ # Directory hierarchy of the fink project
+ Append("LIBS" => "-L/sw/lib");
+ Append("COPT" => "-I/sw/include");
+ # LFS is not supported, but all file functions are automatically 64-bit
+ UnSet("CONFIG_LFS");
+ # Fill in some constants not found in the system header files
+ Set("PAGE_SIZE" => `sysctl -n hw.pagesize`);
+ Set("SOL_TCP" => 6); #missing in /usr/include/netinet/tcp.h
+}
+
+if (!IsSet("CONFIG_LARGE_FILES")) {
+ UnSet("CONFIG_LFS");
+}
+
# Decide how will lib/partmap.c work
Set("PARTMAP_IS_MMAP") if IsSet("CPU_64BIT_POINTERS");