[CMAKE]
[reactos.git] / gcc.cmake
index 5baf47e..2c1e237 100644 (file)
--- a/gcc.cmake
+++ b/gcc.cmake
@@ -1,18 +1,28 @@
 
-if(NOT CMAKE_CROSSCOMPILING)
-
-add_definitions(-fshort-wchar)
-
-else()
-
 # Linking
-link_directories("${REACTOS_SOURCE_DIR}/importlibs" ${REACTOS_BINARY_DIR}/lib/3rdparty/mingw)
+if(ARCH MATCHES i386)
+link_directories("${REACTOS_SOURCE_DIR}/importlibs")
+endif()
+link_directories(${REACTOS_BINARY_DIR}/lib/3rdparty/mingw)
 set(CMAKE_C_LINK_EXECUTABLE "<CMAKE_C_COMPILER> <FLAGS> <CMAKE_C_LINK_FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>")
 set(CMAKE_CXX_LINK_EXECUTABLE "<CMAKE_CXX_COMPILER> <FLAGS> <CMAKE_CXX_LINK_FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>")
-set(CMAKE_EXE_LINKER_FLAGS "-nodefaultlibs -nostdlib -Wl,--enable-auto-image-base -Wl,--kill-at -Wl,--disable-auto-import")
+set(CMAKE_EXE_LINKER_FLAGS "-nodefaultlibs -nostdlib -Wl,--enable-auto-image-base -Wl,--disable-auto-import")
 # -Wl,-T,${REACTOS_SOURCE_DIR}/global.lds
 set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS_INIT} -Wl,--disable-stdcall-fixup")
 
+#set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> -i <SOURCE> <CMAKE_C_LINK_FLAGS> <DEFINES> -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 <OBJECT>")
+
+# Temporary, until windres issues are fixed
+get_target_property(WRC native-wrc IMPORTED_LOCATION_NOCONFIG)
+set(CMAKE_RC_COMPILE_OBJECT
+    "<CMAKE_C_COMPILER> -DRC_INVOKED -D__WIN32__=1 -D__FLAT__=1 <DEFINES> -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 -xc -E <SOURCE> -o <OBJECT>"
+    "${WRC} -i <OBJECT> -o <OBJECT>"
+    "<CMAKE_RC_COMPILER> -i <OBJECT> -J res -O coff -o <OBJECT>")
+
+if(NOT CMAKE_HOST_SYSTEM_NAME MATCHES Windows)
+       set(CMAKE_C_CREATE_STATIC_LIBRARY "<CMAKE_AR> crs <TARGET> <LINK_FLAGS> <OBJECTS>")
+endif()
+
 # Compiler Core
 add_definitions(-pipe -fms-extensions)
 
