-# $Id: Makefile,v 1.99 2003/06/11 12:29:49 ekohl Exp $
+# $Id: Makefile,v 1.137 2004/08/10 12:05:20 ekohl Exp $
#
# ReactOS Operating System
#
STRIP_FLAGS := -Wl,-s
endif
+ifeq ($(OPTIMIZED), 1)
+CFLAGS_OPT := -O2 -Wno-strict-aliasing
+else
+CFLAGS_OPT :=
+endif
+
ifeq ($(KDBG), 1)
-OBJECTS_KDBG := dbg/kdb.o dbg/kdb_keyboard.o dbg/rdebug.o \
- dbg/i386/kdb_help.o dbg/kdb_stabs.o dbg/profile.o
+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 \
+ ../dk/w32/lib/kjs.a dbg/i386/i386-dis.o
+CFLAGS += -I../lib/kjs/include
+preall: all
+
+../dk/w32/lib/kjs.a:
+ $(MAKE) -C ../lib/kjs
else
OBJECTS_KDBG :=
endif
ifeq ($(strip $(SDK_PATH_INC)),)
ASFLAGS += -I./include
-CFLAGS += -I./include -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
+CFLAGS += -I./include -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror $(CFLAGS_OPT)
else
ASFLAGS += -I./include -I$(SDK_PATH_INC)
-CFLAGS += -I./include -I$(SDK_PATH_INC) -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
+CFLAGS += -I./include -I$(SDK_PATH_INC) -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror $(CFLAGS_OPT)
endif
+# ASFLAGS += -D__USE_W32API -D_NTOSKRNL_
+# CFLAGS += -D__USE_W32API -D_NTOSKRNL_
+
+# 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
+
+CFLAGS += $(STD_CFLAGS)
+ASFLAGS += $(STD_ASFLAGS)
+RCFLAGS += $(STD_RCFLAGS)
+
#
# Build configuration
#
include $(PATH_TO_TOP)/rules.mak
+#
+# Javascript extension for kdb
+#
TARGETNAME := ntoskrnl
OBJECTS_PATH = objects
-all: \
- $(OBJECTS_PATH) \
- bugcodes.rc \
+all: $(OBJECTS_PATH) \
+ bugcodes.rc $(PATH_TO_TOP)/include/reactos/bugcodes.h \
$(TARGETNAME).nostrip.exe \
$(TARGETNAME).exe \
$(TARGETNAME).sym \
# System API (Nt/Zw)
OBJECTS_NT = \
nt/channel.o \
+ nt/efi.o \
nt/evtpair.o \
nt/mutant.o \
nt/misc.o \
nt/nttimer.o \
nt/plugplay.o \
nt/profile.o \
- nt/zw.o \
- nt/vdm.o
+ nt/vdm.o \
+ nt/zw.o
# Run-Time Library (Rtl)
OBJECTS_RTL = \
rtl/atom.o \
- rtl/bitmap.o \
- rtl/compress.o \
+ rtl/capture.o \
rtl/ctype.o \
- rtl/dos8dot3.o \
- rtl/error.o \
rtl/handle.o \
- rtl/largeint.o \
- rtl/mem.o \
rtl/message.o \
- rtl/nls.o \
rtl/purecall.o \
- rtl/qsort.o \
- rtl/random.o \
rtl/regio.o \
rtl/sprintf.o \
rtl/stdlib.o \
rtl/string.o \
rtl/swprintf.o \
- rtl/time.o \
- rtl/timezone.o \
- rtl/unicode.o \
rtl/wstring.o \
- rtl/capture.o
+ rtl/nls.o \
+ rtl/rangelist.o \
+ rtl/libsupp.o
OBJECTS_RTL := $(filter-out $(RTL_EXCLUDE_FILTER), $(OBJECTS_RTL))
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/main.o \
ke/mutex.o \
ke/process.o \
+ ke/profile.o \
+ ke/queue.o \
ke/sem.o \
ke/spinlock.o \
ke/timer.o \
- ke/wait.o \
- ke/kthread.o \
- ke/queue.o
+ ke/wait.o
# Memory Manager (Mm)
OBJECTS_MM = \
+ mm/anonmem.o \
mm/aspace.o \
+ mm/balance.o \
mm/cont.o \
mm/drvlck.o \
mm/freelist.o \
mm/iospace.o \
+ mm/kmap.o \
mm/marea.o \
mm/mdl.o \
mm/mm.o \
+ mm/mminit.o \
+ mm/mpw.o \
mm/ncache.o \
mm/npool.o \
mm/pagfault.o \
mm/pagefile.o \
+ mm/pageop.o \
+ mm/pager.o \
mm/paging.o \
mm/pool.o \
mm/ppool.o \
- mm/section.o \
- mm/virtual.o \
- mm/pager.o \
- mm/wset.o \
- mm/mminit.o \
- mm/kmap.o \
- mm/mpw.o \
- mm/pageop.o \
- mm/balance.o \
+ mm/physical.o \
+ mm/region.o \
mm/rmap.o \
+ mm/section.o \
mm/slab.o \
- mm/anonmem.o \
- mm/region.o
+ mm/verifier.o \
+ mm/virtual.o \
+ mm/wset.o
# I/O Subsystem (Io)
OBJECTS_IO = \
io/cntrller.o \
io/create.o \
io/device.o \
+ io/deviface.o \
io/dir.o \
io/driver.o \
io/errlog.o \
io/npipe.o \
io/page.o \
io/parttab.o \
+ io/process.o \
+ io/pnpnotify.o \
+ io/pnpdma.o \
io/pnpmgr.o \
+ io/pnpreport.o \
io/pnproot.o \
- io/process.o \
io/queue.o \
io/rawfs.o \
+ io/remlock.o \
io/resource.o \
io/rw.o \
io/share.o \
io/symlink.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/create.o \
+ ps/debug.o \
ps/idle.o \
+ ps/job.o \
ps/kill.o \
ps/locale.o \
ps/process.o \
ps/psmgr.o \
+ ps/suspend.o \
ps/thread.o \
ps/tinfo.o \
- ps/debug.o \
- ps/suspend.o \
ps/win32.o \
ps/w32call.o
# Executive Subsystem (Ex)
OBJECTS_EX = \
- ex/btree.o \
+ ex/btree.o \
ex/callback.o \
ex/fmutex.o \
- ex/hashtab.o \
+ ex/hashtab.o \
ex/init.o \
ex/interlck.o \
ex/list.o \
ex/napi.o \
ex/power.o \
ex/resource.o \
- ex/time.o \
- ex/stree.o \
+ ex/rundown.o \
+ ex/stree.o \
+ ex/synch.o \
ex/sysinfo.o \
+ ex/time.o \
+ ex/util.o \
ex/win32k.o \
ex/work.o \
ex/zone.o
OBJECTS_SE = \
se/access.o \
se/acl.o \
+ se/audit.o \
se/lsa.o \
se/luid.o \
se/priv.o \
# Configuration Manager (Registry)
OBJECTS_CM = \
cm/import.o \
- cm/registry.o \
cm/ntfunc.o \
- cm/rtlfunc.o \
cm/regfile.o \
- cm/regobj.o
+ cm/registry.o \
+ cm/regobj.o \
+ cm/rtlfunc.o
# Debugger Support (Dbg)
OBJECTS_DBG = \
lpc/send.o
# Power Management (Po)
-OBJECTS_PO = po/power.o
+OBJECTS_PO = \
+ po/power.o
# Cache Manager (Cc)
OBJECTS_CC = \
cc/cacheman.o \
- cc/view.o \
cc/copy.o \
+ cc/fs.o \
cc/pin.o \
- cc/misc.o
+ cc/mdl.o \
+ cc/misc.o \
+ cc/view.o
# Kernel Debugger Support (Kd)
OBJECTS_KD = \
- kd/kdebug.o \
- kd/service.o \
kd/dlog.o \
- kd/gdbstub.o \
- kd/mda.o
+ kd/gdbstub.o \
+ kd/kdebug.o \
+ kd/mda.o \
+ kd/service.o
+
+# Boot video (Inbv)
+OBJECTS_INBV = \
+ inbv/inbv.o
DEP_OBJECTS := $(OBJECTS_NT) $(OBJECTS_MM) $(OBJECTS_ARCH) \
$(OBJECTS_IO) $(OBJECTS_KE) $(OBJECTS_OB) \
# 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
-o $(OBJECTS_PATH)/kd.o \
$(OBJECTS_KD)
+$(OBJECTS_PATH)/inbv.o: $(OBJECTS_INBV)
+ $(LD) \
+ -r \
+ -o $(OBJECTS_PATH)/inbv.o \
+ $(OBJECTS_INBV)
+
# Note: arch.o MUST be the first file!!!
OBJECTS := \
$(OBJECTS_PATH)/arch.o \
$(OBJECTS_PATH)/ps.o \
$(OBJECTS_PATH)/rtl.o \
$(OBJECTS_PATH)/se.o \
+ $(OBJECTS_PATH)/inbv.o \
$(OBJECTS_RESOURCE)
-
-$(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA) $(SDK_PATH_LIB)/string.a
+NTOSKRNL_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
+
+NTOSKRNL_LD_FLAGS := \
+ -Wl,--subsystem,native \
+ -Wl,--image-base,0xc0000000 \
+ -Wl,--file-alignment,0x1000 \
+ -Wl,--section-alignment,0x1000 \
+ -Wl,--entry,_NtProcessStartup
+
+$(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA) $(NTOSKRNL_LIBS)
$(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 \
+ $(NTOSKRNL_LD_FLAGS) \
-Wl,--base-file,base.tmp \
$(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/string.a \
- $(DDK_PATH_LIB)/hal.a
+ $(NTOSKRNL_LIBS)
- $(RM) junk.tmp
$(DLLTOOL) \
--dllname $(TARGETNAME).exe \
-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 \
+ $(NTOSKRNL_LD_FLAGS) \
-Wl,temp.exp \
$(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/string.a \
- $(DDK_PATH_LIB)/hal.a
+ $(NTOSKRNL_LIBS)
- $(RM) temp.exp
-$(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(DDK_PATH_LIB)/hal.a $(SDK_PATH_LIB)/string.a
+$(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(NTOSKRNL_LIBS)
- $(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 \
+ $(NTOSKRNL_LD_FLAGS) \
-Wl,--base-file,base.tmp \
$(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/string.a \
- $(DDK_PATH_LIB)/hal.a
+ $(NTOSKRNL_LIBS)
- $(RM) junk.tmp
$(DLLTOOL) \
--dllname $(TARGETNAME).exe \
-nostdlib \
-mdll \
-o $(TARGETNAME).exe \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
+ $(NTOSKRNL_LD_FLAGS) \
-Wl,temp.exp \
$(TARGETNAME).o -lgcc \
- $(SDK_PATH_LIB)/string.a \
- $(DDK_PATH_LIB)/hal.a
+ $(NTOSKRNL_LIBS)
- $(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)/string.a
+$(TARGETNAME).dbg: $(TARGETNAME).dbg.o $(TARGETNAME).a $(TARGETNAME).dbg.lnk $(NTOSKRNL_LIBS)
$(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 \
+ $(NTOSKRNL_LD_FLAGS) \
-Wl,--base-file,base.tmp \
$(TARGETNAME).dbg.o -lgcc \
- $(SDK_PATH_LIB)/string.a \
- $(DDK_PATH_LIB)/hal.a
+ $(NTOSKRNL_LIBS)
- $(RM) junk.tmp
$(DLLTOOL) \
--dllname $(TARGETNAME).dbg \
-nostdlib \
-mdll \
-o $(TARGETNAME).dbg \
- -Wl,--subsystem,native \
- -Wl,--image-base,0xc0000000 \
- -Wl,--file-alignment,0x1000 \
- -Wl,--section-alignment,0x1000 \
- -Wl,--entry,_NtProcessStartup \
+ $(NTOSKRNL_LD_FLAGS) \
-Wl,temp.exp \
$(TARGETNAME).dbg.o -lgcc \
- $(SDK_PATH_LIB)/string.a \
- $(DDK_PATH_LIB)/hal.a
+ $(NTOSKRNL_LIBS)
- $(RM) temp.exp
$(TARGETNAME).sym: $(TARGETNAME).nostrip.exe
TAGS: $(TAG_OBJECTS)
etags $(addprefix -i , $(TAG_OBJECTS))
-ntoskrnl.map: $(TARGETNAME).nostrip.exe
- $(NM) --numeric-sort $(TARGETNAME).nostrip.exe > ntoskrnl.map
+$(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) \
-o $(TARGETNAME).o \
$(OBJECTS)
-bugcodes.rc: ntoskrnl.mc
+$(PATH_TO_TOP)/include/reactos/bugcodes.h bugcodes.rc: ntoskrnl.mc
$(MC) \
-H $(PATH_TO_TOP)/include/reactos/bugcodes.h \
-o bugcodes.rc \
implib: $(DDK_PATH_LIB)/$(TARGETNAME).a
+test:
+ -
+
clean:
- $(RM) $(OBJECTS_PATH)/*.o cc/*.o cm/*.o dbg/*.o dbg/i386/*.o ex/*.o \
- ex/i386/*.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)
+ ex/i386/*.o inbv/*.o io/*.o ke/*.o ldr/*.o mm/*.o nt/*.o ob/*.o \
+ ps/*.o ps/i386/*.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: all $(INSTALL_DIR)/$(TARGETNAME).exe
-
-$(INSTALL_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
- $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/$(TARGETNAME).exe
+install:
+ - $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/$(TARGETNAME).exe
else # BOOTCD_INSTALL
-install: all $(INSTALL_DIR)/system32/$(TARGETNAME).exe $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
-
-$(INSTALL_DIR)/system32/$(TARGETNAME).exe: $(TARGETNAME).exe
- $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/system32/$(TARGETNAME).exe
-
-$(INSTALL_DIR)/symbols/$(TARGETNAME).sym: $(TARGETNAME).sym
- $(CP) $(TARGETNAME).sym $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
+install:
+ - $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/system32/$(TARGETNAME).exe
+ - $(CP) $(TARGETNAME).sym $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
endif # BOOTCD_INSTALL
.PHONY: install
-dist: $(DIST_DIR)/$(TARGETNAME).exe
-
-$(DIST_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
- $(CP) $(TARGETNAME).exe $(DIST_DIR)/$(TARGETNAME).exe
-
-.PHONY: dist
-
-bootcd: all $(BOOTCD_DIR)/reactos/$(TARGETNAME).exe
-
-$(BOOTCD_DIR)/reactos/$(TARGETNAME).exe: $(TARGETNAME).exe
- $(CP) $(TARGETNAME).exe $(BOOTCD_DIR)/reactos/$(TARGETNAME).exe
+bootcd:
+ - $(CP) $(TARGETNAME).exe $(BOOTCD_DIR)/reactos/$(TARGETNAME).exe
.PHONY: bootcd
%.o: %.asm
$(NASM_CMD) $(NFLAGS) $< -o $@
%.coff: %.rc
- $(RC) $(RCINC) $< -o $@
+ $(RC) $(RCFLAGS) $< -o $@
#
#
.%.TAG: %.c
etags -o $@ $^
+
+docu:
+ doxygen Doxyfile
+
+.PHONY: docu
+
+
# EOF