mirror of https://github.com/PCSX2/pcsx2.git
Begin cleaning up the cross build code.
http://www.vtk.org/Wiki/CMake_Cross_Compiling http://www.cmake.org/cmake/help/v3.0/manual/cmake-toolchains.7.html . The official way that cmake does cross compiling is via the use of a CMAKE_TOOLCHAIN_FILE. This has to be given by the user and can't be included from within a Cmake file since setting up the toolchain has to be the first thing that happens. . After the file is given and validated cmake behaves nicely and all the workarounds and hacks are not really needed anymore. . The consequence of this change is that without this file cmake will try to build for the HOST architecture as expected and with the file it will build for the TARGET architecture of the given toolchain. Due to this remove 64BIT_BUILD_DONT_WORK and just ERROR out if the user tries in the same way as before.
This commit is contained in:
parent
8ea0766773
commit
d6d06d243c
2
build.sh
2
build.sh
|
@ -41,7 +41,6 @@ for ARG in "$@"; do
|
||||||
--asan ) flags+=(-DUSE_ASAN=TRUE) ;;
|
--asan ) flags+=(-DUSE_ASAN=TRUE) ;;
|
||||||
--wx28 ) flags+=(-DWX28_API=TRUE) ;;
|
--wx28 ) flags+=(-DWX28_API=TRUE) ;;
|
||||||
--gtk3 ) flags+=(-DGTK3_API=TRUE) ;;
|
--gtk3 ) flags+=(-DGTK3_API=TRUE) ;;
|
||||||
--64-bit-dont-work ) flags+=(-D64BIT_BUILD_DONT_WORK=TRUE) ;;
|
|
||||||
--no-simd ) flags+=(-DDISABLE_ADVANCE_SIMD=TRUE) ;;
|
--no-simd ) flags+=(-DDISABLE_ADVANCE_SIMD=TRUE) ;;
|
||||||
-D* ) flags+=($ARG) ;;
|
-D* ) flags+=($ARG) ;;
|
||||||
|
|
||||||
|
@ -66,7 +65,6 @@ for ARG in "$@"; do
|
||||||
echo "--gles : Replace openGL backend of GSdx by openGLES3.1"
|
echo "--gles : Replace openGL backend of GSdx by openGLES3.1"
|
||||||
echo
|
echo
|
||||||
echo "** Hardcode Developper option **"
|
echo "** Hardcode Developper option **"
|
||||||
echo "--64-bit-dont-work : Don't use it!"
|
|
||||||
echo "--no-simd : Only allow sse2"
|
echo "--no-simd : Only allow sse2"
|
||||||
echo "--gtk3 : replace GTK2 by GTK3"
|
echo "--gtk3 : replace GTK2 by GTK3"
|
||||||
exit 1
|
exit 1
|
||||||
|
|
|
@ -66,75 +66,30 @@ option(USE_ASAN "Enable address sanitizer")
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
# Select the architecture
|
# Select the architecture
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
option(64BIT_BUILD_DONT_WORK "Enable a x86_64 build instead of cross compiling (WARNING: NOTHING WORK)" OFF)
|
|
||||||
option(DISABLE_ADVANCE_SIMD "Disable advance use of SIMD (SSE2+ & AVX)" OFF)
|
option(DISABLE_ADVANCE_SIMD "Disable advance use of SIMD (SSE2+ & AVX)" OFF)
|
||||||
|
|
||||||
# Architecture bitness detection
|
# Architecture bitness detection
|
||||||
include(TargetArch)
|
include(TargetArch)
|
||||||
target_architecture(PCSX2_TARGET_ARCHITECTURES)
|
target_architecture(PCSX2_TARGET_ARCHITECTURES)
|
||||||
if(${PCSX2_TARGET_ARCHITECTURES} MATCHES "x86_64")
|
if(${PCSX2_TARGET_ARCHITECTURES} MATCHES "x86_64" OR ${PCSX2_TARGET_ARCHITECTURES} MATCHES "i386")
|
||||||
set(_ARCH_64 1)
|
if(${PCSX2_TARGET_ARCHITECTURES} MATCHES "x86_64" AND (CMAKE_BUILD_TYPE MATCHES "Release" OR PACKAGE_MODE))
|
||||||
if(CMAKE_BUILD_TYPE MATCHES "Release" OR PACKAGE_MODE)
|
|
||||||
message(FATAL_ERROR "The ${PCSX2_TARGET_ARCHITECTURES} architecture is not ready yet.")
|
message(FATAL_ERROR "The ${PCSX2_TARGET_ARCHITECTURES} architecture is not ready yet.")
|
||||||
endif()
|
endif()
|
||||||
elseif(${PCSX2_TARGET_ARCHITECTURES} MATCHES "i386")
|
message(STATUS "Compiling a ${PCSX2_TARGET_ARCHITECTURES} build on a ${CMAKE_HOST_SYSTEM_PROCESSOR} host.")
|
||||||
set(_ARCH_32 1)
|
|
||||||
else()
|
else()
|
||||||
message(FATAL_ERROR "Unsupported architecture: ${PCSX2_TARGET_ARCHITECTURES}")
|
message(FATAL_ERROR "Unsupported architecture: ${PCSX2_TARGET_ARCHITECTURES}")
|
||||||
endif()
|
endif()
|
||||||
message(STATUS "Compiling a ${PCSX2_TARGET_ARCHITECTURES} build on a ${CMAKE_HOST_SYSTEM_PROCESSOR} host.")
|
|
||||||
|
|
||||||
# Print a clear message that 64bits is not supported
|
# Print a clear message that most architectures are not supported
|
||||||
if(_ARCH_64)
|
if(NOT (${PCSX2_TARGET_ARCHITECTURES} MATCHES "i386"))
|
||||||
message(WARNING "
|
message(WARNING "
|
||||||
PCSX2 does not support a 64-bits environment and has no yet a plan to support it.
|
PCSX2 does not support the ${PCSX2_TARGET_ARCHITECTURES} architecture and has no plans yet to support it.
|
||||||
It would need a complete rewrite of the core emulator and a lot of time.
|
It would need a complete rewrite of the core emulator and a lot of time.
|
||||||
|
|
||||||
You can still run a 32-bits binary if you install all 32-bits libraries (runtime and dev).")
|
You can still run a i386 binary if you install all the i386 libraries (runtime and dev).")
|
||||||
endif()
|
|
||||||
|
|
||||||
# 64 bits cross-compile specific configuration
|
|
||||||
if(_ARCH_64 AND 64BIT_BUILD_DONT_WORK)
|
|
||||||
# Search library in /usr/lib64
|
|
||||||
SET_PROPERTY(GLOBAL PROPERTY FIND_LIBRARY_USE_LIB64_PATHS ON)
|
|
||||||
# Probably useless but it will not harm
|
|
||||||
SET_PROPERTY(GLOBAL PROPERTY COMPILE_DEFINITIONS "-m64")
|
|
||||||
|
|
||||||
# Note: /usr/lib64 is already taken care above
|
|
||||||
|
|
||||||
# For Debian/ubuntu multiarch
|
|
||||||
if(EXISTS "/usr/lib/x86_64-linux-gnu")
|
|
||||||
set(CMAKE_LIBRARY_ARCHITECTURE "x86_64-linux-gnu")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# x86_64 requires -fPIC
|
|
||||||
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
|
|
||||||
|
|
||||||
if (DISABLE_ADVANCE_SIMD)
|
|
||||||
set(ARCH_FLAG "-m64 -msse -msse2")
|
|
||||||
else()
|
|
||||||
#set(ARCH_FLAG "-m64 -march=native -fabi-version=6")
|
|
||||||
set(ARCH_FLAG "-m64 -march=native")
|
|
||||||
endif()
|
|
||||||
add_definitions(-D_ARCH_64=1 -D_M_X86=1 -D_M_X86_64=1)
|
|
||||||
set(_ARCH_64 1)
|
|
||||||
set(_M_X86 1)
|
|
||||||
set(_M_X86_64 1)
|
|
||||||
else()
|
|
||||||
# Do not search library in /usr/lib64
|
|
||||||
SET_PROPERTY(GLOBAL PROPERTY FIND_LIBRARY_USE_LIB64_PATHS OFF)
|
|
||||||
# Probably useless but it will not harm
|
|
||||||
SET_PROPERTY(GLOBAL PROPERTY COMPILE_DEFINITIONS "-m32")
|
|
||||||
|
|
||||||
# Force the search on 32-bits path.
|
|
||||||
if(EXISTS "/usr/lib32")
|
|
||||||
set(CMAKE_LIBRARY_ARCHITECTURE "../lib32")
|
|
||||||
endif()
|
|
||||||
# Debian/ubuntu drop /usr/lib32 and move /usr/lib to /usr/lib/i386-linux-gnu
|
|
||||||
if(EXISTS "/usr/lib/i386-linux-gnu")
|
|
||||||
set(CMAKE_LIBRARY_ARCHITECTURE "i386-linux-gnu")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(${PCSX2_TARGET_ARCHITECTURES} MATCHES "i386")
|
||||||
# * -fPIC option was removed for multiple reasons.
|
# * -fPIC option was removed for multiple reasons.
|
||||||
# - Code only supports the x86 architecture.
|
# - Code only supports the x86 architecture.
|
||||||
# - code uses the ebx register so it's not compliant with PIC.
|
# - code uses the ebx register so it's not compliant with PIC.
|
||||||
|
@ -142,18 +97,46 @@ else()
|
||||||
# - Only plugins. No package will link to them.
|
# - Only plugins. No package will link to them.
|
||||||
set(CMAKE_POSITION_INDEPENDENT_CODE OFF)
|
set(CMAKE_POSITION_INDEPENDENT_CODE OFF)
|
||||||
|
|
||||||
|
# Do not search library in /usr/lib64
|
||||||
|
SET_PROPERTY(GLOBAL PROPERTY FIND_LIBRARY_USE_LIB64_PATHS OFF)
|
||||||
|
|
||||||
if (DISABLE_ADVANCE_SIMD)
|
if (DISABLE_ADVANCE_SIMD)
|
||||||
set(ARCH_FLAG "-m32 -msse -msse2 -march=i686")
|
set(ARCH_FLAG "-msse -msse2 -march=i686")
|
||||||
else()
|
else()
|
||||||
# AVX requires some fix of the ABI (mangling) (default 2)
|
# AVX requires some fix of the ABI (mangling) (default 2)
|
||||||
# Note: V6 requires GCC 4.7
|
# Note: V6 requires GCC 4.7
|
||||||
#set(ARCH_FLAG "-m32 -march=native -fabi-version=6")
|
#set(ARCH_FLAG "-march=native -fabi-version=6")
|
||||||
set(ARCH_FLAG "-m32 -march=native")
|
set(ARCH_FLAG "-march=native")
|
||||||
endif()
|
endif()
|
||||||
add_definitions(-D_ARCH_32=1 -D_M_X86=1 -D_M_X86_32=1)
|
add_definitions(-D_ARCH_32=1 -D_M_X86=1 -D_M_X86_32=1)
|
||||||
set(_ARCH_32 1)
|
set(_ARCH_32 1)
|
||||||
set(_M_X86 1)
|
set(_M_X86 1)
|
||||||
set(_M_X86_32 1)
|
set(_M_X86_32 1)
|
||||||
|
elseif(${PCSX2_TARGET_ARCHITECTURES} MATCHES "x86_64")
|
||||||
|
# x86_64 requires -fPIC
|
||||||
|
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
|
||||||
|
|
||||||
|
# Search library in /usr/lib64 (Arch Linux)
|
||||||
|
SET_PROPERTY(GLOBAL PROPERTY FIND_LIBRARY_USE_LIB64_PATHS ON)
|
||||||
|
|
||||||
|
if (DISABLE_ADVANCE_SIMD)
|
||||||
|
set(ARCH_FLAG "-msse -msse2")
|
||||||
|
else()
|
||||||
|
#set(ARCH_FLAG "-march=native -fabi-version=6")
|
||||||
|
set(ARCH_FLAG "-march=native")
|
||||||
|
endif()
|
||||||
|
add_definitions(-D_ARCH_64=1 -D_M_X86=1 -D_M_X86_64=1)
|
||||||
|
set(_ARCH_64 1)
|
||||||
|
set(_M_X86 1)
|
||||||
|
set(_M_X86_64 1)
|
||||||
|
else()
|
||||||
|
# All but i386 requires -fPIC
|
||||||
|
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
|
||||||
|
|
||||||
|
# Do not search library in /usr/lib64
|
||||||
|
SET_PROPERTY(GLOBAL PROPERTY FIND_LIBRARY_USE_LIB64_PATHS OFF)
|
||||||
|
|
||||||
|
message(FATAL_ERROR "Unsupported architecture: ${PCSX2_TARGET_ARCHITECTURES}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
|
@ -212,7 +195,7 @@ set(CMAKE_CXX_FLAGS_RELEASE "")
|
||||||
# Remove -rdynamic option that can some segmentation fault when openining pcsx2 plugins
|
# Remove -rdynamic option that can some segmentation fault when openining pcsx2 plugins
|
||||||
set(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "")
|
set(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "")
|
||||||
set(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS "")
|
set(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS "")
|
||||||
if(_ARCH_32)
|
if(${PCSX2_TARGET_ARCHITECTURES} MATCHES "i386")
|
||||||
# Remove -fPIC option on 32bit architectures.
|
# Remove -fPIC option on 32bit architectures.
|
||||||
# No good reason to use it for plugins, also it impacts performance.
|
# No good reason to use it for plugins, also it impacts performance.
|
||||||
set(CMAKE_SHARED_LIBRARY_C_FLAGS "")
|
set(CMAKE_SHARED_LIBRARY_C_FLAGS "")
|
||||||
|
@ -303,9 +286,6 @@ string(STRIP "${CMAKE_CXX_FLAGS} ${DEFAULT_CPP_FLAG}" CMAKE_CXX_FLAGS)
|
||||||
# Too much user/packager use experimental flags as release flags
|
# Too much user/packager use experimental flags as release flags
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
if(CMAKE_BUILD_TYPE MATCHES "Release" OR PACKAGE_MODE)
|
if(CMAKE_BUILD_TYPE MATCHES "Release" OR PACKAGE_MODE)
|
||||||
if (64BIT_BUILD_DONT_WORK)
|
|
||||||
message(FATAL_ERROR "64 bit is not suitable for end users. It will only crash and it will be 10 times slower than 32 bits !!!")
|
|
||||||
endif()
|
|
||||||
if (GTK3_API)
|
if (GTK3_API)
|
||||||
message(FATAL_ERROR "GTK3 is highly experimental besides it requires a wxWidget built with __WXGTK3__ support !!!")
|
message(FATAL_ERROR "GTK3 is highly experimental besides it requires a wxWidget built with __WXGTK3__ support !!!")
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -101,25 +101,6 @@ endif()
|
||||||
|
|
||||||
if(wxWidgets_FOUND)
|
if(wxWidgets_FOUND)
|
||||||
if(Linux)
|
if(Linux)
|
||||||
# Force the use of 32 bit library configuration on
|
|
||||||
# 64 bits machine with 32 bits library in /usr/lib32
|
|
||||||
if(_ARCH_64 AND NOT 64BIT_BUILD_DONT_WORK)
|
|
||||||
## There is no guarantee that wx-config is a link to a 32 bits library. So you need to force the destinity
|
|
||||||
# Library can go into 3 path major paths (+ multiarch)
|
|
||||||
# 1/ /usr/lib32 (32 bits only)
|
|
||||||
# 2/ /usr/lib64 (64 bits only)
|
|
||||||
# 3/ /usr/lib (32 or 64 bits depends on distributions)
|
|
||||||
if (EXISTS "/usr/lib32/wx")
|
|
||||||
STRING(REGEX REPLACE "/usr/lib/wx" "/usr/lib32/wx" wxWidgets_INCLUDE_DIRS "${wxWidgets_INCLUDE_DIRS}")
|
|
||||||
STRING(REGEX REPLACE "/usr/lib64/wx" "/usr/lib32/wx" wxWidgets_INCLUDE_DIRS "${wxWidgets_INCLUDE_DIRS}")
|
|
||||||
endif (EXISTS "/usr/lib32/wx")
|
|
||||||
if (EXISTS "/usr/lib/wx")
|
|
||||||
STRING(REGEX REPLACE "/usr/lib64/wx" "/usr/lib/wx" wxWidgets_INCLUDE_DIRS "${wxWidgets_INCLUDE_DIRS}")
|
|
||||||
endif (EXISTS "/usr/lib/wx")
|
|
||||||
# Multiarch ubuntu/debian
|
|
||||||
STRING(REGEX REPLACE "/usr/lib/x86_64-linux-gnu" "/usr/lib/i386-linux-gnu" wxWidgets_INCLUDE_DIRS "${wxWidgets_INCLUDE_DIRS}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Some people are trying to compile with wx 3.0 ...
|
# Some people are trying to compile with wx 3.0 ...
|
||||||
### 3.0
|
### 3.0
|
||||||
# -I/usr/lib/i386-linux-gnu/wx/include/gtk2-unicode-3.0 -I/usr/include/wx-3.0 -D_FILE_OFFSET_BITS=64 -DWXUSINGDLL -D__WXGTK__ -pthread
|
# -I/usr/lib/i386-linux-gnu/wx/include/gtk2-unicode-3.0 -I/usr/include/wx-3.0 -D_FILE_OFFSET_BITS=64 -DWXUSINGDLL -D__WXGTK__ -pthread
|
||||||
|
@ -151,10 +132,3 @@ include_directories(${CMAKE_SOURCE_DIR}/common/include
|
||||||
# File generated by Cmake
|
# File generated by Cmake
|
||||||
${CMAKE_BINARY_DIR}/common/include
|
${CMAKE_BINARY_DIR}/common/include
|
||||||
)
|
)
|
||||||
|
|
||||||
# WORKAROUND Some issue with multiarch on Debian/Ubuntu
|
|
||||||
if (64BIT_BUILD_DONT_WORK)
|
|
||||||
include_directories(/usr/include/x86_64-linux-gnu)
|
|
||||||
else()
|
|
||||||
include_directories(/usr/include/i386-linux-gnu)
|
|
||||||
endif()
|
|
||||||
|
|
Loading…
Reference in New Issue