@@ -21,19 +31,74 @@ set(CMAKE_CXX_CREATE_SHARED_LIBRARY "<CMAKE_CXX_COMPILER> <CMAKE_SHARED_LIBRARY_
 set(CMAKE_RC_CREATE_SHARED_LIBRARY "<CMAKE_C_COMPILER> <CMAKE_SHARED_LIBRARY_C_FLAGS> <LINK_FLAGS> <CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS> -o <TARGET> <OBJECTS> <LINK_LIBRARIES>")
 
 # Debugging (Note: DWARF-4 on 4.5.1 when we ship)
-#add_definitions(-gdwarf-2 -g2 -femit-struct-debug-detailed=none -feliminate-unused-debug-types)
+add_definitions(-gdwarf-2 -g2 -femit-struct-debug-detailed=none -feliminate-unused-debug-types)
 
 # Tuning
-add_definitions(-march=pentium -mtune=i686)
+if(ARCH MATCHES i386)
+    add_definitions(-march=${OARCH} -mtune=${TUNE})
+else()
+    add_definitions(-march=${OARCH})
+endif()
 
 # Warnings
+
 add_definitions(-Wall -Wno-char-subscripts -Wpointer-arith -Wno-multichar -Wno-error=uninitialized -Wno-unused-value -Winvalid-pch)
 
+if(ARCH MATCHES amd64)
+    add_definitions(-Wno-format)
+elseif(ARCH MATCHES arm)
+    add_definitions(-Wno-attributes)
+endif()
+
 # Optimizations
-add_definitions(-Os -fno-strict-aliasing -ftracer -momit-leaf-frame-pointer -mpreferred-stack-boundary=2 -fno-set-stack-executable -fno-optimize-sibling-calls)
+
+if(OPTIMIZE STREQUAL "1")
+    add_definitions(-Os)
+elseif(OPTIMIZE STREQUAL "2")
+    add_definitions(-Os)
+elseif(OPTIMIZE STREQUAL "3")
+    add_definitions(-O1)
+elseif(OPTIMIZE STREQUAL "4")
+    add_definitions(-O2)
+elseif(OPTIMIZE STREQUAL "5")
+    add_definitions(-O3)
+endif()
+
+add_definitions(-fno-strict-aliasing)
+
+if(ARCH MATCHES i386)
+    add_definitions(-mpreferred-stack-boundary=2 -fno-set-stack-executable -fno-optimize-sibling-calls)
+    if(OPTIMIZE STREQUAL "1")
+        add_definitions(-ftracer -momit-leaf-frame-pointer)
+    endif()
+elseif(ARCH MATCHES amd64)
+    add_definitions(-mpreferred-stack-boundary=4)
+    if(OPTIMIZE STREQUAL "1")
+        add_definitions(-ftracer -momit-leaf-frame-pointer)
+    endif()
+elseif(ARCH MATCHES arm)
+    if(OPTIMIZE STREQUAL "1")
+        add_definitions(-ftracer)
+    endif()
+endif()
+
+# Other
+if(ARCH MATCHES amd64)
+    add_definitions(-U_X86_ -UWIN32)
+elseif(ARCH MATCHES arm)
+    add_definitions(-U_UNICODE -UUNICODE)
+    add_definitions(-D__MSVCRT__) # DUBIOUS
+endif()
+
+# alternative arch name
+if(ARCH MATCHES amd64)
+    set(ARCH2 x86_64)
+else()
+    set(ARCH2 ${ARCH})
+endif()
 
 # Macros
-MACRO(_PCH_GET_COMPILE_FLAGS _target_name _out_compile_flags _header_filename)
+macro(_PCH_GET_COMPILE_FLAGS _target_name _out_compile_flags _header_filename)
     # Add the precompiled header to the build
     get_filename_component(FILE ${_header_filename} NAME)
     set(_gch_filename "${_target_name}_${FILE}.gch")
@@ -43,7 +108,7 @@ MACRO(_PCH_GET_COMPILE_FLAGS _target_name _out_compile_flags _header_filename)
     get_directory_property(DIRINC INCLUDE_DIRECTORIES)
     foreach(item ${DIRINC})
         list(APPEND ${_out_compile_flags} -I${item})
-    endforeach(item) 
+    endforeach()
 
     # This is a particular bit of undocumented/hacky magic I'm quite proud of
     get_directory_property(_compiler_flags DEFINITIONS)
@@ -55,11 +120,11 @@ MACRO(_PCH_GET_COMPILE_FLAGS _target_name _out_compile_flags _header_filename)
     if (_target_defs)
         foreach(item ${_target_defs})
             list(APPEND ${_out_compile_flags} -D${item})
-        endforeach(item)
+        endforeach()
     endif()
-ENDMACRO(_PCH_GET_COMPILE_FLAGS) 
+endmacro()
 
-MACRO(add_pch _target_name _header_filename _src_list)
+macro(add_pch _target_name _header_filename _src_list)
     get_filename_component(FILE ${_header_filename} NAME)
     set(_gch_filename "${_target_name}_${FILE}.gch")
     list(APPEND ${_src_list} ${_gch_filename})
@@ -69,7 +134,7 @@ MACRO(add_pch _target_name _header_filename _src_list)
         OUTPUT ${_gch_filename}
         COMMAND ${CMAKE_C_COMPILER} ${CMAKE_C_COMPILER_ARG1} ${_args}
         DEPENDS ${_header_filename})
-ENDMACRO(add_pch _target_name _header_filename _src_list)
+endmacro()
 
 macro(add_linkerflag MODULE _flag)
     set(NEW_LINKER_FLAGS ${_flag})
@@ -80,11 +145,18 @@ macro(add_linkerflag MODULE _flag)
     set_target_properties(${MODULE} PROPERTIES LINK_FLAGS ${NEW_LINKER_FLAGS})
 endmacro()
 
+# Optional 3rd parameter: stdcall stack bytes
 macro(set_entrypoint MODULE ENTRYPOINT)
     if(${ENTRYPOINT} STREQUAL "0")
         add_linkerflag(${MODULE} "-Wl,-entry,0")
