diff options
-rw-r--r-- | devel/cpuflags/Makefile | 25 | ||||
-rw-r--r-- | devel/cpuflags/files/cpuflags.1 | 38 | ||||
-rwxr-xr-x | devel/cpuflags/files/cpuflags.Linux | 18 | ||||
-rwxr-xr-x | devel/cpuflags/files/cpuflags.NetBSD | 58 | ||||
-rw-r--r-- | devel/cpuflags/pkg/DESCR | 2 | ||||
-rw-r--r-- | devel/cpuflags/pkg/PLIST | 3 |
6 files changed, 144 insertions, 0 deletions
diff --git a/devel/cpuflags/Makefile b/devel/cpuflags/Makefile new file mode 100644 index 00000000000..61eaa057a7e --- /dev/null +++ b/devel/cpuflags/Makefile @@ -0,0 +1,25 @@ +# $NetBSD: Makefile,v 1.1.1.1 2001/06/07 09:59:28 abs Exp $ +# + +DISTNAME= cpuflags-0.1 +CATEGORIES= sysutils +MASTER_SITES= # empty +DISTFILES= # empty + +MAINTAINER= abs@netbsd.org +COMMENT= Determine compiler flags to best target current cpu + +ONLY_FOR_PLATFORM= NetBSD-*-* Linux-*-* + +EXTRACT_ONLY= # empty +NO_WRKSUBDIR= yes +NO_CHECKSUM= yes +NO_PATCH= yes +NO_CONFIGURE= yes +NO_BUILD= yes + +do-install: + ${INSTALL_SCRIPT} ${FILESDIR}/cpuflags.${OPSYS} ${PREFIX}/bin/cpuflags + ${INSTALL_MAN} ${FILESDIR}/cpuflags.1 ${PREFIX}/man/man1/cpuflags.1 + +.include "../../mk/bsd.pkg.mk" diff --git a/devel/cpuflags/files/cpuflags.1 b/devel/cpuflags/files/cpuflags.1 new file mode 100644 index 00000000000..ea9a509f106 --- /dev/null +++ b/devel/cpuflags/files/cpuflags.1 @@ -0,0 +1,38 @@ +.\" $NetBSD: cpuflags.1,v 1.1.1.1 2001/06/07 09:59:28 abs Exp $ + +.Dd May 31, 2001 +.Dt CPUFLAGS 1 +.Os +.Sh NAME +.Nm cpuflags +.Nd determine compiler flags to best target current cpu +.Sh SYNOPSIS +.Nm +.Sh DESCRIPTION +.Nm +queries the current cpu type and gcc version, then outputs appropriate +compiler options to best target code for that cpu. If no options exist +to target the current cpu then nothing is output. +.Pp +In the event of the cpu not being recognised, a warning is sent to stderr. +.Pp +.Sh EXAMPLES +.Nm +can be used to set default flags for building entries from pkgsrc and +recompiling the NetBSD kernel or userland by adding the following to +.Pa /etc/mk.conf +.Bd -literal -offset indent + .if ! defined(CPU_FLAGS) && exists(/usr/pkg/bin/cpuflags) + CPU_FLAGS!=/usr/pkg/bin/cpuflags + MAKE_ENV+=CPU_FLAGS=${CPU_FLAGS} + CFLAGS+=${CPU_FLAGS} + CXXFLAGS+=${CPU_FLAGS} + .endif +.Ed +.Sh BUGS +.Nm +does not know about many cpu types yet - updates welcomed to <abs@netbsd.org> +.Pp +Currently +.Nm +is also gcc specific. diff --git a/devel/cpuflags/files/cpuflags.Linux b/devel/cpuflags/files/cpuflags.Linux new file mode 100755 index 00000000000..dad3176fbc2 --- /dev/null +++ b/devel/cpuflags/files/cpuflags.Linux @@ -0,0 +1,18 @@ +#!/bin/sh +# $NetBSD: cpuflags.Linux,v 1.1.1.1 2001/06/07 09:59:28 abs Exp $ + +hw_model=`uname -m` + +case $hw_model in + # i386 + i386*) FLAGS='-march=i386' ;; + i486*) FLAGS='-march=i486' ;; + i586*) FLAGS='-march=pentium' ;; + i686*) FLAGS='-march=pentiumpro' ;; + # + *) echo "Unknown hw.model '$hw_model'" >&2 +esac + +echo $FLAGS + +exit 0 diff --git a/devel/cpuflags/files/cpuflags.NetBSD b/devel/cpuflags/files/cpuflags.NetBSD new file mode 100755 index 00000000000..9f8157395f5 --- /dev/null +++ b/devel/cpuflags/files/cpuflags.NetBSD @@ -0,0 +1,58 @@ +#!/bin/sh +# $NetBSD: cpuflags.NetBSD,v 1.1.1.1 2001/06/07 09:59:28 abs Exp $ + +gcc_ver=`gcc -v 2>&1 | awk '/gcc version/ {print $3}'` +hw_model=`sysctl -n hw.model` + +case $gcc_ver in + egcs* ) + gcc_ver=2.8 ;; +esac + +if [ "$gcc_ver" \< 2.8 ];then # Old gcc, such as in NetBSD 1.3 + + case $hw_model in + # i386 + *386-class*) FLAGS='-mno-486' ;; + *486-class*) FLAGS='-m486' ;; + *586-class*) FLAGS='-m486' ;; + *686-class*) FLAGS='-m486' ;; + # + # sparc + MB86904* | MB86907*) FLAGS="-msupersparc" ;; # ss5 + TMS390Z50*) FLAGS="-msupersparc" ;; # ss10/ss20 + MB86930* | MB86934*) FLAGS="-msparclite" ;; # from gcc + MB86900/1A*) FLAGS="-mcypress" ;; # ss1+ + # + # arm + SA-110*) FLAGS="" ;; # shark + # + *) echo "Unknown hw.model '$hw_model'" >&2 + esac + +else # Modern gcc + + case $hw_model in + # i386 + *386-class*) FLAGS='-march=i386' ;; + *486-class*) FLAGS='-march=i486' ;; + *586-class*) FLAGS='-march=pentium' ;; + *686-class*) FLAGS='-march=pentiumpro' ;; + # + # sparc + MB86904* | MB86907*) FLAGS="-mcpu=supersparc" ;; # ss5 + TMS390Z50*) FLAGS="-mcpu=supersparc" ;; # ss10/ss20 + MB86930* | MB86934*) FLAGS="-mcpu=sparclite" ;; # from gcc + MB86900/1A*) FLAGS="-mcpu=cypress" ;; # ss1+ + # + # arm - commented until issue with identifying SA based RiscPCs solved + # SA-110*) FLAGS="-mcpu=strongarm110" ;; # shark + SA-110*) FLAGS="" ;; + # + *) echo "Unknown hw.model '$hw_model'" >&2 + esac + +fi +echo $FLAGS + +exit 0 diff --git a/devel/cpuflags/pkg/DESCR b/devel/cpuflags/pkg/DESCR new file mode 100644 index 00000000000..bd9da12fa8c --- /dev/null +++ b/devel/cpuflags/pkg/DESCR @@ -0,0 +1,2 @@ +cpuflags returns the appropriate gcc flags to optimise compilation for the +current CPU. diff --git a/devel/cpuflags/pkg/PLIST b/devel/cpuflags/pkg/PLIST new file mode 100644 index 00000000000..f051d357004 --- /dev/null +++ b/devel/cpuflags/pkg/PLIST @@ -0,0 +1,3 @@ +@comment $NetBSD: PLIST,v 1.1.1.1 2001/06/07 09:59:28 abs Exp $ +bin/cpuflags +man/man1/cpuflags.1 |