[CMAKE]
[reactos.git] / boot / CMakeLists.txt
index 6de591b..866c10a 100644 (file)
@@ -9,17 +9,29 @@ CreateBootSectorTarget(isobtrt ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/bootsect/isob
 include_directories(BEFORE freeldr/freeldr/include)
 include_directories(${REACTOS_SOURCE_DIR}/ntoskrnl/include)
 
+if(ARCH MATCHES arm)
+    if(SARCH MATCHES omap-zoom2)
+        add_definitions(-D_ZOOM2_)
+    endif()
+endif()
+
 if(ARCH MATCHES i386)
+if(MSVC)
+list(APPEND FREELDR_BASE64K_SOURCE
+    freeldr/freeldr/arch/i386/realmode.S)
+else()
 list(APPEND FREELDR_STARTUP_SOURCE
     freeldr/freeldr/arch/i386/fathelp.S
     freeldr/freeldr/arch/i386/arch.S)
+endif()
 elseif(ARCH MATCHES amd64)
 list(APPEND FREELDR_STARTUP_SOURCE
-    freeldr/freeldr/arch/amd64/fathelp.S
+    freeldr/freeldr/arch/i386/fathelp.S
     freeldr/freeldr/arch/amd64/arch.S)
 endif(ARCH MATCHES i386)
 
 if(ARCH MATCHES i386)
+if(NOT MSVC)
 list(APPEND FREELDR_BASE64K_SOURCE
     freeldr/freeldr/arch/i386/boot.S
     freeldr/freeldr/arch/i386/drvmap.S
@@ -29,13 +41,15 @@ list(APPEND FREELDR_BASE64K_SOURCE
     freeldr/freeldr/arch/i386/i386trap.S
     freeldr/freeldr/arch/i386/int386.S
     freeldr/freeldr/arch/i386/linux.S
-    freeldr/freeldr/arch/i386/mb.S)
+    freeldr/freeldr/arch/i386/mb.S
+    freeldr/freeldr/arch/i386/i386bug.c)
+endif()
 elseif(ARCH MATCHES amd64)
 list(APPEND FREELDR_BASE64K_SOURCE
-    freeldr/freeldr/arch/amd64/drvmap.S
-    freeldr/freeldr/arch/amd64/i386cpu.S
-    freeldr/freeldr/arch/amd64/i386idt.S
-    freeldr/freeldr/arch/amd64/i386trap.S
+    freeldr/freeldr/arch/i386/drvmap.S
+    freeldr/freeldr/arch/i386/i386cpu.S
+    freeldr/freeldr/arch/i386/i386idt.S
+    freeldr/freeldr/arch/i386/i386trap.S
     freeldr/freeldr/arch/amd64/mb.S)
 endif(ARCH MATCHES i386)
 
@@ -52,6 +66,7 @@ list(APPEND FREELDR_BASE_SOURCE
     freeldr/freeldr/disk/disk.c
     freeldr/freeldr/disk/partition.c
     freeldr/freeldr/disk/ramdisk.c
+    freeldr/freeldr/disk/scsiport.c
     freeldr/freeldr/fs/ext2.c
     freeldr/freeldr/fs/fat.c
     freeldr/freeldr/fs/fs.c
@@ -95,7 +110,9 @@ list(APPEND FREELDR_BASE_SOURCE
     freeldr/freeldr/oslist.c)
 
 if(ARCH MATCHES i386)
-list(APPEND FREELDR_BASE_SOURCE freeldr/freeldr/disk/scsiport.c)
+list(APPEND FREELDR_BASE_SOURCE
+    freeldr/freeldr/windows/headless.c
+    freeldr/freeldr/disk/scsiport.c)
 endif(ARCH MATCHES i386)
 
 set_source_files_properties(${FREELDR_BASE_SOURCE} PROPERTIES COMPILE_DEFINITIONS "_NTHAL_;_BLDR_;_NTSYSTEM_")
@@ -105,7 +122,6 @@ include_directories(${REACTOS_SOURCE_DIR}/include/reactos/elf)
 
 if(ARCH MATCHES i386)
 list(APPEND FREELDR_ARCH_SOURCE
-    freeldr/freeldr/arch/i386/_alloca.S
     freeldr/freeldr/arch/i386/archmach.c
     freeldr/freeldr/arch/i386/custom.c
     freeldr/freeldr/arch/i386/drivemap.c
@@ -169,18 +185,29 @@ add_library(freeldr SHARED
     ${CMAKE_CURRENT_BINARY_DIR}/freeldr_freeldr.h.gch
     ${FREELDR_SOURCE})
 
-set_target_properties(freeldr PROPERTIES LINK_FLAGS "-Wl,--strip-all -Wl,-entry,_mainCRTStartup -Wl,--image-base,0x8000 -Wl,--exclude-all-symbols -Wl,--subsystem,native -Wl,--file-alignment,0x1000" SUFFIX ".sys")
+if(NOT MSVC)
+set_target_properties(freeldr PROPERTIES LINK_FLAGS "-Wl,--strip-all -Wl,--exclude-all-symbols -Wl,--file-alignment,0x1000 -Wl,-T,${CMAKE_CURRENT_SOURCE_DIR}/freeldr/freeldr/freeldr_i386.lnk" SUFFIX ".sys")
+set_image_base(freeldr 0x8000)
+else()
+set_target_properties(freeldr PROPERTIES LINK_FLAGS "/DRIVER /FIXED /ALIGN:0x400 /SECTION:.text,ERW /SECTION:.data,RW /MERGE:.text16=.text /MERGE:.data=.text /MERGE:.rdata=.text /MERGE:.bss=.text /SUBSYSTEM:BOOT_APPLICATION" SUFFIX ".sys")
+set_image_base(freeldr 0x10000)
+endif()
+
+set_subsystem(freeldr native)
+set_entrypoint(freeldr mainCRTStartup)
 
 if(ARCH MATCHES i386)
 target_link_libraries(freeldr mini_hal)
 endif(ARCH MATCHES i386)
 
 target_link_libraries(freeldr
+    cportlib
     rossym
     cmlib
     rtl
     libcntpr)
 add_pch(freeldr ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/freeldr/include/freeldr.h ${FREELDR_SOURCE})
+add_dependencies(freeldr asm)
 
 list(APPEND SETUPLDR_SOURCE
     ${FREELDR_STARTUP_SOURCE}
@@ -191,14 +218,55 @@ list(APPEND SETUPLDR_SOURCE
 
 add_library(setupldr SHARED ${SETUPLDR_SOURCE})
 
-set_target_properties(setupldr PROPERTIES LINK_FLAGS "-Wl,--strip-all -Wl,-entry,_mainCRTStartup -Wl,--image-base,0x8000 -Wl,--exclude-all-symbols -Wl,--subsystem,native -Wl,--file-alignment,0x1000" SUFFIX ".sys" COMPILE_DEFINITIONS "FREELDR_REACTOS_SETUP")
+if(NOT MSVC)
+set_target_properties(setupldr PROPERTIES LINK_FLAGS "-Wl,--strip-all -Wl,--exclude-all-symbols -Wl,--file-alignment,0x1000 -Wl,-T,${CMAKE_CURRENT_SOURCE_DIR}/freeldr/freeldr/freeldr_i386.lnk" SUFFIX ".sys" COMPILE_DEFINITIONS "FREELDR_REACTOS_SETUP")
+set_image_base(setupldr 0x8000)
+else()
+set_target_properties(setupldr PROPERTIES LINK_FLAGS "/DRIVER /SECTION:.text,ERWP,ALIGN=0x1000" SUFFIX ".sys" COMPILE_DEFINITIONS "FREELDR_REACTOS_SETUP")
+endif()
+
+set_subsystem(setupldr native)
+set_entrypoint(setupldr mainCRTStartup)
 
 if(ARCH MATCHES i386)
 target_link_libraries(setupldr mini_hal)
 endif(ARCH MATCHES i386)
 
 target_link_libraries(setupldr
+    cportlib
     rossym
     cmlib
     rtl
     libcntpr)
+
+add_dependencies(setupldr asm)
+
+# Bootcd files
+add_minicd_target(setupldr loader setupldr.sys)
+add_minicd_target(freeldr loader freeldr.sys)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/txtsetup.sif reactos txtsetup.sif)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/bootcd.ini "" freeldr.ini)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/hivecls_${ARCH}.inf reactos hivecls.inf)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/hivedef_${ARCH}.inf reactos hivedef.inf)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/hivesft_${ARCH}.inf reactos hivesft.inf)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/hivesys_${ARCH}.inf reactos hivesys.inf)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/autorun.inf "" autorun.inf)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/icon.ico "" icon.ico)
+add_minicd(${CMAKE_CURRENT_SOURCE_DIR}/bootdata/readme.txt "" readme.txt)
+# Livecd files
+list(APPEND LIVECD_HIVES
+    ${CMAKE_CURRENT_SOURCE_DIR}/bootdata/livecd.inf
+    ${CMAKE_CURRENT_SOURCE_DIR}/bootdata/hiveinst_${ARCH}.inf)
+
+add_custom_command(
+    OUTPUT ${LIVECD_DIR}/reactos/system32/config/sam
+    COMMAND native-mkhive ${CMAKE_CURRENT_SOURCE_DIR}/bootdata ${LIVECD_DIR}/reactos/system32/config ${ARCH} ${LIVECD_HIVES}
+    DEPENDS native-mkhive)
+
+add_custom_target(livecd_hives DEPENDS ${LIVECD_DIR}/reactos/system32/config/sam)
+
+add_livecd_target(setupldr loader)
+add_livecd(${REACTOS_SOURCE_DIR}/boot/bootdata/livecd.ini "" freeldr.ini)
+
+#regtest
+add_cab(${REACTOS_SOURCE_DIR}/boot/bootdata/bootcdregtest/regtest.cmd 7)