+    elseif(ARCH MATCHES i386)
+        set(_entrysymbol _${ENTRYPOINT})
+        if (${ARGC} GREATER 2)
+            set(_entrysymbol ${_entrysymbol}@${ARGV2})
+        endif()
+        add_linkerflag(${MODULE} "-Wl,-entry,${_entrysymbol}")
     else()
-        add_linkerflag(${MODULE} "-Wl,-entry,_${ENTRYPOINT}")
+        add_linkerflag(${MODULE} "-Wl,-entry,${ENTRYPOINT}")
     endif()
 endmacro()
 
@@ -99,16 +171,14 @@ endmacro()
 macro(set_module_type MODULE TYPE)
 
     add_dependencies(${MODULE} psdk buildno_header)
-       
     if(${IS_CPP})
-         target_link_libraries(${MODULE} stlport -lsupc++ -lgcc)
-       endif()
-       
+        target_link_libraries(${MODULE} stlport -lsupc++ -lgcc)
+    endif()
+
     if(${TYPE} MATCHES nativecui)
         set_subsystem(${MODULE} native)
-        set_entrypoint(${MODULE} NtProcessStartup@4)
-    endif()
-    if(${TYPE} MATCHES win32gui)
+        set_entrypoint(${MODULE} NtProcessStartup 4)
+    elseif(${TYPE} MATCHES win32gui)
         set_subsystem(${MODULE} windows)
         set_entrypoint(${MODULE} WinMainCRTStartup)
         if(NOT IS_UNICODE)
@@ -116,9 +186,8 @@ macro(set_module_type MODULE TYPE)
         else()
             target_link_libraries(${MODULE} mingw_wmain)
         endif(NOT IS_UNICODE)
-               target_link_libraries(${MODULE} mingw_common)
-    endif()
-    if(${TYPE} MATCHES win32cui)
+        target_link_libraries(${MODULE} mingw_common)
+    elseif(${TYPE} MATCHES win32cui)
         set_subsystem(${MODULE} console)
         set_entrypoint(${MODULE} mainCRTStartup)
         if(NOT IS_UNICODE)
@@ -126,34 +195,34 @@ macro(set_module_type MODULE TYPE)
         else()
             target_link_libraries(${MODULE} mingw_wmain)
         endif(NOT IS_UNICODE)
-               target_link_libraries(${MODULE} mingw_common)
-    endif()
-    if(${TYPE} MATCHES win32dll)
-        set_entrypoint(${MODULE} DllMainCRTStartup@12)
+        target_link_libraries(${MODULE} mingw_common)
+    elseif(${TYPE} MATCHES win32dll)
+               set_entrypoint(${MODULE} DllMain 12)
         target_link_libraries(${MODULE} mingw_dllmain mingw_common)
-               if(DEFINED baseaddress_${MODULE})
-                       set_image_base(${MODULE} ${baseaddress_${MODULE}})
-               else()
-                       message(STATUS "${MODULE} has no base address")
-               endif()
-    endif()
-    if(${TYPE} MATCHES win32ocx)
-        set_entrypoint(${MODULE} DllMainCRTStartup@12)
+        if(DEFINED baseaddress_${MODULE})
+            set_image_base(${MODULE} ${baseaddress_${MODULE}})
+        else()
+            message(STATUS "${MODULE} has no base address")
+        endif()
+    elseif(${TYPE} MATCHES win32ocx)
+        set_entrypoint(${MODULE} DllMain 12)
         target_link_libraries(${MODULE} mingw_dllmain mingw_common)
         set_target_properties(${MODULE} PROPERTIES SUFFIX ".ocx")
-    endif()
-    if(${TYPE} MATCHES cpl)
-        set_entrypoint(${MODULE} DllMainCRTStartup@12)
+    elseif(${TYPE} MATCHES cpl)
+        set_entrypoint(${MODULE} DllMain 12)
         target_link_libraries(${MODULE} mingw_dllmain mingw_common)
         set_target_properties(${MODULE} PROPERTIES SUFFIX ".cpl")
