Rollback removal of auto-dependancy checking.
[reactos.git] / reactos / ntoskrnl / Makefile
index 5d1d0f8..d134a4e 100644 (file)
@@ -1,42 +1,62 @@
-# $Id: Makefile,v 1.26 2001/03/25 18:56:12 dwelch Exp $
+# $Id: Makefile,v 1.88 2002/12/09 15:18:11 robd Exp $
 #
 # ReactOS Operating System
 #
-PATH_TO_TOP = ..
-
 
+#
+# Path to the directory containing the root makefile
+#
+PATH_TO_TOP := ..
 
 #
-# Architecture to build for
+# Include details of the host OS configuration
 #
-ARCH := i386
+include $(PATH_TO_TOP)/config
 
-TARGETNAME = ntoskrnl
+CONFIG :=
 
-OBJECTS_PATH = objects
+ifeq ($(DBG), 1)
+CFLAGS_DBG := -g
+LINKER_SCRIPT := ntoskrnl.lnk
+STRIP_FLAGS := -Wl,-s
+else
+CFLAGS_DBG :=
+LINKER_SCRIPT := ntoskrnl.lnk
+STRIP_FLAGS := -Wl,-s
+endif
 
-ASFLAGS = -Iinclude
-CFLAGS = -Iinclude -D__NTOSKRNL__ -DDBG -g -Wall -Werror 
-# -DDBGPRINT_FILE_LOG
-#         -W -Wpointer-arith -Wconversion -Wstrict-prototypes -Wundef \
-#       -Wmissing-prototypes -Wshadow\
-#CFLAGS = -DDBGPRINT_FILE_LOG
+ifeq ($(KDBG), 1)
+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 ($(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
+
+#
+# Build configuration
+#
 include $(PATH_TO_TOP)/rules.mak
 
-all: $(EXE_PREFIX)depends$(EXE_POSTFIX) \
-       $(OBJECTS_PATH) \
-       $(TARGETNAME).nostrip.exe \
-       $(TARGETNAME).exe
 
-$(EXE_PREFIX)depends$(EXE_POSTFIX): depends.c
-       $(HOST_CC) -o depends$(EXE_POSTFIX) depends.c
+TARGETNAME := ntoskrnl
 
-#
-# Hardware Abstraction Layer (Hal)
-# Defines $(OBJECTS_HAL)
-#
-include hal/x86/sources
+OBJECTS_PATH = objects
+
+all: \
+       $(OBJECTS_PATH) \
+       bugcodes.rc \
+       $(TARGETNAME).nostrip.exe \
+       $(TARGETNAME).exe \
+       $(TARGETNAME).sym \
+       ntoskrnl.map
 
 #
 # Architecture specific Makefile
@@ -46,7 +66,6 @@ include Makefile.$(ARCH)
 
 # System API (Nt/Zw)
 OBJECTS_NT = \
-       nt/atom.o \
        nt/channel.o \
        nt/evtpair.o \
        nt/mutant.o \
@@ -62,17 +81,22 @@ OBJECTS_NT = \
 
 # 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 \
@@ -80,13 +104,16 @@ OBJECTS_RTL = \
        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)
-# Note: head.o MUST be the first file!!!
 OBJECTS_KE = \
        ke/apc.o \
        ke/bug.o \
@@ -103,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 \
@@ -128,11 +157,17 @@ OBJECTS_MM = \
        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 \
@@ -140,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 \
@@ -150,12 +185,16 @@ OBJECTS_IO = \
        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 \
@@ -182,27 +221,33 @@ OBJECTS_PS = \
        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
 
@@ -224,6 +269,7 @@ OBJECTS_FS = \
 OBJECTS_SE = \
        se/access.o \
        se/acl.o \
+       se/lsa.o \
        se/luid.o \
        se/priv.o \
        se/sd.o \
@@ -233,14 +279,20 @@ OBJECTS_SE = \
 
 # 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 = \
        dbg/dbgctrl.o \
        dbg/errinfo.o \
        dbg/print.o \
-       dbg/user.o
+       dbg/user.o \
+       $(OBJECTS_KDBG)
 
 # Loader
 OBJECTS_LDR = \
@@ -274,22 +326,32 @@ OBJECTS_PO = po/power.o
 # 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 = \
@@ -303,15 +365,11 @@ IE_DATA = \
 $(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)
 
@@ -325,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) \
@@ -337,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) \
@@ -415,22 +473,18 @@ $(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) 
-
-$(TARGETNAME).coff: $(TARGETNAME).rc ../include/reactos/resource.h
+               $(OBJECTS_KD)
 
