Rollback removal of auto-dependancy checking.
[reactos.git] / reactos / ntoskrnl / Makefile
index c10616e..d134a4e 100644 (file)
@@ -1,4 +1,4 @@
-# $Id: Makefile,v 1.60 2001/12/31 01:53:44 dwelch Exp $
+# $Id: Makefile,v 1.88 2002/12/09 15:18:11 robd Exp $
 #
 # ReactOS Operating System
 #
@@ -27,7 +27,7 @@ endif
 
 ifeq ($(KDBG), 1)
 OBJECTS_KDBG := dbg/kdb.o dbg/kdb_keyboard.o dbg/rdebug.o \
-                dbg/i386/kdb_help.o
+                dbg/i386/kdb_help.o dbg/kdb_stabs.o
 else
 OBJECTS_KDBG :=
 endif
@@ -52,9 +52,11 @@ OBJECTS_PATH = objects
 
 all: \
        $(OBJECTS_PATH) \
+       bugcodes.rc \
        $(TARGETNAME).nostrip.exe \
        $(TARGETNAME).exe \
-       $(TARGETNAME).sym 
+       $(TARGETNAME).sym \
+       ntoskrnl.map
 
 #
 # Architecture specific Makefile
@@ -81,7 +83,9 @@ OBJECTS_NT = \
 OBJECTS_RTL = \
        rtl/atom.o \
        rtl/bitmap.o \
+       rtl/compress.o \
        rtl/ctype.o \
+       rtl/dos8dot3.o \
        rtl/error.o \
        rtl/handle.o \
        rtl/largeint.o \
@@ -92,9 +96,9 @@ OBJECTS_RTL = \
        rtl/memset.o \
        rtl/message.o \
        rtl/nls.o \
+       rtl/purecall.o \
        rtl/qsort.o \
        rtl/regio.o \
-       rtl/seh.o \
        rtl/sprintf.o \
        rtl/stdlib.o \
        rtl/string.o \
@@ -103,10 +107,12 @@ OBJECTS_RTL = \
        rtl/timezone.o \
        rtl/unicode.o \
        rtl/wstring.o \
-       rtl/bitops.o \
        rtl/memcmp.o \
        rtl/capture.o
 
+OBJECTS_RTL := $(filter-out $(RTL_EXCLUDE_FILTER), $(OBJECTS_RTL))
+
+
 # Kernel (Ke)
 OBJECTS_KE = \
        ke/apc.o \
@@ -124,12 +130,14 @@ 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 \
@@ -151,11 +159,15 @@ OBJECTS_MM = \
        mm/mpw.o \
        mm/pageop.o \
        mm/balance.o \
-       mm/rmap.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 \
@@ -163,7 +175,7 @@ OBJECTS_IO = \
        io/create.o \
        io/device.o \
        io/dir.o \
-       io/drvlck.o \
+       io/driver.o \
        io/errlog.o \
        io/error.o \
        io/event.o \
@@ -173,6 +185,7 @@ OBJECTS_IO = \
        io/iocomp.o \
        io/ioctrl.o \
        io/iomgr.o \
+       io/iowork.o \
        io/irp.o \
        io/lock.o \
        io/mailslot.o \
@@ -214,12 +227,16 @@ OBJECTS_PS = \
        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 \
@@ -228,6 +245,7 @@ OBJECTS_EX = \
        ex/power.o \
        ex/resource.o \
        ex/time.o \
+  ex/stree.o \
        ex/sysinfo.o \
        ex/win32k.o \
        ex/work.o \
@@ -317,7 +335,8 @@ OBJECTS_CC = \
 OBJECTS_KD = \
        kd/kdebug.o \
        kd/service.o \
-       kd/dlog.o
+       kd/dlog.o \
+  kd/gdbstub.o kd/mda.o
 
 DEP_OBJECTS := $(OBJECTS_NT) $(OBJECTS_MM) $(OBJECTS_ARCH) \
        $(OBJECTS_IO) $(OBJECTS_KE) $(OBJECTS_OB) \
