diff options
author | Lorenzo Cappelletti <lorenzo.cappelletti@gmail.com> | 2021-07-19 10:36:34 +0200 |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2021-07-20 11:50:09 -0400 |
commit | 1c66012f8eafb136335278d2bbb63319a01bb093 (patch) | |
tree | 25e410fa6181c9a2bd7175fc32eb91f65219568e /Modules | |
parent | 91a904495a862f961fabccf1640f2cc3c1af137f (diff) | |
download | cmake-1c66012f8eafb136335278d2bbb63319a01bb093.tar.gz |
Compiler/IAR: search for both IAR's binaries * and *.exe
IAR is available for both Linux and Windows OSes. Moreover,
binaries `*.exe` could be called from a Linux box, or vice versa.
See also commit 01a4eec446 (IAR: Changes required for Linux,
2019-04-25, v3.15.0-rc1~185^2).
Fixes: #22312
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/Compiler/IAR-FindBinUtils.cmake | 32 |
1 files changed, 24 insertions, 8 deletions
diff --git a/Modules/Compiler/IAR-FindBinUtils.cmake b/Modules/Compiler/IAR-FindBinUtils.cmake index 6c67d34793..01f6d22590 100644 --- a/Modules/Compiler/IAR-FindBinUtils.cmake +++ b/Modules/Compiler/IAR-FindBinUtils.cmake @@ -20,19 +20,31 @@ if("${CMAKE_${_CMAKE_PROCESSING_LANGUAGE}_COMPILER_ARCHITECTURE_ID}" STREQUAL "A string(TOLOWER "${CMAKE_${_CMAKE_PROCESSING_LANGUAGE}_COMPILER_ARCHITECTURE_ID}" _archid_lower) # Find linker - find_program(CMAKE_IAR_LINKER ilink${_archid_lower} HINTS ${__iar_hints} + find_program(CMAKE_IAR_LINKER + NAMES ilink${_archid_lower} ilink${_archid_lower}.exe + HINTS ${__iar_hints} DOC "The IAR ILINK linker") - find_program(CMAKE_IAR_ARCHIVE iarchive HINTS ${__iar_hints} + find_program(CMAKE_IAR_ARCHIVE + NAMES iarchive iarchive.exe + HINTS ${__iar_hints} DOC "The IAR archiver") # Find utility tools - find_program(CMAKE_IAR_ELFTOOL ielftool HINTS ${__iar_hints} + find_program(CMAKE_IAR_ELFTOOL + NAMES ielftool ielftool.exe + HINTS ${__iar_hints} DOC "The IAR ELF Tool") - find_program(CMAKE_IAR_ELFDUMP ielfdump${_archid_lower} HINTS ${__iar_hints} + find_program(CMAKE_IAR_ELFDUMP + NAMES ielfdump${_archid_lower} ielfdump${_archid_lower}.exe + HINTS ${__iar_hints} DOC "The IAR ELF Dumper") - find_program(CMAKE_IAR_OBJMANIP iobjmanip HINTS ${__iar_hints} + find_program(CMAKE_IAR_OBJMANIP + NAMES iobjmanip iobjmanip.exe + HINTS ${__iar_hints} DOC "The IAR ELF Object Tool") - find_program(CMAKE_IAR_SYMEXPORT isymexport HINTS ${__iar_hints} + find_program(CMAKE_IAR_SYMEXPORT + NAMES isymexport + HINTS ${__iar_hints} DOC "The IAR Absolute Symbol Exporter") mark_as_advanced(CMAKE_IAR_LINKER CMAKE_IAR_ARCHIVE CMAKE_IAR_ELFTOOL CMAKE_IAR_ELFDUMP CMAKE_IAR_OBJMANIP CMAKE_IAR_SYMEXPORT) @@ -51,9 +63,13 @@ elseif("${CMAKE_${_CMAKE_PROCESSING_LANGUAGE}_COMPILER_ARCHITECTURE_ID}" STREQUA "${CMAKE_${_CMAKE_PROCESSING_LANGUAGE}_COMPILER_ARCHITECTURE_ID}" STREQUAL "8051") # Find the "xlink" linker and "xar" archiver: - find_program(CMAKE_IAR_LINKER xlink HINTS ${__iar_hints} + find_program(CMAKE_IAR_LINKER + NAMES xlink xlink.exe + HINTS ${__iar_hints} DOC "The IAR XLINK linker") - find_program(CMAKE_IAR_AR xar HINTS ${__iar_hints} + find_program(CMAKE_IAR_AR + NAMES xar xar.exe + HINTS ${__iar_hints} DOC "The IAR archiver") mark_as_advanced(CMAKE_IAR_LINKER CMAKE_IAR_AR) |