-    endif()
-       if(${TYPE} MATCHES kernelmodedriver)
-           set_target_properties(${MODULE} PROPERTIES LINK_FLAGS "-Wl,--exclude-all-symbols -Wl,-file-alignment=0x1000 -Wl,-section-alignment=0x1000" SUFFIX ".sys")
-           set_entrypoint(${MODULE} DriverEntry@8)
-               set_subsystem(${MODULE} native)
+    elseif(${TYPE} MATCHES kernelmodedriver)
+        set_target_properties(${MODULE} PROPERTIES LINK_FLAGS "-Wl,--exclude-all-symbols -Wl,-file-alignment=0x1000 -Wl,-section-alignment=0x1000" SUFFIX ".sys")
+        set_entrypoint(${MODULE} DriverEntry 8)
+        set_subsystem(${MODULE} native)
         set_image_base(${MODULE} 0x00010000)
-               add_dependencies(${MODULE} bugcodes)
-       endif()
+        add_dependencies(${MODULE} bugcodes)
+    elseif(${TYPE} MATCHES nativedll)
+        set_subsystem(${MODULE} native)
+    else()
+        message(FATAL_ERROR "Unknown module type : ${TYPE}")
+    endif()
 endmacro()
 
 macro(set_unicode)
@@ -168,75 +237,102 @@ macro(set_rc_compiler)
 
     foreach(arg ${defines})
         set(rc_result_defs "${rc_result_defs} -D${arg}")
-    endforeach(arg ${defines})
+    endforeach()
 
     foreach(arg ${includes})
         set(rc_result_incs "-I${arg} ${rc_result_incs}")
-    endforeach(arg ${includes})
+    endforeach()
 
-    set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> ${rc_result_defs} ${rc_result_incs} -i <SOURCE> -O coff -o <OBJECT>")
+    #set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> ${rc_result_defs} ${rc_result_incs} -i <SOURCE> -O coff -o <OBJECT>")
+    set(CMAKE_RC_COMPILE_OBJECT
+    "<CMAKE_C_COMPILER> -DRC_INVOKED -D__WIN32__=1 -D__FLAT__=1 ${rc_result_defs} -I${CMAKE_CURRENT_SOURCE_DIR} ${rc_result_incs} -xc -E <SOURCE> -o <OBJECT>"
+    "${WRC} -I${CMAKE_CURRENT_SOURCE_DIR} -i <OBJECT> -o <OBJECT>"
+    "<CMAKE_RC_COMPILER> -i <OBJECT> -J res -O coff -o <OBJECT>")
 endmacro()
 
 #idl files support
 set(IDL_COMPILER native-widl)
-set(IDL_FLAGS -m32 --win32)
-set(IDL_HEADER_ARG -h -H) #.h
-set(IDL_TYPELIB_ARG -t -T) #.tlb
+
+if(ARCH MATCHES i386)
+    set(IDL_FLAGS -m32 --win32)
+elseif(ARCH MATCHES amd64)
+    set(IDL_FLAGS -m64 --win64)
+endif()
+
+set(IDL_HEADER_ARG -h -o) #.h
+set(IDL_TYPELIB_ARG -t -o) #.tlb
 set(IDL_SERVER_ARG -s -S) #.c for server library
 set(IDL_CLIENT_ARG -c -C) #.c for stub client library
 set(IDL_PROXY_ARG -p -P)
-set(IDL_DLLDATA_ARG --dlldata-only --dlldata=)
+set(IDL_INTERFACE_ARG -u -o)
+set(IDL_DLLDATA_ARG --dlldata-only -o)
+
 
 macro(add_importlibs MODULE)
+    add_dependency_node(${MODULE})
     foreach(LIB ${ARGN})
         target_link_libraries(${MODULE} ${CMAKE_BINARY_DIR}/importlibs/lib${LIB}.a)
         add_dependencies(${MODULE} lib${LIB})
+        add_dependency_edge(${MODULE} ${LIB})
     endforeach()
 endmacro()
 
-macro(add_importlib_target _spec_file)
-    get_filename_component(_name ${_spec_file} NAME_WE)
-    
-    if (${ARGC} GREATER 1)
-        set(DLLNAME_OPTION "-n=${ARGV1}")
+if(NOT ARCH MATCHES i386)
+    set(DECO_OPTION "-@")
+endif()
+
+macro(add_importlib_target _exports_file)
+
+    get_filename_component(_name ${_exports_file} NAME_WE)
+    get_filename_component(_extension ${_exports_file} EXT)
+    get_target_property(_suffix ${_name} SUFFIX)
+    if(${_suffix} STREQUAL "_suffix-NOTFOUND")
+        get_target_property(_type ${_name} TYPE)
+        if(${_type} MATCHES EXECUTABLE)
+            set(_suffix ".exe")
+        else()
+            set(_suffix ".dll")
+        endif()
+    endif()
+
+    if (${_extension} STREQUAL ".spec")
+
+        add_custom_command(
+            OUTPUT ${CMAKE_BINARY_DIR}/importlibs/lib${_name}.a
+            COMMAND native-spec2def -n=${_name}${_suffix} -a=${ARCH2} -d=${CMAKE_CURRENT_BINARY_DIR}/${_name}_implib.def ${CMAKE_CURRENT_SOURCE_DIR}/${_exports_file}
+            COMMAND ${MINGW_PREFIX}dlltool --def ${CMAKE_CURRENT_BINARY_DIR}/${_name}_implib.def --kill-at --output-lib=${CMAKE_BINARY_DIR}/importlibs/lib${_name}.a
+            DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${_exports_file})
+
+    elseif(${_extension} STREQUAL ".def")
+        message("Use of def files for import libs is deprecated: ${_exports_file}")
+        add_custom_command(
+            OUTPUT ${CMAKE_BINARY_DIR}/importlibs/lib${_name}.a
+            COMMAND ${MINGW_PREFIX}dlltool --def ${CMAKE_CURRENT_SOURCE_DIR}/${_exports_file} --kill-at --output-lib=${CMAKE_BINARY_DIR}/importlibs/lib${_name}.a
+            DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${_exports_file})
     else()
-        set(DLLNAME_OPTION "")
+        message(FATAL_ERROR "Unsupported exports file extension: ${_extension}")
     endif()
-    
-    add_custom_command(
-        OUTPUT ${CMAKE_BINARY_DIR}/importlibs/lib${_name}.a
-        COMMAND native-spec2def ${DLLNAME_OPTION} -d=${CMAKE_CURRENT_BINARY_DIR}/${_name}.def ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file}
-        COMMAND ${MINGW_PREFIX}dlltool --def ${CMAKE_CURRENT_BINARY_DIR}/${_name}.def --kill-at --output-lib=${CMAKE_BINARY_DIR}/importlibs/lib${_name}.a
-        DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file})
+
     add_custom_target(
         lib${_name}
         DEPENDS ${CMAKE_BINARY_DIR}/importlibs/lib${_name}.a)
+
 endmacro()
 
 macro(spec2def _dllname _spec_file)
     get_filename_component(_file ${_spec_file} NAME_WE)
     add_custom_command(
         OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${_file}.def ${CMAKE_CURRENT_BINARY_DIR}/${_file}_stubs.c
-        COMMAND native-spec2def -n=${_dllname} -d=${CMAKE_CURRENT_BINARY_DIR}/${_file}.def -s=${CMAKE_CURRENT_BINARY_DIR}/${_file}_stubs.c ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file}
+        COMMAND native-spec2def -n=${_dllname} --kill-at -a=${ARCH2} -d=${CMAKE_CURRENT_BINARY_DIR}/${_file}.def -s=${CMAKE_CURRENT_BINARY_DIR}/${_file}_stubs.c ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file}
         DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file})
     set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${_file}.def
         PROPERTIES GENERATED TRUE EXTERNAL_OBJECT TRUE)
     set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${_file}_stubs.c PROPERTIES GENERATED TRUE)
-    list(APPEND SOURCE ${CMAKE_CURRENT_BINARY_DIR}/${_file}_stubs.c)
 endmacro()
 
-# Optional 3rd parameter: dllname
-macro(set_export_spec _module _spec_file)
-    get_filename_component(_file ${_spec_file} NAME_WE)
-    if (${ARGC} GREATER 2)
-        set(_dllname ${ARGV2})
-    else()
-        set(_dllname ${_file}.dll)
-    endif()
-    spec2def(${_dllname} ${_spec_file})
+macro(macro_mc FILE)
+    set(COMMAND_MC ${MINGW_PREFIX}windmc -A -b ${CMAKE_CURRENT_SOURCE_DIR}/${FILE}.mc -r ${REACTOS_BINARY_DIR}/include/reactos -h ${REACTOS_BINARY_DIR}/include/reactos)
 endmacro()
 
 #pseh lib, needed with mingw
 set(PSEH_LIB "pseh")
-
-endif()