-# $Id: Makefile,v 1.126 2004/06/23 21:03:43 ion Exp $
-#
-# ReactOS Operating System
-#
+preall: all
-#
-# Path to the directory containing the root makefile
-#
PATH_TO_TOP := ..
-#
-# Include details of the host OS configuration
-#
include $(PATH_TO_TOP)/config
+TARGET_REGTESTS = yes
+
+TARGET_TYPE = kernel
+
+TARGET_NAME = ntoskrnl
+
+TARGET_BASE = 0xc0000000
+
+TARGET_BOOTSTRAP = yes
+
CONFIG :=
-ifeq ($(DBG), 1)
-CFLAGS_DBG := -g
LINKER_SCRIPT := ntoskrnl.lnk
STRIP_FLAGS := -Wl,-s
+
+ifeq ($(OPTIMIZED), 1)
+CFLAGS_OPT := -O2 -Wno-strict-aliasing
else
-CFLAGS_DBG :=
-LINKER_SCRIPT := ntoskrnl.lnk
-STRIP_FLAGS := -Wl,-s
+CFLAGS_OPT :=
endif
ifeq ($(KDBG), 1)
OBJECTS_KDBG := dbg/kdb.o dbg/kdb_serial.o dbg/kdb_keyboard.o dbg/rdebug.o \
- dbg/i386/kdb_help.o dbg/kdb_stabs.o dbg/profile.o \
+ dbg/i386/kdb_help.o dbg/kdb_stabs.o dbg/kdb_symbols.o dbg/profile.o \
../dk/w32/lib/kjs.a dbg/i386/i386-dis.o
-CFLAGS += -I../lib/kjs/include
+CFLAGS_KDBG := -I../lib/kjs/include
preall: all
../dk/w32/lib/kjs.a:
OBJECTS_KDBG :=
endif
-ifeq ($(strip $(SDK_PATH_INC)),)
-ASFLAGS += -I./include
-CFLAGS += -I./include -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
-else
-ASFLAGS += -I./include -I$(SDK_PATH_INC)
-CFLAGS += -I./include -I$(SDK_PATH_INC) -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
-endif
-
-# ASFLAGS += -D__USE_W32API -D_NTOSKRNL_
-# CFLAGS += -D__USE_W32API -D_NTOSKRNL_
+TARGET_ASFLAGS = -I./include
+TARGET_CFLAGS = -I./include $(CFLAGS_KDBG) -Wall -Werror $(CFLAGS_OPT)
# require os code to explicitly request A/W version of structs/functions
-CFLAGS += -D_DISABLE_TIDENTS
-
-# no native setjmp/longjmp in the kernel
-CFLAGS += -D_SEH_NO_NATIVE_NLG
+TARGET_CFLAGS += -D_DISABLE_TIDENTS
-CFLAGS += $(STD_CFLAGS)
-ASFLAGS += $(STD_ASFLAGS)
-RCFLAGS += $(STD_RCFLAGS)
+# 3GB User Mode Memory Space support
+ifeq ($(3GB), 1)
+TARGET_CFLAGS += -D__3GB__
+TARGET_BASE = 0xC0000000
+else
+TARGET_BASE = 0x80000000
+endif
-#
-# Build configuration
-#
-include $(PATH_TO_TOP)/rules.mak
+# enable thread event pair features (NT4 only!)
+# TARGET_CFLAGS += -D_ENABLE_THRDEVTPAIR
#
# Javascript extension for kdb
#
-TARGETNAME := ntoskrnl
-
OBJECTS_PATH = objects
-all: $(OBJECTS_PATH) \
- bugcodes.rc $(PATH_TO_TOP)/include/reactos/bugcodes.h \
- $(TARGETNAME).nostrip.exe \
- $(TARGETNAME).exe \
- $(TARGETNAME).sym \
- ntoskrnl.map
-
#
# Architecture specific Makefile
# Defines $(OBJECTS_ARCH)
# System API (Nt/Zw)
OBJECTS_NT = \
nt/channel.o \
+ nt/efi.o \
nt/evtpair.o \
nt/mutant.o \
nt/misc.o \
# Run-Time Library (Rtl)
OBJECTS_RTL = \
rtl/atom.o \
- rtl/bit.o \
- rtl/bitmap.o \
rtl/capture.o \
rtl/ctype.o \
rtl/handle.o \
ke/catch.o \
ke/critical.o \
ke/dpc.o \
+ ke/device.o \
ke/error.o \
ke/event.o \
ke/kqueue.o \
ke/kthread.o \
+ ke/ipi.o \
ke/main.o \
ke/mutex.o \
ke/process.o \
+ ke/profile.o \
ke/queue.o \
ke/sem.o \
ke/spinlock.o \
mm/paging.o \
mm/pool.o \
mm/ppool.o \
+ mm/physical.o \
mm/region.o \
mm/rmap.o \
mm/section.o \
mm/slab.o \
+ mm/verifier.o \
mm/virtual.o \
mm/wset.o
OBJECTS_IO = \
io/adapter.o \
io/arcname.o \
+ io/bootlog.o \
io/buildirp.o \
io/cancel.o \
io/cleanup.o \
io/timer.o \
io/vpb.o \
io/wdm.o \
+ io/wmi.o \
io/xhaldisp.o \
io/xhaldrv.o
ob/namespc.o \
ob/ntobj.o \
ob/object.o \
+ ob/sdcache.o \
ob/security.o \
ob/symlink.o
# Process Manager (Ps)
OBJECTS_PS = \
+ ps/cid.o \
ps/create.o \
ps/debug.o \
ps/idle.o \
+ ps/job.o \
ps/kill.o \
ps/locale.o \
ps/process.o \
ex/napi.o \
ex/power.o \
ex/resource.o \
- ex/rundown.o \
+ ex/rundown.o \
ex/stree.o \
- ex/synch.o \
+ ex/synch.o \
ex/sysinfo.o \
- ex/time.o \
- ex/util.o \
+ ex/time.o \
+ ex/util.o \
ex/win32k.o \
ex/work.o \
ex/zone.o
# Kernel Debugger Support (Kd)
OBJECTS_KD = \
kd/dlog.o \
- kd/gdbstub.o \
+ kd/gdbstub.o \
kd/kdebug.o \
- kd/mda.o \
+ kd/mda.o \
kd/service.o
# Boot video (Inbv)
$(OBJECTS_IO) $(OBJECTS_KE) $(OBJECTS_OB) \
$(OBJECTS_PS) $(OBJECTS_EX) $(OBJECTS_CC) $(OBJECTS_FS) $(OBJECTS_SE) \
$(OBJECTS_DBG) $(OBJECTS_CM) $(OBJECTS_LDR) $(OBJECTS_LPC) \
- $(OBJECTS_PO) $(OBJECTS_KD) $(OBJECTS_RTL)
+ $(OBJECTS_PO) $(OBJECTS_KD) $(OBJECTS_RTL) $(OBJECTS_INBV)
TAG_OBJECTS := $(join $(dir $(DEP_OBJECTS)),$(patsubst %.o, .%.TAG, $(notdir $(DEP_OBJECTS))))
-#
-# Include automatic dependancy tracking
-#
-DEP_EXCLUDE_FILTER := ex/napi.% nt/zw.%
-GENERATED_HEADER_FILES := $(PATH_TO_TOP)/include/reactos/bugcodes.h
-include $(PATH_TO_TOP)/tools/depend.mk
+TARGET_PCH = include/ntoskrnl.h
# Resources
OBJECTS_RESOURCE = \
- $(TARGETNAME).coff
-
-# IMPORTS/EXPORTS
-IE_DATA = \
- $(TARGETNAME).def \
- $(TARGETNAME).edf
+ $(TARGET_NAME).coff
$(OBJECTS_PATH):
mkdir $(OBJECTS_PATH)
-$(OBJECTS_RESOURCE): $(TARGETNAME).rc bugcodes.rc $(PATH_TO_TOP)/include/reactos/resource.h
+$(OBJECTS_RESOURCE): $(TARGET_NAME).rc bugcodes.rc $(PATH_TO_TOP)/include/reactos/resource.h
#
# Build subsystem intermediate objects
$(OBJECTS_PATH)/inbv.o \
$(OBJECTS_RESOURCE)
+EXTRA_OBJECTS = $(PATH_TO_TOP)/include/reactos/bugcodes.h
+
+TARGET_OBJECTS = $(EXTRA_OBJECTS) $(OBJECTS)
-$(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA) $(SDK_PATH_LIB)/rtl.a $(SDK_PATH_LIB)/string.a $(SDK_PATH_LIB)/rosrtl.a
- $(CC) \
- -Wl,-T,ntoskrnl.lnk \
- -nostartfiles \
- -nostdlib \
- -mdll \
- -o junk.tmp \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
- -Wl,--base-file,base.tmp \
- $(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/rtl.a \
- $(SDK_PATH_LIB)/string.a \
- $(SDK_PATH_LIB)/rosrtl.a \
- $(DDK_PATH_LIB)/hal.a
- - $(RM) junk.tmp
- $(DLLTOOL) \
- --dllname $(TARGETNAME).exe \
- --base-file base.tmp \
- --output-exp temp.exp \
- --def $(TARGETNAME).edf \
- --kill-at
- - $(RM) base.tmp
- $(CC) \
- -nostartfiles \
- -nostdlib \
- -Wl,-T,ntoskrnl.lnk \
- -mdll \
- -o $(TARGETNAME).nostrip.exe \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
- -Wl,temp.exp \
- $(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/rtl.a \
- $(SDK_PATH_LIB)/string.a \
- $(SDK_PATH_LIB)/rosrtl.a \
- $(DDK_PATH_LIB)/hal.a
- - $(RM) temp.exp
-
-$(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(DDK_PATH_LIB)/hal.a $(SDK_PATH_LIB)/rtl.a $(SDK_PATH_LIB)/string.a $(SDK_PATH_LIB)/rosrtl.a
- - $(CC) \
- -Wl,-T,$(LINKER_SCRIPT) \
- -nostartfiles \
- -nostdlib \
- -mdll \
- -o junk.tmp \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
- -Wl,--base-file,base.tmp \
- $(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/rtl.a \
- $(SDK_PATH_LIB)/string.a \
- $(SDK_PATH_LIB)/rosrtl.a \
- $(DDK_PATH_LIB)/hal.a
- - $(RM) junk.tmp
- $(DLLTOOL) \
- --dllname $(TARGETNAME).exe \
- --base-file base.tmp \
- --output-exp temp.exp \
- --def $(TARGETNAME).edf \
- --kill-at
- - $(RM) base.tmp
- $(CC) \
- -Wl,-T,$(LINKER_SCRIPT) $(STRIP_FLAGS)\
- -nostartfiles \
- -nostdlib \
- -mdll \
- -o $(TARGETNAME).exe \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
- -Wl,temp.exp \
- $(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/rtl.a \
- $(SDK_PATH_LIB)/string.a \
- $(SDK_PATH_LIB)/rosrtl.a \
- $(DDK_PATH_LIB)/hal.a
- - $(RM) temp.exp
-
-$(TARGETNAME).dbg.o: $(TARGETNAME).o
- $(STRIP) --strip-debug -o $(TARGETNAME).dbg.o $(TARGETNAME).o
-
-$(TARGETNAME).dbg: $(TARGETNAME).dbg.o $(TARGETNAME).a $(TARGETNAME).dbg.lnk $(DDK_PATH_LIB)/hal.a $(SDK_PATH_LIB)/rtl.a $(SDK_PATH_LIB)/string.a $(SDK_PATH_LIB)/rosrtl.a
- $(CC) \
- -Wl,-T,$(TARGETNAME).dbg.lnk \
- -nostartfiles \
- -nostdlib \
- -mdll \
- -o junk.tmp \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
- -Wl,--base-file,base.tmp \
- $(TARGETNAME).dbg.o -lgcc \
- $(SDK_PATH_LIB)/rtl.a \
- $(SDK_PATH_LIB)/string.a \
- $(SDK_PATH_LIB)/rosrtl.a \
- $(DDK_PATH_LIB)/hal.a
- - $(RM) junk.tmp
- $(DLLTOOL) \
- --dllname $(TARGETNAME).dbg \
- --base-file base.tmp \
- --output-exp temp.exp \
- --def $(TARGETNAME).edf \
- --kill-at
- - $(RM) base.tmp
- $(CC) \
- -Wl,-T,$(TARGETNAME).dbg.lnk \
- -nostartfiles \
- -nostdlib \
- -mdll \
- -o $(TARGETNAME).dbg \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
- -Wl,temp.exp \
- $(TARGETNAME).dbg.o -lgcc \
- $(SDK_PATH_LIB)/rtl.a \
- $(SDK_PATH_LIB)/string.a \
- $(SDK_PATH_LIB)/rosrtl.a \
- $(DDK_PATH_LIB)/hal.a
- - $(RM) temp.exp
-
-$(TARGETNAME).sym: $(TARGETNAME).nostrip.exe
- $(RSYM) $(TARGETNAME).nostrip.exe $(TARGETNAME).sym
+TARGET_LIBS = \
+ $(DDK_PATH_LIB)/hal.a \
+ $(SDK_PATH_LIB)/rtl.a \
+ $(SDK_PATH_LIB)/string.a \
+ $(SDK_PATH_LIB)/rosrtl.a \
+ $(SDK_PATH_LIB)/pseh.a
+
+TARGET_LFLAGS = \
+ -Wl,-T,ntoskrnl.lnk \
+ -Wl,--subsystem,native \
+ -Wl,--image-base,$(TARGET_BASE) \
+ -Wl,--file-alignment,0x1000 \
+ -Wl,--section-alignment,0x1000 \
+ -Wl,--entry,_NtProcessStartup
TAGS: $(TAG_OBJECTS)
etags $(addprefix -i , $(TAG_OBJECTS))
-$(TARGETNAME).map: $(TARGETNAME).nostrip.exe
-ifeq ($(FULL_MAP),yes)
- $(OBJDUMP) -d -S $(TARGETNAME).nostrip.exe > $(TARGETNAME).map
-else
- $(NM) --numeric-sort $(TARGETNAME).nostrip.exe > $(TARGETNAME).map
-endif
-
-$(TARGETNAME).o: $(OBJECTS)
- $(LD) \
- -r \
- -o $(TARGETNAME).o \
- $(OBJECTS)
+GENERATED_HEADER_FILES := $(PATH_TO_TOP)/include/reactos/bugcodes.h
$(PATH_TO_TOP)/include/reactos/bugcodes.h bugcodes.rc: ntoskrnl.mc
$(MC) \
-H $(PATH_TO_TOP)/include/reactos/bugcodes.h \
-o bugcodes.rc \
- $(TARGETNAME).mc
-
-$(DDK_PATH_LIB)/$(TARGETNAME).a: $(TARGETNAME).def
- - $(DLLTOOL) \
- --dllname $(TARGETNAME).exe \
- --def $(TARGETNAME).def \
- --output-lib $(DDK_PATH_LIB)/$(TARGETNAME).a \
- --kill-at
-
-implib: $(DDK_PATH_LIB)/$(TARGETNAME).a
-
-clean:
- - $(RM) $(OBJECTS_PATH)/*.o cc/*.o cm/*.o dbg/*.o dbg/i386/*.o ex/*.o \
- ex/i386/*.o inbv/*.o io/*.o ke/*.o ldr/*.o mm/*.o nt/*.o ob/*.o ps/*.o \
- rtl/*.o rtl/i386/*.o se/*.o ke/i386/*.o mm/i386/*.o fs/*.o po/*.o \
- lpc/*.o kd/*.o $(TARGETNAME).o junk.tmp base.tmp temp.exp \
- $(TARGETNAME).exe $(TARGETNAME).nostrip.exe $(TARGETNAME).sym ntoskrnl.map \
- $(TARGETNAME).coff bugcodes.rc msg?????.bin $(DEP_FILES) \
- $(TAG_OBJECTS) $(PATH_TO_TOP)/include/reactos/bugcodes.h
-
-
-.PHONY: clean
-
-ifneq ($(BOOTCD_INSTALL),)
-
-install:
- - $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/$(TARGETNAME).exe
-
-else # BOOTCD_INSTALL
-
-install:
- - $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/system32/$(TARGETNAME).exe
- - $(CP) $(TARGETNAME).sym $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
-
-endif # BOOTCD_INSTALL
-
-
-.PHONY: install
-
-bootcd:
- - $(CP) $(TARGETNAME).exe $(BOOTCD_DIR)/reactos/$(TARGETNAME).exe
-
-.PHONY: bootcd
+ $(TARGET_NAME).mc
+TARGET_CLEAN = \
+ $(PATH_TO_TOP)/include/reactos/bugcodes.h \
+ $(DEP_OBJECTS) $(DEP_FILES) MSG00409.bin bugcodes.rc
ex/napi.o: ex/napi.c $(PATH_TO_TOP)/include/ntdll/napi.h
ke/main.o: ke/main.c $(PATH_TO_TOP)/include/reactos/buildno.h
-%.o: %.cc
- $(CC) $(CFLAGS) -c $< -o $@
-%.o: %.c
- $(CC) $(CFLAGS) -c $< -o $@
-%.o: %.S
- $(AS) $(ASFLAGS) -c $< -o $@
-%.o: %.s
- $(AS) $(ASFLAGS) -c $< -o $@
-%.o: %.asm
- $(NASM_CMD) $(NFLAGS) $< -o $@
-%.coff: %.rc
- $(RC) $(RCFLAGS) $< -o $@
+$(TARGET_PCH): $(PATH_TO_TOP)/include/reactos/bugcodes.h
+
-#
-#
-#
.%.TAG: %.S
etags -o $@ $<
.PHONY: docu
+include $(PATH_TO_TOP)/rules.mak
+
+include $(TOOLS_PATH)/helper.mk
-# EOF
+include $(TOOLS_PATH)/depend.mk