Merge topic 'haiku-updates'
0cc42b87
Haiku: Fix compiler detection when using distcc84603d80
Haiku: Enable CMake builtin ELF editor
This commit is contained in:
commit
06c9f55449
|
@ -21,18 +21,26 @@ set(CMAKE_EXE_EXPORTS_C_FLAG "-Wl,--export-dynamic")
|
||||||
# "/boot/system/develop/lib/<subdir>/", which we assume to be the secondary
|
# "/boot/system/develop/lib/<subdir>/", which we assume to be the secondary
|
||||||
# architecture specific subdirectory and extract the name of the architecture
|
# architecture specific subdirectory and extract the name of the architecture
|
||||||
# accordingly.
|
# accordingly.
|
||||||
set(__HAIKU_COMPILER ${CMAKE_C_COMPILER})
|
|
||||||
|
|
||||||
if(NOT __HAIKU_COMPILER)
|
# First of all, find a C or C++ compiler we can run. The "arg1" is necessary
|
||||||
|
# here for compilers such as "distcc gcc-x86" or "ccache gcc-x86"
|
||||||
|
# TODO See CMakeDetermineCompilerId.cmake for some more things we may want to do.
|
||||||
|
if(CMAKE_C_COMPILER)
|
||||||
|
set(__HAIKU_COMPILER ${CMAKE_C_COMPILER})
|
||||||
|
string (STRIP "${CMAKE_C_COMPILER_ARG1}" __HAIKU_COMPILER_FLAGS)
|
||||||
|
else()
|
||||||
set(__HAIKU_COMPILER ${CMAKE_CXX_COMPILER})
|
set(__HAIKU_COMPILER ${CMAKE_CXX_COMPILER})
|
||||||
|
string (STRIP "${CMAKE_CXX_COMPILER_ARG1}" __HAIKU_COMPILER_FLAGS)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
execute_process(
|
execute_process(
|
||||||
COMMAND ${__HAIKU_COMPILER} -print-search-dirs
|
COMMAND ${__HAIKU_COMPILER} ${__HAIKU_COMPILER_FLAGS} -print-search-dirs
|
||||||
OUTPUT_VARIABLE _HAIKU_SEARCH_DIRS
|
OUTPUT_VARIABLE _HAIKU_SEARCH_DIRS
|
||||||
|
RESULT_VARIABLE _HAIKU_SEARCH_DIRS_FOUND
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||||
|
|
||||||
string(REGEX MATCH ".*\nlibraries: =?([^\n]*:)?/boot/system/develop/lib/([^/]*)/(:[^\n]*)?\n.*" _dummy "\n${_HAIKU_SEARCH_DIRS}\n")
|
string(REGEX MATCH "libraries: =?([^\n]*:)?/boot/system/develop/lib/([^/]*)/?(:?\n+)" _dummy "${_HAIKU_SEARCH_DIRS}\n")
|
||||||
set(CMAKE_HAIKU_SECONDARY_ARCH "${CMAKE_MATCH_2}")
|
set(CMAKE_HAIKU_SECONDARY_ARCH "${CMAKE_MATCH_2}")
|
||||||
|
|
||||||
if(NOT CMAKE_HAIKU_SECONDARY_ARCH)
|
if(NOT CMAKE_HAIKU_SECONDARY_ARCH)
|
||||||
|
@ -53,14 +61,12 @@ else()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
list(APPEND CMAKE_SYSTEM_PREFIX_PATH
|
list(APPEND CMAKE_SYSTEM_PREFIX_PATH
|
||||||
/boot/common/non-packaged
|
/boot/system/non-packaged
|
||||||
/boot/common
|
|
||||||
/boot/system
|
/boot/system
|
||||||
)
|
)
|
||||||
|
|
||||||
LIST(APPEND CMAKE_HAIKU_COMMON_INCLUDE_DIRECTORIES
|
LIST(APPEND CMAKE_HAIKU_COMMON_INCLUDE_DIRECTORIES
|
||||||
/boot/common/non-packaged/develop/headers${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
/boot/system/non-packaged/develop/headers${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
||||||
/boot/common/develop/headers${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
|
||||||
/boot/system/develop/headers/os
|
/boot/system/develop/headers/os
|
||||||
/boot/system/develop/headers/os/app
|
/boot/system/develop/headers/os/app
|
||||||
/boot/system/develop/headers/os/device
|
/boot/system/develop/headers/os/device
|
||||||
|
@ -108,8 +114,7 @@ LIST(APPEND CMAKE_HAIKU_CXX_INCLUDE_DIRECTORIES
|
||||||
LIST(APPEND CMAKE_SYSTEM_INCLUDE_PATH ${CMAKE_HAIKU_C_INCLUDE_DIRECTORIES})
|
LIST(APPEND CMAKE_SYSTEM_INCLUDE_PATH ${CMAKE_HAIKU_C_INCLUDE_DIRECTORIES})
|
||||||
|
|
||||||
LIST(APPEND CMAKE_HAIKU_DEVELOP_LIB_DIRECTORIES
|
LIST(APPEND CMAKE_HAIKU_DEVELOP_LIB_DIRECTORIES
|
||||||
/boot/common/non-packaged/develop/lib${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
/boot/system/non-packaged/develop/lib${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
||||||
/boot/common/develop/lib${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
|
||||||
/boot/system/develop/lib${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
/boot/system/develop/lib${CMAKE_HAIKU_SECONDARY_ARCH_SUBDIR}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -120,6 +125,6 @@ LIST(APPEND CMAKE_PLATFORM_IMPLICIT_LINK_DIRECTORIES
|
||||||
LIST(APPEND CMAKE_SYSTEM_LIBRARY_PATH ${CMAKE_HAIKU_DEVELOP_LIB_DIRECTORIES})
|
LIST(APPEND CMAKE_SYSTEM_LIBRARY_PATH ${CMAKE_HAIKU_DEVELOP_LIB_DIRECTORIES})
|
||||||
|
|
||||||
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
|
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
|
||||||
set(CMAKE_INSTALL_PREFIX "/boot/common" CACHE PATH
|
set(CMAKE_INSTALL_PREFIX "/boot/system" CACHE PATH
|
||||||
"Install path prefix, prepended onto install directories." FORCE)
|
"Install path prefix, prepended onto install directories." FORCE)
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -18,6 +18,23 @@ else()
|
||||||
endif()
|
endif()
|
||||||
if(HAVE_ELF_H)
|
if(HAVE_ELF_H)
|
||||||
set(CMAKE_USE_ELF_PARSER 1)
|
set(CMAKE_USE_ELF_PARSER 1)
|
||||||
|
elseif(HAIKU)
|
||||||
|
# On Haiku, we need to include elf32.h from the private headers
|
||||||
|
set(CMake_HAIKU_INCLUDE_DIRS
|
||||||
|
/boot/system/develop/headers/private/system
|
||||||
|
/boot/system/develop/headers/private/system/arch/x86
|
||||||
|
)
|
||||||
|
|
||||||
|
set(CMAKE_REQUIRED_INCLUDES ${CMake_HAIKU_INCLUDE_DIRS})
|
||||||
|
CHECK_INCLUDE_FILE("elf32.h" HAVE_ELF32_H)
|
||||||
|
unset(CMAKE_REQUIRED_INCLUDES)
|
||||||
|
|
||||||
|
if(HAVE_ELF32_H)
|
||||||
|
set(CMAKE_USE_ELF_PARSER 1)
|
||||||
|
else()
|
||||||
|
unset(CMake_HAIKU_INCLUDE_DIRS)
|
||||||
|
set(CMAKE_USE_ELF_PARSER)
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
set(CMAKE_USE_ELF_PARSER)
|
set(CMAKE_USE_ELF_PARSER)
|
||||||
endif()
|
endif()
|
||||||
|
@ -57,6 +74,7 @@ include_directories(
|
||||||
${CMAKE_EXPAT_INCLUDES}
|
${CMAKE_EXPAT_INCLUDES}
|
||||||
${CMAKE_TAR_INCLUDES}
|
${CMAKE_TAR_INCLUDES}
|
||||||
${CMAKE_COMPRESS_INCLUDES}
|
${CMAKE_COMPRESS_INCLUDES}
|
||||||
|
${CMake_HAIKU_INCLUDE_DIRS}
|
||||||
)
|
)
|
||||||
|
|
||||||
# let cmake know it is supposed to use it
|
# let cmake know it is supposed to use it
|
||||||
|
|
|
@ -23,6 +23,26 @@
|
||||||
#if defined(__OpenBSD__)
|
#if defined(__OpenBSD__)
|
||||||
# include <stdint.h>
|
# include <stdint.h>
|
||||||
# include <elf_abi.h>
|
# include <elf_abi.h>
|
||||||
|
#elif defined(__HAIKU__)
|
||||||
|
# include <elf32.h>
|
||||||
|
# include <elf64.h>
|
||||||
|
typedef struct Elf32_Ehdr Elf32_Ehdr;
|
||||||
|
typedef struct Elf32_Shdr Elf32_Shdr;
|
||||||
|
typedef struct Elf32_Sym Elf32_Sym;
|
||||||
|
typedef struct Elf32_Rel Elf32_Rel;
|
||||||
|
typedef struct Elf32_Rela Elf32_Rela;
|
||||||
|
# define ELFMAG0 0x7F
|
||||||
|
# define ELFMAG1 'E'
|
||||||
|
# define ELFMAG2 'L'
|
||||||
|
# define ELFMAG3 'F'
|
||||||
|
# define ET_NONE 0
|
||||||
|
# define ET_REL 1
|
||||||
|
# define ET_EXEC 2
|
||||||
|
# define ET_DYN 3
|
||||||
|
# define ET_CORE 4
|
||||||
|
# define EM_386 3
|
||||||
|
# define EM_SPARC 2
|
||||||
|
# define EM_PPC 20
|
||||||
#else
|
#else
|
||||||
# include <elf.h>
|
# include <elf.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue