-# $Id: Makefile,v 1.35 2001/04/16 00:48:04 chorns Exp $
+# $Id: Makefile,v 1.88 2002/12/09 15:18:11 robd Exp $
#
# ReactOS Operating System
#
PATH_TO_TOP := ..
#
-# Include details of the kernel configuration
+# Include details of the host OS configuration
#
+include $(PATH_TO_TOP)/config
-include config
-
-#
-#
-#
CONFIG :=
ifeq ($(DBG), 1)
CFLAGS_DBG := -g
-CONFIG += DBG
+LINKER_SCRIPT := ntoskrnl.lnk
+STRIP_FLAGS := -Wl,-s
else
CFLAGS_DBG :=
+LINKER_SCRIPT := ntoskrnl.lnk
+STRIP_FLAGS := -Wl,-s
endif
ifeq ($(KDBG), 1)
-OBJECTS_KDBG := dbg/kdb.o dbg/kdb_keyboard.o dbg/i386/kdb_help.o
-CONFIG += KDBG
+OBJECTS_KDBG := dbg/kdb.o dbg/kdb_keyboard.o dbg/rdebug.o \
+ dbg/i386/kdb_help.o dbg/kdb_stabs.o
else
OBJECTS_KDBG :=
endif
-ifeq ($(MP), 1)
-CONFIG += MP
+ifeq ($(strip $(SDK_PATH_INC)),)
+ASFLAGS += -I./include
+CFLAGS += -I./include -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
else
-CONFIG += UP
+ASFLAGS += -I./include -I$(SDK_PATH_INC)
+CFLAGS += -I./include -I$(SDK_PATH_INC) -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
endif
-TARGETNAME := ntoskrnl
+#
+# Build configuration
+#
+include $(PATH_TO_TOP)/rules.mak
-OBJECTS_PATH = objects
-ASFLAGS = -Iinclude
-CFLAGS = -Iinclude -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
+TARGETNAME := ntoskrnl
-include $(PATH_TO_TOP)/rules.mak
+OBJECTS_PATH = objects
-all: $(EXE_PREFIX)depends$(EXE_POSTFIX) \
+all: \
$(OBJECTS_PATH) \
+ bugcodes.rc \
$(TARGETNAME).nostrip.exe \
$(TARGETNAME).exe \
- $(TARGETNAME).sym
-
-$(EXE_PREFIX)depends$(EXE_POSTFIX): depends.c
- $(HOST_CC) -o depends$(EXE_POSTFIX) depends.c
+ $(TARGETNAME).sym \
+ ntoskrnl.map
#
# Architecture specific Makefile
# System API (Nt/Zw)
OBJECTS_NT = \
- nt/atom.o \
nt/channel.o \
nt/evtpair.o \
nt/mutant.o \
# Run-Time Library (Rtl)
OBJECTS_RTL = \
+ rtl/atom.o \
rtl/bitmap.o \
+ rtl/compress.o \
rtl/ctype.o \
+ rtl/dos8dot3.o \
rtl/error.o \
- rtl/interlck.o \
+ rtl/handle.o \
rtl/largeint.o \
rtl/mem.o \
rtl/memchr.o \
rtl/memcpy.o \
rtl/memmove.o \
rtl/memset.o \
+ rtl/message.o \
rtl/nls.o \
+ rtl/purecall.o \
rtl/qsort.o \
rtl/regio.o \
rtl/sprintf.o \
rtl/string.o \
rtl/swprintf.o \
rtl/time.o \
+ rtl/timezone.o \
rtl/unicode.o \
rtl/wstring.o \
- rtl/bitops.o \
- rtl/memcmp.o
+ rtl/memcmp.o \
+ rtl/capture.o
+
+OBJECTS_RTL := $(filter-out $(RTL_EXCLUDE_FILTER), $(OBJECTS_RTL))
+
# Kernel (Ke)
OBJECTS_KE = \
ke/spinlock.o \
ke/timer.o \
ke/wait.o \
- ke/kthread.o
+ ke/kthread.o \
+ ke/queue.o
# Memory Manager (Mm)
OBJECTS_MM = \
mm/aspace.o \
mm/cont.o \
+ mm/drvlck.o \
mm/freelist.o \
mm/iospace.o \
mm/marea.o \
mm/mminit.o \
mm/kmap.o \
mm/mpw.o \
- mm/pageop.o
+ mm/pageop.o \
+ mm/balance.o \
+ mm/rmap.o \
+ mm/slab.o \
+ mm/anonmem.o \
+ mm/region.o
# I/O Subsystem (Io)
OBJECTS_IO = \
io/adapter.o \
+ io/arcname.o \
io/buildirp.o \
io/cancel.o \
io/cleanup.o \
io/create.o \
io/device.o \
io/dir.o \
- io/drvlck.o \
+ io/driver.o \
io/errlog.o \
io/error.o \
io/event.o \
io/iocomp.o \
io/ioctrl.o \
io/iomgr.o \
+ io/iowork.o \
io/irp.o \
io/lock.o \
io/mailslot.o \
io/mdl.o \
io/npipe.o \
io/page.o \
+ io/parttab.o \
io/pnpmgr.o \
+ io/pnproot.o \
io/process.o \
io/queue.o \
io/resource.o \
ps/create.o \
ps/idle.o \
ps/kill.o \
+ ps/locale.o \
ps/process.o \
ps/psmgr.o \
ps/thread.o \
ps/tinfo.o \
ps/debug.o \
- ps/suspend.o
+ ps/suspend.o \
+ ps/win32.o \
+ ps/w32call.o
# Executive Subsystem (Ex)
OBJECTS_EX = \
+ ex/btree.o \
ex/callback.o \
ex/fmutex.o \
+ ex/hashtab.o \
ex/init.o \
ex/interlck.o \
ex/list.o \
- ex/locale.o \
ex/lookas.o \
ex/napi.o \
ex/power.o \
ex/resource.o \
ex/time.o \
+ ex/stree.o \
ex/sysinfo.o \
+ ex/win32k.o \
ex/work.o \
ex/zone.o
OBJECTS_SE = \
se/access.o \
se/acl.o \
+ se/lsa.o \
se/luid.o \
se/priv.o \
se/sd.o \
# Configuration Manager (Registry)
OBJECTS_CM = \
- cm/registry.o
+ cm/import.o \
+ cm/registry.o \
+ cm/ntfunc.o \
+ cm/rtlfunc.o \
+ cm/regfile.o \
+ cm/regobj.o
# Debugger Support (Dbg)
OBJECTS_DBG = \
# Cache Manager (Cc)
OBJECTS_CC = \
cc/cacheman.o \
- cc/view.o
+ cc/view.o \
+ cc/copy.o \
+ cc/pin.o \
+ cc/misc.o
# Kernel Debugger Support (Kd)
OBJECTS_KD = \
kd/kdebug.o \
kd/service.o \
- kd/dlog.o
+ kd/dlog.o \
+ kd/gdbstub.o kd/mda.o
-C_OBJECTS := $(OBJECTS_NT) $(OBJECTS_HAL) $(OBJECTS_MM) $(OBJECTS_ARCH) \
+DEP_OBJECTS := $(OBJECTS_NT) $(OBJECTS_MM) $(OBJECTS_ARCH) \
$(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)
-D_FILES := $(filter-out ex/napi.%, $(filter-out nt/zw.%, $(C_OBJECTS:.o=.d)))
-D1_FILES := $(join $(dir $(D_FILES)), $(addprefix ., $(notdir $(D_FILES))))
+TAG_OBJECTS := $(join $(dir $(DEP_OBJECTS)),$(patsubst %.o, .%.TAG, $(notdir $(DEP_OBJECTS))))
+
+#
+# Include automatic dependancy tracking
+#
+DEP_EXCLUDE_FILTER := ex/napi.% nt/zw.%
+include $(PATH_TO_TOP)/tools/depend.mk
+
# Resources
OBJECTS_RESOURCE = \
$(OBJECTS_PATH):
mkdir $(OBJECTS_PATH)
+$(OBJECTS_RESOURCE): $(TARGETNAME).rc bugcodes.rc $(PATH_TO_TOP)/include/reactos/resource.h
+
#
# Build subsystem intermediate objects
#
-$(OBJECTS_PATH)/hal.o: $(OBJECTS_HAL)
- $(LD) \
- -r \
- -o $(OBJECTS_PATH)/hal.o \
- $(OBJECTS_HAL)
-
$(OBJECTS_PATH)/arch.o: $(OBJECTS_ARCH)
$(LD) -r -o $(OBJECTS_PATH)/arch.o $(OBJECTS_ARCH)
$(LD) \
-r \
-o $(OBJECTS_PATH)/ke.o \
- $(OBJECTS_KE)
+ $(OBJECTS_KE)
$(OBJECTS_PATH)/rtl.o: $(OBJECTS_RTL)
$(LD) \
$(LD) \
-r \
-o $(OBJECTS_PATH)/mm.o \
- $(OBJECTS_MM)
+ $(OBJECTS_MM)
$(OBJECTS_PATH)/ob.o: $(OBJECTS_OB)
$(LD) \
$(LD) \
-r \
-o $(OBJECTS_PATH)/cc.o \
- $(OBJECTS_CC)
+ $(OBJECTS_CC)
$(OBJECTS_PATH)/kd.o: $(OBJECTS_KD)
$(LD) \
-r \
-o $(OBJECTS_PATH)/kd.o \
- $(OBJECTS_KD)
-
-$(TARGETNAME).coff: $(TARGETNAME).rc ../include/reactos/resource.h
-
+ $(OBJECTS_KD)
# Note: arch.o MUST be the first file!!!
OBJECTS := \
$(OBJECTS_PATH)/arch.o \
$(OBJECTS_PATH)/ke.o \
- $(OBJECTS_PATH)/hal.o \
$(OBJECTS_PATH)/cc.o \
$(OBJECTS_PATH)/cm.o \
$(OBJECTS_PATH)/dbg.o \
$(OBJECTS_RESOURCE)
-ifeq ($(DOSCLI),yes)
-CLEAN_FILES = $(OBJECTS_PATH)\*.o cc\*.o cm\*.o dbg\*.o ex\*.o hal\x86\*.o io\*.o \
- ke\*.o ldr\*.o mm\*.o nt\*.o ob\*.o ps\*.o rtl\*.o se\*.o \
- ke\i386\*.o mm\i386\*.o fs\*.o po\*.o nls\*.o lpc\*.o \
- kd\*.o $(TARGETNAME).o $(TARGETNAME).a junk.tmp base.tmp temp.exp \
- $(TARGETNAME).exe $(TARGETNAME).nostrip.exe $(TARGETNAME).sym $(TARGETNAME).coff $(D1_FILES)
-else
-CLEAN_FILES = $(OBJECTS_PATH)/*.o cc/*.o cm/*.o dbg/*.o ex/*.o hal/x86/*.o io/*.o \
- ke/*.o ldr/*.o mm/*.o nt/*.o ob/*.o ps/*.o rtl/*.o se/*.o \
- ke/i386/*.o mm/i386/*.o fs/*.o po/*.o nls/*.o lpc/*.o \
- kd/*.o $(TARGETNAME).o $(TARGETNAME).a junk.tmp base.tmp temp.exp \
- $(TARGETNAME).exe $(TARGETNAME).nostrip.exe $(TARGETNAME).sym $(TARGETNAME).coff $(D1_FILES)
-endif
-
-
-$(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(TARGETNAME).a $(IE_DATA)
+$(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA)
$(CC) \
-Wl,-T,ntoskrnl.lnk \
- -nostartfiles -nostdlib \
+ -nostartfiles \
+ -nostdlib \
-mdll \
-o junk.tmp \
-Wl,--subsystem,native \
-Wl,--file-alignment,0x1000 \
-Wl,--section-alignment,0x1000 \
-Wl,--base-file,base.tmp \
- $(TARGETNAME).o -lgcc
+ $(TARGETNAME).o -lgcc \
+ $(DDK_PATH_LIB)/hal.a
- $(RM) junk.tmp
$(DLLTOOL) \
--dllname $(TARGETNAME).exe \
--kill-at
- $(RM) base.tmp
$(CC) \
- -nostartfiles -nostdlib \
+ -nostartfiles \
+ -nostdlib \
-Wl,-T,ntoskrnl.lnk \
-mdll \
-o $(TARGETNAME).nostrip.exe \
-Wl,--file-alignment,0x1000 \
-Wl,--section-alignment,0x1000 \
-Wl,temp.exp \
- $(TARGETNAME).o -lgcc
+ $(TARGETNAME).o -lgcc \
+ $(DDK_PATH_LIB)/hal.a
- $(RM) temp.exp
-$(TARGETNAME).exe: $(TARGETNAME).o $(TARGETNAME).a $(TARGETNAME).lnk
- $(CC) \
- -Wl,-T,ntoskrnl.lnk \
- -nostartfiles -nostdlib \
+$(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(DDK_PATH_LIB)/hal.a
+ - $(CC) \
+ -Wl,-T,$(LINKER_SCRIPT) \
+ -nostartfiles \
+ -nostdlib \
-mdll \
-o junk.tmp \
-Wl,--subsystem,native \
-Wl,--file-alignment,0x1000 \
-Wl,--section-alignment,0x1000 \
-Wl,--base-file,base.tmp \
- $(TARGETNAME).o -lgcc
+ $(TARGETNAME).o -lgcc \
+ $(DDK_PATH_LIB)/hal.a
- $(RM) junk.tmp
$(DLLTOOL) \
--dllname $(TARGETNAME).exe \
--kill-at
- $(RM) base.tmp
$(CC) \
- -Wl,-T,ntoskrnl.lnk -Wl,-s\
- -nostartfiles -nostdlib \
+ -Wl,-T,$(LINKER_SCRIPT) $(STRIP_FLAGS)\
+ -nostartfiles \
+ -nostdlib \
-mdll \
-o $(TARGETNAME).exe \
-Wl,--subsystem,native \
-Wl,--file-alignment,0x1000 \
-Wl,--section-alignment,0x1000 \
-Wl,temp.exp \
- $(TARGETNAME).o -lgcc
+ $(TARGETNAME).o -lgcc \
+ $(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
+ $(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,--base-file,base.tmp \
+ $(TARGETNAME).dbg.o -lgcc \
+ $(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,temp.exp \
+ $(TARGETNAME).dbg.o -lgcc \
+ $(DDK_PATH_LIB)/hal.a
- $(RM) temp.exp
$(TARGETNAME).sym: $(TARGETNAME).nostrip.exe
- $(NM) --numeric-sort $(TARGETNAME).nostrip.exe > $(TARGETNAME).sym
+ $(RSYM) $(TARGETNAME).nostrip.exe $(TARGETNAME).sym
+
+TAGS: $(TAG_OBJECTS)
+ etags $(addprefix -i , $(TAG_OBJECTS))
+
+ntoskrnl.map: $(TARGETNAME).nostrip.exe
+ $(NM) --numeric-sort $(TARGETNAME).nostrip.exe > ntoskrnl.map
$(TARGETNAME).o: $(OBJECTS)
$(LD) \
-o $(TARGETNAME).o \
$(OBJECTS)
-$(TARGETNAME).a: $(TARGETNAME).def
- $(DLLTOOL) \
+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 $(TARGETNAME).a \
+ --output-lib $(DDK_PATH_LIB)/$(TARGETNAME).a \
--kill-at
-clean: $(CLEAN_FILES:%=%_clean)
+implib: $(DDK_PATH_LIB)/$(TARGETNAME).a
-$(CLEAN_FILES:%=%_clean): %_clean:
- - $(RM) $*
+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 se/*.o ke/i386/*.o mm/i386/*.o fs/*.o po/*.o nls/*.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)
-.PHONY: clean $(CLEAN_FILES:%=%_clean)
-install: $(FLOPPY_DIR)/$(TARGETNAME).exe
+.PHONY: clean
-$(FLOPPY_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
- $(CP) $(TARGETNAME).exe $(FLOPPY_DIR)/$(TARGETNAME).exe
-
-.PHONY: install
+install: all $(INSTALL_DIR)/system32/$(TARGETNAME).exe $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
-dist: ../$(DIST_DIR)/$(TARGETNAME).exe
+$(INSTALL_DIR)/system32/$(TARGETNAME).exe: $(TARGETNAME).exe
+ $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/system32/$(TARGETNAME).exe
-../$(DIST_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
- $(CP) $(TARGETNAME).exe ../$(DIST_DIR)/$(TARGETNAME).exe
+$(INSTALL_DIR)/symbols/$(TARGETNAME).sym: $(TARGETNAME).sym
+ $(CP) $(TARGETNAME).sym $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
-.PHONY: dist
-
-ex/napi.o: ex/napi.c ../include/ntdll/napi.h
+.PHONY: install
-ke/main.o: ke/main.c ../include/reactos/buildno.h
+dist: $(DIST_DIR)/$(TARGETNAME).exe
-mkconfig$(EXE_SUFFIX): mkconfig.c
- $(HOST_CC) -g -o mkconfig$(EXE_SUFFIX) mkconfig.c
+$(DIST_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
+ $(CP) $(TARGETNAME).exe $(DIST_DIR)/$(TARGETNAME).exe
-config:
- $(EXE_PREFIX)mkconfig$(EXE_SUFFIX) include/internal/config.h $(CONFIG)
+.PHONY: dist
-include/internal/config.h: config mkconfig$(EXE_SUFFIX)
- $(EXE_PREFIX)mkconfig$(EXE_SUFFIX) include/internal/config.h$(CONFIG)
+ex/napi.o: ex/napi.c $(PATH_TO_TOP)/include/ntdll/napi.h
-ifneq ($(MAKECMDGOALS),clean)
-include $(D1_FILES)
-endif
+ke/main.o: ke/main.c $(PATH_TO_TOP)/include/reactos/buildno.h
-.%.d: %.c $(EXE_PREFIX)depends$(EXE_POSTFIX)
- $(CC) $(CFLAGS) -M $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@
+%.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) $(RCINC) $< -o $@
-.%.d: %.s
- $(CC) $(CFLAGS) -M $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@
+#
+#
+#
+.%.TAG: %.S
+ etags -o $@ $<
-.%.d: %.S
- $(CC) $(CFLAGS) -M $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@
+.%.TAG: %.s
+ etags -o $@ $<
-.%.d: %.asm
- $(NASM_CMD) $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@
+.%.TAG: %.c
+ etags -o $@ $^
# EOF