2
0
mirror of https://github.com/boostorg/build.git synced 2026-02-15 13:02:11 +00:00

Add arm/arm64 target support in clang-win config (#74)

This commit is contained in:
Volo Zyko
2021-08-16 06:26:30 +03:00
committed by GitHub
parent 37622df644
commit 320c2b2ed5

View File

@@ -93,102 +93,149 @@ rule init ( version ? : command * : options * )
for local addr in 32 64
{
local config = [ SPLIT_BY_CHARACTERS [ SHELL "$(compiler) -m$(addr) -### foo.obj /link 2>&1" ] : "\n" ] ;
local match = 1 ;
local items ;
while $(match)
for local arch in x86 arm
{
match = [ MATCH "^ *(\"[^\"]*\")(.*)" : $(config) ] ;
if $(match)
local clang-arch ;
if $(arch) = x86
{
items += $(match[1]) ;
config = $(match[2]) ;
if $(addr) = 32 { clang-arch = i386 ; } else { clang-arch = x86_64 ; }
}
}
local ml ;
if $(items)
{
ml = [ regex.replace $(items[1]) "x64\\\\+link\\.exe" "x64\\ml64.exe" ] ;
ml = [ regex.replace $(ml) "x86\\\\+link\\.exe" "x86\\ml.exe" ] ;
if ! [ MATCH "(ml\\.exe)" "(ml64\\.exe)" : $(ml) ]
else if $(arch) = arm
{
ml = ;
if $(addr) = 32 { clang-arch = arm ; } else { clang-arch = aarch64 ; }
}
}
local assembler = [ get-option "assembler" : $(addr) : $(options) ] ;
assembler ?= $(ml) ;
if $(addr) = 32 { assembler ?= ml.exe ; } else { assembler ?= ml64.exe ; }
local config = [ SPLIT_BY_CHARACTERS [ SHELL "$(compiler) --target=$(clang-arch)-pc-windows-msvc -### foo.obj /link 2>&1" ] : "\n" ] ;
local link ;
local match = 1 ;
local items ;
if $(items)
{
link = [ regex.replace $(items[1]) "\\\\+HostX64\\\\+x86\\\\+" "\\HostX86\\x86\\" ] ;
}
local archiver = [ get-option "archiver" : $(addr) : $(options) ] ;
if $(link)
{
archiver ?= "$(link) /lib" ;
}
archiver ?= lib.exe ;
.notice "$(addr):" "using assembler '$(assembler)'" ;
.notice "$(addr):" "using archiver '$(archiver)'" ;
local manifest-tool = [ get-option "manifest-tool" : $(addr) : $(options) ] ;
local resource-compiler = [ get-option "resource-compiler" : $(addr) : $(options) ] ;
local mc-compiler = [ get-option "mc-compiler" : $(addr) : $(options) ] ;
local idl-compiler = [ get-option "idl-compiler" : $(addr) : $(options) ] ;
for local item in $(items)
{
match = [ MATCH "\"-libpath:(.*)\\\\+Lib\\\\.*\\\\um\\\\+x(.*)\"" : $(item) ] ;
if $(match)
while $(match)
{
local sdk-path = "$(match[1])\\bin\\x$(match[2])" ;
.notice "$(addr):" "using SDK path '$(sdk-path)'" ;
match = [ MATCH "^ *(\"[^\"]*\")(.*)" : $(config) ] ;
manifest-tool ?= "\"$(sdk-path)\\mt.exe\"" ;
resource-compiler ?= "\"$(sdk-path)\\rc.exe\"" ;
mc-compiler ?= "\"$(sdk-path)\\mc.exe\"" ;
idl-compiler ?= "\"$(sdk-path)\\midl.exe\"" ;
if $(match)
{
items += $(match[1]) ;
config = $(match[2]) ;
}
}
local asm ;
if $(items)
{
asm = [ regex.replace $(items[1]) "x64\\\\+link\\.exe" "x64\\ml64.exe" ] ;
asm = [ regex.replace $(asm) "x86\\\\+link\\.exe" "x86\\ml.exe" ] ;
asm = [ regex.replace $(asm) "arm64\\\\+link\\.exe" "arm64\\armasm64.exe" ] ;
asm = [ regex.replace $(asm) "arm\\\\+link\\.exe" "arm\\armasm.exe" ] ;
if ! [ MATCH "(ml\\.exe)" "(ml64\\.exe)" "(armasm64\\.exe)" "(armasm\\.exe)" : $(asm) ]
{
asm = ;
}
}
local assembler = [ get-option "assembler" : $(addr) : $(options) ] ;
assembler ?= $(asm) ;
if $(arch) = x86
{
if $(addr) = 32 { assembler ?= ml.exe ; } else { assembler ?= ml64.exe ; }
}
else if $(arch) = arm
{
if $(addr) = 32 { assembler ?= armasm.exe ; } else { assembler ?= armasm64.exe ; }
}
local linker ;
if $(items)
{
linker = [ regex.replace $(items[1]) "\\\\+HostX64\\\\+x86\\\\+" "\\HostX86\\x86\\" ] ;
}
.notice "$(arch)-$(addr):" "using linker '$(linker)'" ;
local archiver = [ get-option "archiver" : $(addr) : $(options) ] ;
if $(linker)
{
archiver ?= "$(linker) /lib" ;
}
archiver ?= lib.exe ;
.notice "$(arch)-$(addr):" "using assembler '$(assembler)'" ;
.notice "$(arch)-$(addr):" "using archiver '$(archiver)'" ;
local manifest-tool = [ get-option "manifest-tool" : $(addr) : $(options) ] ;
local resource-compiler = [ get-option "resource-compiler" : $(addr) : $(options) ] ;
local mc-compiler = [ get-option "mc-compiler" : $(addr) : $(options) ] ;
local idl-compiler = [ get-option "idl-compiler" : $(addr) : $(options) ] ;
for local item in $(items)
{
match = [ MATCH "\"-libpath:(.*)\\\\+Lib\\\\.*\\\\um\\\\+x(.*)\"" : $(item) ] ;
if $(match)
{
local sdk-path = "$(match[1])\\bin\\x$(match[2])" ;
.notice "$(arch)-$(addr):" "using SDK path '$(sdk-path)'" ;
manifest-tool ?= "\"$(sdk-path)\\mt.exe\"" ;
resource-compiler ?= "\"$(sdk-path)\\rc.exe\"" ;
mc-compiler ?= "\"$(sdk-path)\\mc.exe\"" ;
idl-compiler ?= "\"$(sdk-path)\\midl.exe\"" ;
}
}
manifest-tool ?= mt.exe ;
resource-compiler ?= rc.exe ;
mc-compiler ?= mc.exe ;
idl-compiler ?= midl.exe ;
.notice "$(arch)-$(addr):" "using manifest-tool '$(manifest-tool)'" ;
.notice "$(arch)-$(addr):" "using resource-compiler '$(resource-compiler)'" ;
.notice "$(arch)-$(addr):" "using mc-compiler '$(mc-compiler)'" ;
.notice "$(arch)-$(addr):" "using idl-compiler '$(idl-compiler)'" ;
local linker-arch ;
if $(arch) = x86
{
if $(addr) = 32 { linker-arch = x86 ; } else { linker-arch = x64 ; }
}
else if $(arch) = arm
{
if $(addr) = 32 { linker-arch = arm ; } else { linker-arch = arm64 ; }
}
local cond = "$(condition)/<architecture>$(arch)/<address-model>$(addr)" ;
if $(addr) = $(default-addr) && $(arch) = x86
{
cond += "$(condition)/<architecture>/<address-model>" ;
cond += "$(condition)/<architecture>/<address-model>$(addr)" ;
cond += "$(condition)/<architecture>$(arch)/<address-model>" ;
}
toolset.flags clang-win.compile .CC $(cond) : $(compiler) --target=$(clang-arch)-pc-windows-msvc ;
toolset.flags clang-win.link .LD $(cond) : $(linker) /nologo "/machine:$(linker-arch)" ;
toolset.flags clang-win.link LINKOPT $(cond) : ;
toolset.flags clang-win.link LINKFLAGS $(cond) : "/incremental:no" "/manifest" ;
if $(arch) = x86
{
toolset.flags clang-win.compile .ASM $(cond) : $(assembler) -nologo -c -Zp4 -Cp -Cx ;
toolset.flags clang-win.compile .ASM_OUTPUT $(cond) : -Fo ;
}
else if $(arch) = arm
{
toolset.flags clang-win.compile .ASM $(cond) : $(assembler) -machine $(arch) ;
toolset.flags clang-win.compile .ASM_OUTPUT $(cond) : -o ;
}
toolset.flags clang-win.archive .LD $(cond) : $(archiver) /nologo ;
toolset.flags clang-win.link .MT $(cond) : $(manifest-tool) -nologo ;
toolset.flags clang-win.compile .MC $(cond) : $(mc-compiler) ;
toolset.flags clang-win.compile .RC $(cond) : $(resource-compiler) ;
toolset.flags clang-win.compile .IDL $(cond) : $(idl-compiler) ;
}
manifest-tool ?= mt.exe ;
resource-compiler ?= rc.exe ;
mc-compiler ?= mc.exe ;
idl-compiler ?= midl.exe ;
.notice "$(addr):" "using manifest-tool '$(manifest-tool)'" ;
.notice "$(addr):" "using resource-compiler '$(resource-compiler)'" ;
.notice "$(addr):" "using mc-compiler '$(mc-compiler)'" ;
.notice "$(addr):" "using idl-compiler '$(idl-compiler)'" ;
local cond = "$(condition)/<architecture>/<address-model>$(addr)" "$(condition)/<architecture>x86/<address-model>$(addr)" ;
if $(addr) = $(default-addr) { cond += "$(condition)/<architecture>/<address-model>" "$(condition)/<architecture>x86/<address-model>" ; }
toolset.flags clang-win.compile .CC $(cond) : $(compiler) -m$(addr) ;
toolset.flags clang-win.link .LD $(cond) : $(compiler) -m$(addr) ;
toolset.flags clang-win.link LINKOPT $(cond) : /link ;
toolset.flags clang-win.link LINKFLAGS $(cond) : "/incremental:no" "/manifest" ;
toolset.flags clang-win.compile .ASM $(cond) : $(assembler) -nologo -c -Zp4 -Cp -Cx ;
toolset.flags clang-win.compile .ASM_OUTPUT $(cond) : -Fo ;
toolset.flags clang-win.archive .LD $(cond) : $(archiver) /nologo ;
toolset.flags clang-win.link .MT $(cond) : $(manifest-tool) -nologo ;
toolset.flags clang-win.compile .MC $(cond) : $(mc-compiler) ;
toolset.flags clang-win.compile .RC $(cond) : $(resource-compiler) ;
toolset.flags clang-win.compile .IDL $(cond) : $(idl-compiler) ;
}
toolset.flags clang-win.link LIBRARY_OPTION <toolset>clang-win : "" : unchecked ;