|  | @@ -4,7 +4,7 @@
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  # shellcheck disable=SC2006,SC2268 # see below for rationale
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -timestamp='2023-07-31'
 | 
	
		
			
				|  |  | +timestamp='2023-09-19'
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  # This file is free software; you can redistribute it and/or modify it
 | 
	
		
			
				|  |  |  # under the terms of the GNU General Public License as published by
 | 
	
	
		
			
				|  | @@ -1181,7 +1181,7 @@ case $cpu-$vendor in
 | 
	
		
			
				|  |  |  		case $cpu in
 | 
	
		
			
				|  |  |  			1750a | 580 \
 | 
	
		
			
				|  |  |  			| a29k \
 | 
	
		
			
				|  |  | -			| aarch64 | aarch64_be \
 | 
	
		
			
				|  |  | +			| aarch64 | aarch64_be | aarch64c | arm64ec \
 | 
	
		
			
				|  |  |  			| abacus \
 | 
	
		
			
				|  |  |  			| alpha | alphaev[4-8] | alphaev56 | alphaev6[78] \
 | 
	
		
			
				|  |  |  			| alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] \
 | 
	
	
		
			
				|  | @@ -1200,6 +1200,7 @@ case $cpu-$vendor in
 | 
	
		
			
				|  |  |  			| d10v | d30v | dlx | dsp16xx \
 | 
	
		
			
				|  |  |  			| e2k | elxsi | epiphany \
 | 
	
		
			
				|  |  |  			| f30[01] | f700 | fido | fr30 | frv | ft32 | fx80 \
 | 
	
		
			
				|  |  | +			| javascript \
 | 
	
		
			
				|  |  |  			| h8300 | h8500 \
 | 
	
		
			
				|  |  |  			| hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
 | 
	
		
			
				|  |  |  			| hexagon \
 | 
	
	
		
			
				|  | @@ -1284,11 +1285,12 @@ esac
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  # Decode manufacturer-specific aliases for certain operating systems.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -if test x$basic_os != x
 | 
	
		
			
				|  |  | +if test x"$basic_os" != x
 | 
	
		
			
				|  |  |  then
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  # First recognize some ad-hoc cases, or perhaps split kernel-os, or else just
 | 
	
		
			
				|  |  |  # set os.
 | 
	
		
			
				|  |  | +obj=
 | 
	
		
			
				|  |  |  case $basic_os in
 | 
	
		
			
				|  |  |  	gnu/linux*)
 | 
	
		
			
				|  |  |  		kernel=linux
 | 
	
	
		
			
				|  | @@ -1488,10 +1490,16 @@ case $os in
 | 
	
		
			
				|  |  |  			os=eabi
 | 
	
		
			
				|  |  |  			;;
 | 
	
		
			
				|  |  |  		    *)
 | 
	
		
			
				|  |  | -			os=elf
 | 
	
		
			
				|  |  | +			os=
 | 
	
		
			
				|  |  | +			obj=elf
 | 
	
		
			
				|  |  |  			;;
 | 
	
		
			
				|  |  |  		esac
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | +	aout* | coff* | elf* | pe*)
 | 
	
		
			
				|  |  | +		# These are machine code file formats, not OSes
 | 
	
		
			
				|  |  | +		obj=$os
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  |  	*)
 | 
	
		
			
				|  |  |  		# No normalization, but not necessarily accepted, that comes below.
 | 
	
		
			
				|  |  |  		;;
 | 
	
	
		
			
				|  | @@ -1510,12 +1518,15 @@ else
 | 
	
		
			
				|  |  |  # system, and we'll never get to this point.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  kernel=
 | 
	
		
			
				|  |  | +obj=
 | 
	
		
			
				|  |  |  case $cpu-$vendor in
 | 
	
		
			
				|  |  |  	score-*)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	spu-*)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	*-acorn)
 | 
	
		
			
				|  |  |  		os=riscix1.2
 | 
	
	
		
			
				|  | @@ -1525,28 +1536,35 @@ case $cpu-$vendor in
 | 
	
		
			
				|  |  |  		os=gnu
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	arm*-semi)
 | 
	
		
			
				|  |  | -		os=aout
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=aout
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	c4x-* | tic4x-*)
 | 
	
		
			
				|  |  | -		os=coff
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=coff
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	c8051-*)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	clipper-intergraph)
 | 
	
		
			
				|  |  |  		os=clix
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	hexagon-*)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	tic54x-*)
 | 
	
		
			
				|  |  | -		os=coff
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=coff
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	tic55x-*)
 | 
	
		
			
				|  |  | -		os=coff
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=coff
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	tic6x-*)
 | 
	
		
			
				|  |  | -		os=coff
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=coff
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	# This must come before the *-dec entry.
 | 
	
		
			
				|  |  |  	pdp10-*)
 | 
	
	
		
			
				|  | @@ -1568,19 +1586,24 @@ case $cpu-$vendor in
 | 
	
		
			
				|  |  |  		os=sunos3
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	m68*-cisco)
 | 
	
		
			
				|  |  | -		os=aout
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=aout
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	mep-*)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	mips*-cisco)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	mips*-*)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	or32-*)
 | 
	
		
			
				|  |  | -		os=coff
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=coff
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	*-tti)	# must be before sparc entry or we get the wrong os.
 | 
	
		
			
				|  |  |  		os=sysv3
 | 
	
	
		
			
				|  | @@ -1589,7 +1612,8 @@ case $cpu-$vendor in
 | 
	
		
			
				|  |  |  		os=sunos4.1.1
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	pru-*)
 | 
	
		
			
				|  |  | -		os=elf
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=elf
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	*-be)
 | 
	
		
			
				|  |  |  		os=beos
 | 
	
	
		
			
				|  | @@ -1670,10 +1694,12 @@ case $cpu-$vendor in
 | 
	
		
			
				|  |  |  		os=uxpv
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	*-rom68k)
 | 
	
		
			
				|  |  | -		os=coff
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=coff
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	*-*bug)
 | 
	
		
			
				|  |  | -		os=coff
 | 
	
		
			
				|  |  | +		os=
 | 
	
		
			
				|  |  | +		obj=coff
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  	*-apple)
 | 
	
		
			
				|  |  |  		os=macos
 | 
	
	
		
			
				|  | @@ -1691,7 +1717,8 @@ esac
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  fi
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -# Now, validate our (potentially fixed-up) OS.
 | 
	
		
			
				|  |  | +# Now, validate our (potentially fixed-up) individual pieces (OS, OBJ).
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  case $os in
 | 
	
		
			
				|  |  |  	# Sometimes we do "kernel-libc", so those need to count as OSes.
 | 
	
		
			
				|  |  |  	musl* | newlib* | relibc* | uclibc*)
 | 
	
	
		
			
				|  | @@ -1702,6 +1729,9 @@ case $os in
 | 
	
		
			
				|  |  |  	# VxWorks passes extra cpu info in the 4th filed.
 | 
	
		
			
				|  |  |  	simlinux | simwindows | spe)
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | +	# See `case $cpu-$os` validation below
 | 
	
		
			
				|  |  | +	ghcjs)
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  |  	# Now accept the basic system types.
 | 
	
		
			
				|  |  |  	# The portable systems comes first.
 | 
	
		
			
				|  |  |  	# Each alternative MUST end in a * to match a version number.
 | 
	
	
		
			
				|  | @@ -1719,11 +1749,11 @@ case $os in
 | 
	
		
			
				|  |  |  	     | mirbsd* | netbsd* | dicos* | openedition* | ose* \
 | 
	
		
			
				|  |  |  	     | bitrig* | openbsd* | secbsd* | solidbsd* | libertybsd* | os108* \
 | 
	
		
			
				|  |  |  	     | ekkobsd* | freebsd* | riscix* | lynxos* | os400* \
 | 
	
		
			
				|  |  | -	     | bosx* | nextstep* | cxux* | aout* | elf* | oabi* \
 | 
	
		
			
				|  |  | -	     | ptx* | coff* | ecoff* | winnt* | domain* | vsta* \
 | 
	
		
			
				|  |  | +	     | bosx* | nextstep* | cxux* | oabi* \
 | 
	
		
			
				|  |  | +	     | ptx* | ecoff* | winnt* | domain* | vsta* \
 | 
	
		
			
				|  |  |  	     | udi* | lites* | ieee* | go32* | aux* | hcos* \
 | 
	
		
			
				|  |  |  	     | chorusrdb* | cegcc* | glidix* | serenity* \
 | 
	
		
			
				|  |  | -	     | cygwin* | msys* | pe* | moss* | proelf* | rtems* \
 | 
	
		
			
				|  |  | +	     | cygwin* | msys* | moss* | proelf* | rtems* \
 | 
	
		
			
				|  |  |  	     | midipix* | mingw32* | mingw64* | mint* \
 | 
	
		
			
				|  |  |  	     | uxpv* | beos* | mpeix* | udk* | moxiebox* \
 | 
	
		
			
				|  |  |  	     | interix* | uwin* | mks* | rhapsody* | darwin* \
 | 
	
	
		
			
				|  | @@ -1747,60 +1777,95 @@ case $os in
 | 
	
		
			
				|  |  |  	kernel* | msvc* )
 | 
	
		
			
				|  |  |  		# Restricted further below
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | +	'')
 | 
	
		
			
				|  |  | +		if test x"$obj" = x
 | 
	
		
			
				|  |  | +		then
 | 
	
		
			
				|  |  | +			echo "Invalid configuration '$1': Blank OS only allowed with explicit machine code file format" 1>&2
 | 
	
		
			
				|  |  | +		fi
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  |  	*)
 | 
	
		
			
				|  |  |  		echo "Invalid configuration '$1': OS '$os' not recognized" 1>&2
 | 
	
		
			
				|  |  |  		exit 1
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  esac
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +case $obj in
 | 
	
		
			
				|  |  | +	aout* | coff* | elf* | pe*)
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  | +	'')
 | 
	
		
			
				|  |  | +		# empty is fine
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  | +	*)
 | 
	
		
			
				|  |  | +		echo "Invalid configuration '$1': Machine code format '$obj' not recognized" 1>&2
 | 
	
		
			
				|  |  | +		exit 1
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  | +esac
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +# Here we handle the constraint that a (synthetic) cpu and os are
 | 
	
		
			
				|  |  | +# valid only in combination with each other and nowhere else.
 | 
	
		
			
				|  |  | +case $cpu-$os in
 | 
	
		
			
				|  |  | +	# The "javascript-unknown-ghcjs" triple is used by GHC; we
 | 
	
		
			
				|  |  | +	# accept it here in order to tolerate that, but reject any
 | 
	
		
			
				|  |  | +	# variations.
 | 
	
		
			
				|  |  | +	javascript-ghcjs)
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  | +	javascript-* | *-ghcjs)
 | 
	
		
			
				|  |  | +		echo "Invalid configuration '$1': cpu '$cpu' is not valid with os '$os$obj'" 1>&2
 | 
	
		
			
				|  |  | +		exit 1
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  | +esac
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  # As a final step for OS-related things, validate the OS-kernel combination
 | 
	
		
			
				|  |  |  # (given a valid OS), if there is a kernel.
 | 
	
		
			
				|  |  | -case $kernel-$os in
 | 
	
		
			
				|  |  | -	linux-gnu* | linux-dietlibc* | linux-android* | linux-newlib* \
 | 
	
		
			
				|  |  | -		   | linux-musl* | linux-relibc* | linux-uclibc* | linux-mlibc* )
 | 
	
		
			
				|  |  | +case $kernel-$os-$obj in
 | 
	
		
			
				|  |  | +	linux-gnu*- | linux-dietlibc*- | linux-android*- | linux-newlib*- \
 | 
	
		
			
				|  |  | +		   | linux-musl*- | linux-relibc*- | linux-uclibc*- | linux-mlibc*- )
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	uclinux-uclibc* )
 | 
	
		
			
				|  |  | +	uclinux-uclibc*- )
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	managarm-mlibc* | managarm-kernel* )
 | 
	
		
			
				|  |  | +	managarm-mlibc*- | managarm-kernel*- )
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	windows*-gnu* | windows*-msvc*)
 | 
	
		
			
				|  |  | +	windows*-msvc*-)
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	-dietlibc* | -newlib* | -musl* | -relibc* | -uclibc* | -mlibc* )
 | 
	
		
			
				|  |  | +	-dietlibc*- | -newlib*- | -musl*- | -relibc*- | -uclibc*- | -mlibc*- )
 | 
	
		
			
				|  |  |  		# These are just libc implementations, not actual OSes, and thus
 | 
	
		
			
				|  |  |  		# require a kernel.
 | 
	
		
			
				|  |  |  		echo "Invalid configuration '$1': libc '$os' needs explicit kernel." 1>&2
 | 
	
		
			
				|  |  |  		exit 1
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	-kernel* )
 | 
	
		
			
				|  |  | +	-kernel*- )
 | 
	
		
			
				|  |  |  		echo "Invalid configuration '$1': '$os' needs explicit kernel." 1>&2
 | 
	
		
			
				|  |  |  		exit 1
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	*-kernel* )
 | 
	
		
			
				|  |  | +	*-kernel*- )
 | 
	
		
			
				|  |  |  		echo "Invalid configuration '$1': '$kernel' does not support '$os'." 1>&2
 | 
	
		
			
				|  |  |  		exit 1
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	*-msvc* )
 | 
	
		
			
				|  |  | +	*-msvc*- )
 | 
	
		
			
				|  |  |  		echo "Invalid configuration '$1': '$os' needs 'windows'." 1>&2
 | 
	
		
			
				|  |  |  		exit 1
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	kfreebsd*-gnu* | kopensolaris*-gnu*)
 | 
	
		
			
				|  |  | +	kfreebsd*-gnu*- | kopensolaris*-gnu*-)
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	vxworks-simlinux | vxworks-simwindows | vxworks-spe)
 | 
	
		
			
				|  |  | +	vxworks-simlinux- | vxworks-simwindows- | vxworks-spe-)
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	nto-qnx*)
 | 
	
		
			
				|  |  | +	nto-qnx*-)
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	os2-emx)
 | 
	
		
			
				|  |  | +	os2-emx-)
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	*-eabi* | *-gnueabi*)
 | 
	
		
			
				|  |  | +	*-eabi*- | *-gnueabi*-)
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	none-coff* | none-elf*)
 | 
	
		
			
				|  |  | +	none--*)
 | 
	
		
			
				|  |  |  		# None (no kernel, i.e. freestanding / bare metal),
 | 
	
		
			
				|  |  | -		# can be paired with an output format "OS"
 | 
	
		
			
				|  |  | +		# can be paired with an machine code file format
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	-*)
 | 
	
		
			
				|  |  | +	-*-)
 | 
	
		
			
				|  |  |  		# Blank kernel with real OS is always fine.
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  | -	*-*)
 | 
	
		
			
				|  |  | +	--*)
 | 
	
		
			
				|  |  | +		# Blank kernel and OS with real machine code file format is always fine.
 | 
	
		
			
				|  |  | +		;;
 | 
	
		
			
				|  |  | +	*-*-*)
 | 
	
		
			
				|  |  |  		echo "Invalid configuration '$1': Kernel '$kernel' not known to work with OS '$os'." 1>&2
 | 
	
		
			
				|  |  |  		exit 1
 | 
	
		
			
				|  |  |  		;;
 | 
	
	
		
			
				|  | @@ -1884,7 +1949,7 @@ case $vendor in
 | 
	
		
			
				|  |  |  		;;
 | 
	
		
			
				|  |  |  esac
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -echo "$cpu-$vendor-${kernel:+$kernel-}$os"
 | 
	
		
			
				|  |  | +echo "$cpu-$vendor${kernel:+-$kernel}${os:+-$os}${obj:+-$obj}"
 | 
	
		
			
				|  |  |  exit
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  # Local variables:
 |