diff options
Diffstat (limited to 'ld')
-rwxr-xr-x | ld/config.sub | 680 |
1 files changed, 425 insertions, 255 deletions
diff --git a/ld/config.sub b/ld/config.sub index 58338df..dac9ab8 100755 --- a/ld/config.sub +++ b/ld/config.sub @@ -11,266 +11,436 @@ # Each package is responsible for reporting which valid configurations # it does not support. The user should be able to distinguish # a failure to support a valid configuration from a meaningless -# configuration. +# configuration (e.g. a typo). -# Separate what the user gave into CPU-company and OS (if any). -basic_machine=`echo $1 | sed 's/-[^-]*$//'` -if [ $basic_machine != $1 ] -then os=`echo $1 | sed 's/^.*-/-/'` -else os=; fi +# Please email any bugs, comments, and/or additions to this file to: +# configure@cygnus.com -# Decode aliases for certain machine-company combinations. -case $basic_machine in - # Recognize the basic CPU types without company name. - vax | tahoe | i386 | i860 | m68k | m68000 | m88k | sparc | ns32k \ - | alliant | arm | c1 | c2 | mips | pyramid | tron | a29k \ - | rtpc | rs6000 | i960 | none) - ;; - # Recognize the basic CPU types with company name. - vax-* | tahoe-* | i386-* | i860-* | m68k-* | m68000-* | m88k-* \ - | sparc-* | ns32k-* | alliant-* | arm-* | c1-* | c2-* \ - | mips-* | pyramid-* | tron-* | a29k-* | rtpc-* \ - | rs6000-* | i960-*) - ;; - # Recognize the machine names - # which stand for a CPU time and a company. - nindy960) - basic_machine=i960-intel - os=-nindy - ;; - vxworks68) - basic_machine=m68k-wrs - os=-vxworks - ;; - vxworks960) - basic_machine=i960-wrs - os=-vxworks - ;; - am29k) - basic_machine=a29k-unknown - os=-bsd - ;; - umax) - basic_machine=ns32k-umax - os=-sysv # maybe? - ;; - pn) - basic_machine=pn-gould - os=-sysv # maybe? - ;; - np1) - basic_machine=np1-gould - os=-sysv # maybe? - ;; - merlin) - basic_machine=merlin-utek - os=-sysv # maybe? - ;; - iris | iris4d) - basic_machine=mips-sgi - os=-sysv # maybe? - ;; - news1000) - basic_machine=m68030-sony - os=-sysv # maybe? - ;; - news | news700 | news800 | news900) - basic_machine=m68k-sony - os=-sysv # maybe? - ;; - unixpc | safari | pc7300 | 3b1 | 7300 | 7300-att | att-7300) - basic_machine=m68k-att - os=-sysv # maybe? - ;; - delta | 3300 | motorola-3300 | motorola-delta \ - | 3300-motorola | delta-motorola) - basic_machine=m68k-motorola - os=-sysv # maybe? - ;; - vax-dec) - basic_machine=vax - os=-ultrix # maybe? - ;; - balance) - basic_machine=ns32k-sequent - os=-dynix - ;; - mmax) - basic_machine=ns32k-encore - os=-sysv # maybe? - ;; - symmetry) - basic_machine=i386-sequent - os=-dynix - ;; - sun2) - basic_machine=m68000-sun - os=-sunos4 - ;; - sun2os3) - basic_machine=m68000-sun - os=-sunos3 - ;; - sun2os4) - basic_machine=m68000-sun - os=-sunos4 - ;; - sun3) - basic_machine=m68k-sun - os=-sunos4 - ;; - sun3os3) - basic_machine=m68k-sun - os=-sunos3 - ;; - sun3os4) - basic_machine=m68k-sun - os=-sunos4 - ;; - sun4) - basic_machine=sparc-sun - os=-sunos4 - ;; - sun4os3) - basic_machine=sparc-sun - os=-sunos3 - ;; - sun4os4) - basic_machine=sparc-sun - os=-sunos4 - ;; - pbd) - basic_machine=sparc-unicom - os=-sysv - ;; - roadrunner | sun386 | sun386i) - basic_machine=i386-sun - os=-sunos - ;; - ps2) - basic_machine=i386-ibm - os=-sysv # maybe? - ;; - i386sco) - basic_machine=i386-sco - os=-sysv # maybe? - ;; - i386v) - basic_machine=i386-unknown - os=-sysv - ;; - i386v32) - basic_machine=i386-unknown - os=-sysv32 - ;; - next) - basic_machine=m68k-next - os=-sysv # maybe? - ;; - hp300bsd) - basic_machine=m68k-hp - os=-bsd - ;; - hp300hpux | hpux | hp9k3[2-9][0-9]) - basic_machine=m68k-hp - os=-hpux - ;; - hp9k31[0-9] | hp9k2[0-9][0-9]) - basic_machine=m68000-hp - os=-hpux - ;; - isi | isi68) - basic_machine=m68k-isi - os=-sysv # maybe? - ;; - apollo68) - basic_machine=m68k-apollo - os=-sysv # maybe? - ;; - altos | altos3068) - basic_machine=m68k-altos - os=-sysv # maybe? - ;; - altosgas) - basic_machine=m68k-altos - os=-gas - ;; - miniframe) - basic_machine=m68000-convergent - os=-sysv # maybe? - ;; - tower | tower-32) - basic_machine=m68k-ncr - os=-sysv # maybe? - ;; - bigmips | news-3600 | risc-news) - basic_machine=mips-sony - os=-newsos # maybe? - ;; - littlemips) - basic_machine=mips-little - os=-bsd - ;; - dec3100 | decstatn | decstation | decstation-3100 | pmax) - basic_machine=mips-dec - os=-ultrix - ;; - magnum | m3230) - basic_machine=mips-mips - os=-sysv # maybe? - ;; - gmicro) - basic_machine=tron - os=-sysv # maybe? - ;; - convex-c1) - basic_machine=c1-convex - os=-sysv # maybe? - ;; - convex-c2) - basic_machine=c2-convex - os=-sysv # maybe? - ;; - *) - echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 +# decode aliases into canonical names + +case "$1" in +# cpu alone is a valid alias for cpu-none-none. +vax | tahoe | i386 | i860 | m68k | m68000 | m88k | sparc | ns32k \ + | alliant | arm | c1 | c2 | mips | pyramid | tron | a29k \ + | romp | rs6000 | i960 | h8300) + cpu=$1 + vendor=none + os=none + ;; +altos | altos3068) + cpu=m68k + vendor=altos + os=sysv # maybe? + ;; +altosgas) + cpu=m68k + vendor=altos + os=gas + ;; +am29k) + cpu=a29k + vendor=none + os=bsd + ;; +amdahl) + cpu=580 + vendor=amdahl + os=uts + ;; +amigados) + cpu=m68k + vendor=cbm + os=amigados # Native AmigaDOS + ;; +amigaunix | amix) + cpu=m68k + vendor=cbm + os=svr4 # System V Release 4 (svr4 is an industry recognized acronym) + ;; +apollo68) + cpu=m68k + vendor=apollo + os=sysv # maybe? + ;; +balance) + cpu=ns32k + vendor=sequent + os=dynix + ;; +convex-c1) + cpu=c1 + vendor=convex + os=sysv # maybe? + ;; +convex-c2) + cpu=c2 + vendor=convex + os=sysv # maybe? + ;; +cray | ymp) + cpu=ymp + vendor=cray + os=unicos + ;; +cray2) + cpu=cray2 + vendor=cray + os=unicos + ;; +dec3100 | decstatn | decstation | decstation-3100 | pmax | pmin) + cpu=mips + vendor=dec + os=ultrix + ;; +delta | 3300 | motorola-3300 | motorola-delta \ + | 3300-motorola | delta-motorola) + cpu=m68k + vendor=motorola + os=sysv # maybe? + ;; + +delta88) + cpu=m88k + vendor=motorola + os=m88kbcs + ;; + +gmicro) + cpu=tron + vendor=gmicro + os=sysv # maybe? + ;; + +h8300hds) + cpu=h8300 + vendor=hitachi + os=hds + ;; + +# start-sanitize-v9 +hal-32 | hal32) + cpu=sparc64 + vendor=hal + os=hal32 + ;; +hal-64 | hal64) + cpu=sparc64 + vendor=hal + os=hal64 + ;; +sparc64) + cpu=sparc64 + vendor=sun + os=v9 + ;; +sparc64-v7 | sparc64v7) + cpu=sparc64 + vendor=sun + os=v7 + ;; +# end-sanitize-v9 +hp300bsd) + cpu=m68k + vendor=hp + os=bsd + ;; +hp300hpux | hpux | hp9k3[2-9][0-9]) + cpu=m68k + vendor=hp + os=hpux + ;; +hp9k31[0-9] | hp9k2[0-9][0-9]) + cpu=m68000 + vendor=hp + os=hpux + ;; +i386sco) + cpu=i386 + vendor=sco + os=sysv # maybe? + ;; +i386v) + cpu=i386 + vendor=none + os=sysv + ;; +i386v32) + cpu=i386 + vendor=none + os=sysv32 + ;; +iris | iris4d) + cpu=mips + vendor=sgi + os=irix # maybe? + ;; + +dpx2) + vendor=bull + cpu=m68k + os=sysv + ;; +isi | isi68) + cpu=m68k + vendor=isi + os=sysv # maybe? + ;; +littlemips) + cpu=mips + vendor=little + os=bsd + ;; +magnum | m3230) + cpu=mips + vendor=mips + os=sysv # maybe? + ;; +merlin) + cpu=ns32k + vendor=utek + os=sysv # maybe? + ;; +miniframe) + cpu=m68000 + vendor=convergent + os=sysv # maybe? + ;; +mmax) + cpu=ns32k + vendor=encore + os=sysv # maybe? + ;; +news | news700 | news800 | news900) + cpu=m68k + vendor=sony + os=newsos3 # Based on bsd-4.3 + ;; +news1000) + cpu=m68030 + vendor=sony + os=newsos3 # ? + ;; +news-3600 | bigmips | risc-news) + cpu=mips + vendor=sony + os=newsos4 # Presumably? + ;; +next) + cpu=m68k + vendor=next + os=sysv # maybe? + ;; +nindy960) + cpu=i960 + vendor=intel + os=nindy + ;; +none) + cpu=none + vendor=none + os=none + ;; +np1) + cpu=np1 + vendor=gould + os=sysv # maybe? + ;; +rtpc) + cpu=romp + vendor=ibm + os=aix # maybe? + ;; +pbd) + cpu=sparc + vendor=unicom + os=sysv + ;; +pn) + cpu=pn + vendor=gould + os=sysv # maybe? + ;; +ps2) + cpu=i386 + vendor=ibm + os=sysv # maybe? + ;; +sun2) + cpu=m68000 + vendor=sun + os=sunos4 + ;; +sun2os3) + cpu=m68000 + vendor=sun + os=sunos3 + ;; +sun2os4) + cpu=m68000 + vendor=sun + os=sunos4 + ;; +sun3) + cpu=m68k + vendor=sun + os=sunos4 + ;; +sun3os3) + cpu=m68k + vendor=sun + os=sunos3 + ;; +sun3os4) + cpu=m68k + vendor=sun + os=sunos4 + ;; +sun386 | roadrunner | sun386i) + cpu=i386 + vendor=sun + os=sunos + ;; +sun4) + cpu=sparc + vendor=sun + os=sunos4 + ;; +sun4os3) + cpu=sparc + vendor=sun + os=sunos3 + ;; +sun4os4) + cpu=sparc + vendor=sun + os=sunos4 + ;; +symmetry) + cpu=i386 + vendor=sequent + os=dynix + ;; +tower | tower-32) + cpu=m68k + vendor=ncr + os=sysv # maybe? + ;; +ultra3) + cpu=a29k + vendor=nyu + os=sym1 + ;; +umax) + cpu=ns32k + vendor=encore + os=sysv # maybe? + ;; +unixpc | safari | pc7300 | 3b1 | 7300 | 7300-att | att-7300) + cpu=m68k + vendor=att + os=sysv # maybe? + ;; +vax-dec) + cpu=vax + vendor=dec + os=ultrix # maybe? + ;; +vxworks68) + cpu=m68k + vendor=wrs + os=vxworks + ;; +vxworks960) + cpu=i960 + vendor=wrs + os=vxworks + ;; +xmp) + cpu=xmp + vendor=cray + os=unicos + ;; +# not an alias. parse what we expect to be a canonical name. +*) + cpu=`echo $1 | sed 's/-.*$//'` + + if [ "${cpu}" = "$1" ] ; then + # no vendor so this is an invalid name. + echo '***' No vendor: configuration \`$1\' not recognized 1>&2 exit 1 - ;; + else + # parse out vendor + rest=`echo $1 | sed "s/${cpu}-//"` + vendor=`echo ${rest} | sed 's/-.*$//'` + + if [ "${vendor}" = "${rest}" ] ; then + # a missing os is acceptable + os=none + else + os=`echo ${rest} | sed "s/${vendor}-//"` + fi + fi + ;; esac -# Decode manufacturer-specific aliases for certain operating systems. +# At this point we should have three parts of a canonical name in cpu, +# vendor, and os. -case $os in - # First accept the basic system types. - # The portable systems comes first. - -bsd* | -sysv* | -mach* \ - | -vms* | -sco* | -esix* | -isc* | -aix* | -sunos* | -hpux* \ - | -unos* | -osf* | -v88r* | -aout | -coff | -bout \ - | -nindy | -vxworks) - ;; - -newsos*) - os=-bsd - ;; - -ultrix*) - os=-bsd - ;; - -osfrose*) - os=-osf - ;; - -osf*) - os=-bsd - ;; - -dynix*) - os=-bsd - ;; - -ctix*) - os=-sysv - ;; - *) - # Get rid of the `-' at the beginning of $os. - os=`echo $1 | sed 's/[^-]*-//'` - echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 - exit 1 - ;; +# verify that the cpu is known. + +case "${cpu}" in +none | vax | tahoe | i386 | i860 | m68k | m68000 | m88k | sparc \ + | ns32k | alliant | arm | c1 | c2 | mips | pyramid | tron \ + | a29k | romp | rs6000 | i960 | xmp | ymp | cray2 | 580 | h8300) + ;; + +# start-sanitize-v9 +sparc64) ;; +# end-sanitize-v9 + +*) + echo '***' Invalid cpu \`${cpu}\': configuration \`$1\' not recognized 1>&2 + exit 1 + ;; +esac + +# verify that the vendor is known. + +case "${vendor}" in + altos | amdahl | aout | apollo | att | bcs | bout |\ + cbm | convergent | convex | coff | cray | dec | encore |\ + gould | hitachi | intel | isi | hp | ibm | little | mips | motorola |\ + ncr | next | none | nyu | sco | sequent | sgi | sony | sun |\ + unicom | utek | wrs | bull ) ;; + +# start-sanitize-v9 +hal) ;; +# end-sanitize-v9 + +*) + echo '***' Invalid vendor \`${vendor}\': configuration \`$1\' not recognized 1>&2 + exit 1 + ;; +esac + +# verify that the os is known, if it exists. + +case "${os}" in +aix* | aout | bout | bsd* | coff | ctix* | dynix* | esix* | hpux* \ + | hds | irix* | isc* | kern | mach* | newsos* | nindy* | none \ + | osf* | sco* | sunos* | sysv* | ultrix* | unos* | v88r* \ + | vms* | vxworks* | sym[1-9]* | unicos* | uts | svr4 \ + | amigados) + ;; + +# start-sanitize-v9 +hal32 | hal64 | v7 | v9) ;; +# end-sanitize-v9 + +*) + echo '***' Invalid os \`${os}\': configuration \`$1\' not recognized 1>&2 + exit 1 + ;; esac -echo ${basic_machine}${os} +echo ${cpu}-${vendor}-${os} |