-
-# Note: ke.o MUST be the first file!!!
+# 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 \
@@ -451,25 +505,11 @@ OBJECTS := \
        $(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 \
@@ -477,7 +517,8 @@ $(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(TARGETNAME).a $(IE_DATA)
                -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 \
@@ -487,7 +528,8 @@ $(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(TARGETNAME).a $(IE_DATA)
                --kill-at
        - $(RM) base.tmp
        $(CC) \
-               -nostartfiles -nostdlib \
+               -nostartfiles \
+               -nostdlib \
                -Wl,-T,ntoskrnl.lnk \
                -mdll \
                -o $(TARGETNAME).nostrip.exe \
@@ -496,16 +538,15 @@ $(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(TARGETNAME).a $(IE_DATA)
                -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
-       $(STRIP) \
-               --strip-debug \
-               $(TARGETNAME).o
-       $(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 \
@@ -513,7 +554,8 @@ $(TARGETNAME).exe: $(TARGETNAME).o $(TARGETNAME).a
                -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 \
@@ -523,8 +565,9 @@ $(TARGETNAME).exe: $(TARGETNAME).o $(TARGETNAME).a
                --kill-at
        - $(RM) base.tmp
        $(CC) \
-               -Wl,-T,ntoskrnl.lnk \
-               -nostartfiles -nostdlib \
+               -Wl,-T,$(LINKER_SCRIPT) $(STRIP_FLAGS)\
+               -nostartfiles \
+               -nostdlib \
                -mdll \
                -o $(TARGETNAME).exe \
                -Wl,--subsystem,native \
@@ -532,10 +575,58 @@ $(TARGETNAME).exe: $(TARGETNAME).o $(TARGETNAME).a
                -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
-       $(NM) --numeric-sort $(TARGETNAME).exe > $(TARGETNAME).sym
 
+$(TARGETNAME).sym: $(TARGETNAME).nostrip.exe
+       $(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) \
@@ -543,49 +634,77 @@ $(TARGETNAME).o: $(OBJECTS)
                -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
+install: all $(INSTALL_DIR)/system32/$(TARGETNAME).exe $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
 
-.PHONY: install
+$(INSTALL_DIR)/system32/$(TARGETNAME).exe: $(TARGETNAME).exe
+       $(CP) $(TARGETNAME).exe $(INSTALL_DIR)/system32/$(TARGETNAME).exe
 
-dist: ../$(DIST_DIR)/$(TARGETNAME).exe
+$(INSTALL_DIR)/symbols/$(TARGETNAME).sym: $(TARGETNAME).sym
+       $(CP) $(TARGETNAME).sym $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
 
-../$(DIST_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
-       $(CP) $(TARGETNAME).exe ../$(DIST_DIR)/$(TARGETNAME).exe
+.PHONY: install
 
-.PHONY: dist
+dist: $(DIST_DIR)/$(TARGETNAME).exe
 
-ex/napi.o: ex/napi.c ../include/ntdll/napi.h
+$(DIST_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
+       $(CP) $(TARGETNAME).exe $(DIST_DIR)/$(TARGETNAME).exe
 
-ke/main.o: ke/main.c ../include/reactos/buildno.h
+.PHONY: dist
 
-include $(D1_FILES)
+ex/napi.o: ex/napi.c $(PATH_TO_TOP)/include/ntdll/napi.h
 
-.%.d: %.c $(EXE_PREFIX)depends$(EXE_POSTFIX)
-       $(CC) $(CFLAGS) -M $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@
+ke/main.o: ke/main.c $(PATH_TO_TOP)/include/reactos/buildno.h
 
-.%.d: %.s
-       $(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 $@ $<
 
+.%.TAG: %.s
+       etags -o $@ $<
 
+.%.TAG: %.c
+       etags -o $@ $^
 
 # EOF