From: Timo Kreuzer Date: Sat, 13 Nov 2010 21:02:14 +0000 (+0000) Subject: [FREELDR] X-Git-Tag: backups/GSoC_2011/GSoC_Themes@51550~538 X-Git-Url: https://git.reactos.org/?p=reactos.git;a=commitdiff_plain;h=306ed4d40b29d4626c13c3721d6b82229fed3164 [FREELDR] Merge r49573 svn path=/branches/cmake-bringup/; revision=49574 --- 306ed4d40b29d4626c13c3721d6b82229fed3164 diff --cc boot/CMakeLists.txt index 7f2770c00c4,00000000000..20e6823dd93 mode 100644,000000..100644 --- a/boot/CMakeLists.txt +++ b/boot/CMakeLists.txt @@@ -1,234 -1,0 +1,235 @@@ + +CreateBootSectorTarget(dosmbr ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/bootsect/dosmbr.asm ${CMAKE_CURRENT_BINARY_DIR}/freeldr/bootsect/dosmbr.bin) +CreateBootSectorTarget(ext2 ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/bootsect/ext2.asm ${CMAKE_CURRENT_BINARY_DIR}/freeldr/bootsect/ext2.bin) +CreateBootSectorTarget(fat32 ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/bootsect/fat32.asm ${CMAKE_CURRENT_BINARY_DIR}/freeldr/bootsect/fat32.bin) +CreateBootSectorTarget(fat ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/bootsect/fat.asm ${CMAKE_CURRENT_BINARY_DIR}/freeldr/bootsect/fat.bin) +CreateBootSectorTarget(isoboot ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/bootsect/isoboot.asm ${CMAKE_CURRENT_BINARY_DIR}/freeldr/bootsect/isoboot.bin) +CreateBootSectorTarget(isobtrt ${CMAKE_CURRENT_SOURCE_DIR}/freeldr/bootsect/isobtrt.asm ${CMAKE_CURRENT_BINARY_DIR}/freeldr/bootsect/isobtrt.bin) + +include_directories(BEFORE freeldr/freeldr/include) +include_directories(${REACTOS_SOURCE_DIR}/ntoskrnl/include) + +if(ARCH MATCHES i386) +list(APPEND FREELDR_STARTUP_SOURCE + freeldr/freeldr/arch/i386/fathelp.S + freeldr/freeldr/arch/i386/arch.S) +elseif(ARCH MATCHES amd64) +list(APPEND FREELDR_STARTUP_SOURCE + freeldr/freeldr/arch/amd64/fathelp.S + freeldr/freeldr/arch/amd64/arch.S) +endif(ARCH MATCHES i386) + +if(ARCH MATCHES i386) +list(APPEND FREELDR_BASE64K_SOURCE + freeldr/freeldr/arch/i386/boot.S + freeldr/freeldr/arch/i386/drvmap.S + freeldr/freeldr/arch/i386/i386cpu.S + freeldr/freeldr/arch/i386/i386idt.S + freeldr/freeldr/arch/i386/i386pnp.S + 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/i386bug.c) +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/amd64/mb.S) +endif(ARCH MATCHES i386) + +set_source_files_properties(${FREELDR_BASE64K_SOURCE} PROPERTIES COMPILE_DEFINITIONS "_NTHAL_") + +include_directories(${REACTOS_SOURCE_DIR}/lib/cmlib) + +list(APPEND FREELDR_BASE_SOURCE + freeldr/freeldr/arcemul/mm.c + freeldr/freeldr/arcemul/time.c + freeldr/freeldr/cache/blocklist.c + freeldr/freeldr/cache/cache.c + freeldr/freeldr/comm/rs232.c + freeldr/freeldr/disk/disk.c + freeldr/freeldr/disk/partition.c + freeldr/freeldr/disk/ramdisk.c + freeldr/freeldr/fs/ext2.c + freeldr/freeldr/fs/fat.c + freeldr/freeldr/fs/fs.c + freeldr/freeldr/fs/iso.c + freeldr/freeldr/fs/ntfs.c + freeldr/freeldr/inifile/ini_init.c + freeldr/freeldr/inifile/inifile.c + freeldr/freeldr/inifile/parse.c + freeldr/freeldr/mm/meminit.c + freeldr/freeldr/mm/mm.c + freeldr/freeldr/reactos/registry.c + freeldr/freeldr/reactos/arcname.c + freeldr/freeldr/reactos/archwsup.c + freeldr/freeldr/reactos/binhive.c + freeldr/freeldr/reactos/reactos.c + freeldr/freeldr/reactos/imageldr.c + freeldr/freeldr/rtl/bget.c + freeldr/freeldr/rtl/libsupp.c + freeldr/freeldr/ui/directui.c + freeldr/freeldr/ui/gui.c + freeldr/freeldr/ui/minitui.c + freeldr/freeldr/ui/noui.c + freeldr/freeldr/ui/tui.c + freeldr/freeldr/ui/tuimenu.c + freeldr/freeldr/ui/ui.c + freeldr/freeldr/video/fade.c + freeldr/freeldr/video/palette.c + freeldr/freeldr/video/video.c + freeldr/freeldr/windows/conversion.c + freeldr/freeldr/windows/headless.c + freeldr/freeldr/windows/peloader.c + freeldr/freeldr/windows/winldr.c + freeldr/freeldr/windows/wlmemory.c + freeldr/freeldr/windows/wlregistry.c + freeldr/freeldr/freeldr.c + freeldr/freeldr/debug.c + freeldr/freeldr/version.c + freeldr/freeldr/cmdline.c + freeldr/freeldr/machine.c + freeldr/freeldr/options.c + freeldr/freeldr/linuxboot.c + freeldr/freeldr/oslist.c) + +if(ARCH MATCHES i386) +list(APPEND FREELDR_BASE_SOURCE freeldr/freeldr/disk/scsiport.c) +endif(ARCH MATCHES i386) + +set_source_files_properties(${FREELDR_BASE_SOURCE} PROPERTIES COMPILE_DEFINITIONS "_NTHAL_;_BLDR_;_NTSYSTEM_") + +include_directories(${REACTOS_SOURCE_DIR}/include/reactos/libs) +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 + freeldr/freeldr/arch/i386/halstub.c + freeldr/freeldr/arch/i386/hardware.c + freeldr/freeldr/arch/i386/hwacpi.c + freeldr/freeldr/arch/i386/hwapm.c + freeldr/freeldr/arch/i386/hwpci.c + freeldr/freeldr/arch/i386/i386disk.c + freeldr/freeldr/arch/i386/i386rtl.c + freeldr/freeldr/arch/i386/i386vid.c + freeldr/freeldr/arch/i386/loader.c + freeldr/freeldr/arch/i386/machpc.c + freeldr/freeldr/arch/i386/miscboot.c + freeldr/freeldr/arch/i386/ntoskrnl.c + freeldr/freeldr/arch/i386/pccons.c + freeldr/freeldr/arch/i386/pcdisk.c + freeldr/freeldr/arch/i386/pcmem.c + freeldr/freeldr/arch/i386/pcrtc.c + freeldr/freeldr/arch/i386/pcvideo.c + freeldr/freeldr/arch/i386/machxbox.c + freeldr/freeldr/arch/i386/xboxcons.c + freeldr/freeldr/arch/i386/xboxdisk.c + freeldr/freeldr/arch/i386/xboxfont.c + freeldr/freeldr/arch/i386/xboxhw.c + freeldr/freeldr/arch/i386/xboxi2c.c + freeldr/freeldr/arch/i386/xboxmem.c + freeldr/freeldr/arch/i386/xboxrtc.c + freeldr/freeldr/arch/i386/xboxvideo.c + freeldr/freeldr/windows/i386/ntsetup.c + freeldr/freeldr/windows/i386/wlmemory.c) +else() +#TBD +endif(ARCH MATCHES i386) + +set_source_files_properties(${FREELDR_ARCH_SOURCE} PROPERTIES COMPILE_DEFINITIONS "_NTHAL_;_BLDR_;_NTSYSTEM_") + +list(APPEND SETUPLDR_MAIN_SOURCE + freeldr/freeldr/bootmgr.c + freeldr/freeldr/inffile/inffile.c + freeldr/freeldr/reactos/setupldr.c) + +if(ARCH MATCHES i386) +list(APPEND SETUPLDR_MAIN_SOURCE freeldr/freeldr/windows/setupldr2.c) +elseif(ARCH MATCHES amd64) +list(APPEND SETUPLDR_MAIN_SOURCE freeldr/freeldr/windows/setupldr2.c) +endif(ARCH MATCHES i386) + +set_source_files_properties(${SETUPLDR_MAIN_SOURCE} PROPERTIES COMPILE_FLAGS "-ffreestanding -fno-builtin -fno-inline -fno-zero-initialized-in-bss") + + + +list(APPEND FREELDR_SOURCE + freeldr/freeldr/bootmgr.c + ${FREELDR_STARTUP_SOURCE} + ${FREELDR_BASE64K_SOURCE} + ${FREELDR_BASE_SOURCE} + ${FREELDR_ARCH_SOURCE}) + +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 -Wl,-T,${REACTOS_SOURCE_DIR}/global.lds" SUFFIX ".sys") + +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}) + +list(APPEND SETUPLDR_SOURCE + ${FREELDR_STARTUP_SOURCE} + ${FREELDR_BASE64K_SOURCE} + ${FREELDR_BASE_SOURCE} + ${FREELDR_ARCH_SOURCE} + ${SETUPLDR_MAIN_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 -Wl,-T,${REACTOS_SOURCE_DIR}/global.lds" SUFFIX ".sys" COMPILE_DEFINITIONS "FREELDR_REACTOS_SETUP") + +if(ARCH MATCHES i386) +target_link_libraries(setupldr mini_hal) +endif(ARCH MATCHES i386) + +target_link_libraries(setupldr + cportlib + rossym + cmlib + rtl + libcntpr) + +# 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) ++add_livecd(${REACTOS_SOURCE_DIR}/boot/bootdata/livecd.ini "" freeldr.ini) diff --cc boot/freeldr/freeldr/arch/i386/i386bug.c index 00000000000,989ce6ec9e1..989ce6ec9e1 mode 000000,100644..100644 --- a/boot/freeldr/freeldr/arch/i386/i386bug.c +++ b/boot/freeldr/freeldr/arch/i386/i386bug.c