@@ -325,10 +344,12 @@ DEP_OBJECTS := $(OBJECTS_NT) $(OBJECTS_MM) $(OBJECTS_ARCH) \
        $(OBJECTS_DBG) $(OBJECTS_CM) $(OBJECTS_LDR) $(OBJECTS_LPC) \
        $(OBJECTS_PO) $(OBJECTS_KD) $(OBJECTS_RTL)
 
+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
 
 
@@ -344,7 +365,7 @@ IE_DATA = \
 $(OBJECTS_PATH):
        mkdir $(OBJECTS_PATH)
 
-$(OBJECTS_RESOURCE): $(TARGETNAME).rc $(PATH_TO_TOP)/include/reactos/resource.h
+$(OBJECTS_RESOURCE): $(TARGETNAME).rc bugcodes.rc $(PATH_TO_TOP)/include/reactos/resource.h
 
 #
 # Build subsystem intermediate objects
@@ -362,7 +383,7 @@ $(OBJECTS_PATH)/ke.o: $(OBJECTS_KE)
        $(LD) \
                -r \
                -o $(OBJECTS_PATH)/ke.o \
-               $(OBJECTS_KE) 
+               $(OBJECTS_KE)
 
 $(OBJECTS_PATH)/rtl.o: $(OBJECTS_RTL)
        $(LD) \
@@ -374,7 +395,7 @@ $(OBJECTS_PATH)/mm.o: $(OBJECTS_MM)
        $(LD) \
                -r \
                -o $(OBJECTS_PATH)/mm.o \
-               $(OBJECTS_MM) 
+               $(OBJECTS_MM)
 
 $(OBJECTS_PATH)/ob.o: $(OBJECTS_OB)
        $(LD) \
@@ -452,13 +473,13 @@ $(OBJECTS_PATH)/cc.o: $(OBJECTS_CC)
        $(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) 
+               $(OBJECTS_KD)
 
 # Note: arch.o MUST be the first file!!!
 OBJECTS := \
@@ -483,12 +504,6 @@ OBJECTS := \
        $(OBJECTS_PATH)/se.o \
        $(OBJECTS_RESOURCE)
 
-CLEAN_FILES = $(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 \
-                   $(TARGETNAME).coff $(DEP_FILES)
 
 $(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA)
        $(CC) \
@@ -605,7 +620,13 @@ $(TARGETNAME).dbg: $(TARGETNAME).dbg.o $(TARGETNAME).a $(TARGETNAME).dbg.lnk
        - $(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) \
@@ -613,23 +634,41 @@ $(TARGETNAME).o: $(OBJECTS)
                -o $(TARGETNAME).o \
                $(OBJECTS)
 
-implib:
+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
 
-clean: 
-       - $(RM) $(CLEAN_FILES)
+implib: $(DDK_PATH_LIB)/$(TARGETNAME).a
 
-.PHONY: clean 
+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)
 
-install: all $(INSTALL_DIR)/system32/$(TARGETNAME).exe
+
+.PHONY: clean
+
+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
+
 .PHONY: install
 
 dist: $(DIST_DIR)/$(TARGETNAME).exe
@@ -650,10 +689,22 @@ ke/main.o: ke/main.c $(PATH_TO_TOP)/include/reactos/buildno.h
 %.o: %.S
        $(AS) $(ASFLAGS) -c $< -o $@
 %.o: %.s
-       $(AS) $(ASFLAGS) -c $< -o $@    
+       $(AS) $(ASFLAGS) -c $< -o $@
 %.o: %.asm
        $(NASM_CMD) $(NFLAGS) $< -o $@
 %.coff: %.rc
        $(RC) $(RCINC) $< -o $@
 
+#
+#
+#
+.%.TAG: %.S
+       etags -o $@ $<
+
+.%.TAG: %.s
+       etags -o $@ $<
+
+.%.TAG: %.c
+       etags -o $@ $^
+
 # EOF