X-Git-Url: https://git.reactos.org/?p=reactos.git;a=blobdiff_plain;f=toolchain-mingw32.cmake;h=6281b24d19dbda7efc304f2d515120d7d4f7d6fc;hp=a82e6046c801e4356765dbcecaa357b9f126861e;hb=7dce7ccce4171b1e16bdbc9b258b15369236600b;hpb=b2e6f743b66955dc0fa4a6d3f8ff46ffe2450cc2 diff --git a/toolchain-mingw32.cmake b/toolchain-mingw32.cmake index a82e6046c80..6281b24d19d 100644 --- a/toolchain-mingw32.cmake +++ b/toolchain-mingw32.cmake @@ -1,9 +1,20 @@ + +if(NOT ARCH) +set(ARCH i386) +endif(NOT ARCH) + # Choose the right MinGW prefix -if (CMAKE_HOST_SYSTEM_NAME MATCHES Windows) -set(MINGW_PREFIX "") +if(ARCH MATCHES i386) + +if(CMAKE_HOST_SYSTEM_NAME MATCHES Windows) +set(MINGW_PREFIX "" CACHE STRING "MinGW Prefix") else() -set(MINGW_PREFIX "mingw32-") -endif() +set(MINGW_PREFIX "mingw32-" CACHE STRING "MinGW Prefix") +endif(CMAKE_HOST_SYSTEM_NAME MATCHES Windows) + +elseif(ARCH MATCHES amd64) +set(MINGW_PREFIX "x86_64-w64-mingw32-" CACHE STRING "MinGW Prefix") +endif(ARCH MATCHES i386) # the name of the target operating system SET(CMAKE_SYSTEM_NAME Windows) @@ -12,6 +23,26 @@ SET(CMAKE_SYSTEM_PROCESSOR i686) # which compilers to use for C and C++ SET(CMAKE_C_COMPILER ${MINGW_PREFIX}gcc) SET(CMAKE_CXX_COMPILER ${MINGW_PREFIX}g++) +SET(CMAKE_RC_COMPILER ${MINGW_PREFIX}windres) +SET(CMAKE_ASM_COMPILER ${MINGW_PREFIX}gcc) +SET(CMAKE_ASM_COMPILE_OBJECT " -x assembler-with-cpp -o -D__ASM__ -c ") +SET(CMAKE_IDL_COMPILER native-widl) + +SET(CMAKE_IDL_COMPILE_OBJECT " -m32 --win32 -h -H ") +SET(CMAKE_RC_COMPILE_OBJECT " -i -I${REACTOS_SOURCE_DIR}/include/psdk -I${REACTOS_BINARY_DIR}/include/psdk -I${REACTOS_SOURCE_DIR}/include/ -I${REACTOS_SOURCE_DIR}/include/reactos -I${REACTOS_BINARY_DIR}/include/reactos -I${REACTOS_SOURCE_DIR}/include/reactos/wine -I${REACTOS_SOURCE_DIR}/include/crt -I${REACTOS_SOURCE_DIR}/include/crt/mingw32 -O coff -o ") + +# Use stdcall fixups, and don't link with anything by default unless we say so +set(CMAKE_C_STANDARD_LIBRARIES "-lgcc" CACHE STRING "Standard C Libraries") + +#MARK_AS_ADVANCED(CLEAR CMAKE_CXX_STANDARD_LIBRARIES) +set(CMAKE_CXX_STANDARD_LIBRARIES "" CACHE STRING "Standard C++ Libraries") + +if(ARCH MATCHES i386) +set(CMAKE_SHARED_LINKER_FLAGS_INIT "-nodefaultlibs -nostdlib -Wl,--enable-auto-image-base -Wl,--enable-stdcall-fixup -Wl,--kill-at") +#-Wl,-T,${REACTOS_SOURCE_DIR}/global.lds +elseif(ARCH MATCHES amd64) +set(CMAKE_SHARED_LINKER_FLAGS_INIT "-nodefaultlibs -nostdlib -Wl,--enable-auto-image-base -Wl,--enable-stdcall-fixup -Wl,--kill-at") +endif(ARCH MATCHES i386) # adjust the default behaviour of the FIND_XXX() commands: # search headers and libraries in the target environment, search @@ -19,3 +50,4 @@ SET(CMAKE_CXX_COMPILER ${MINGW_PREFIX}g++) set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) +