More sensible dependencies scheme for configuration
[reactos.git] / reactos / ntoskrnl / Makefile
index 4d45ec5..cbdf1d6 100644 (file)
@@ -1,28 +1,60 @@
-# $Id: Makefile,v 1.18 2001/03/14 00:21:21 dwelch Exp $
+# $Id: Makefile,v 1.32 2001/04/10 22:13:22 dwelch Exp $
 #
 # ReactOS Operating System
 #
-PATH_TO_TOP = ..
 
 #
-# Architecture to build for
+# Path to the directory containing the root makefile
 #
-ARCH := i386
+PATH_TO_TOP := ..
 
-TARGETNAME = ntoskrnl
+#
+# Include details of the kernel configuration
+#
+include config
+
+#
+#
+#
+CONFIG :=
+
+ifeq ($(DBG), 1)
+CFLAGS_DBG := -g
+CONFIG += DBG
+else
+CFLAGS_DBG :=
+endif
+
+ifeq ($(KDBG), 1)
+OBJECTS_KDBG := dbg/kdb.o dbg/kdb_keyboard.o dbg/i386/kdb_help.o
+CONFIG += KDBG
+else
+OBJECTS_KDBG :=
+endif
+
+ifeq ($(MP), 1)
+CONFIG += MP
+else
+CONFIG += UP
+endif
+
+TARGETNAME := ntoskrnl
 
 OBJECTS_PATH = objects
 
 ASFLAGS = -Iinclude
-CFLAGS = -Iinclude -D__NTOSKRNL__ -DDBG -g -Wall -Werror 
-#         -W -Wpointer-arith -Wconversion -Wstrict-prototypes -Wundef \
-#       -Wmissing-prototypes -Wshadow\
-#CFLAGS += -DDBGPRINT_FILE_LOG
+CFLAGS = -Iinclude -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror 
 
-all: \
+include $(PATH_TO_TOP)/rules.mak
+
+all: $(EXE_PREFIX)depends$(EXE_POSTFIX) \
        $(OBJECTS_PATH) \
        $(TARGETNAME).nostrip.exe \
-       $(TARGETNAME).exe
+       $(TARGETNAME).exe \
+       $(TARGETNAME).sym
+
+$(EXE_PREFIX)depends$(EXE_POSTFIX): depends.c
+       $(HOST_CC) -o depends$(EXE_POSTFIX) depends.c
 
 #
 # Hardware Abstraction Layer (Hal)
@@ -87,7 +119,6 @@ OBJECTS_KE = \
        ke/dpc.o \
        ke/error.o \
        ke/event.o \
-       ke/kernel.o \
        ke/kqueue.o \
        ke/main.o \
        ke/mutex.o \
@@ -123,11 +154,6 @@ OBJECTS_MM = \
        mm/mpw.o \
        mm/pageop.o
 
-OBJECTS_MM_I386 = \
-       mm/i386/memsafe.o \
-       mm/i386/page.o \
-       mm/i386/pfault.o
-
 # I/O Subsystem (Io)
 OBJECTS_IO = \
        io/adapter.o \
@@ -235,9 +261,11 @@ OBJECTS_CM = \
 
 # Debugger Support (Dbg)
 OBJECTS_DBG = \
-       dbg/brkpoint.o \
+       dbg/dbgctrl.o \
        dbg/errinfo.o \
-       dbg/print.o
+       dbg/print.o \
+       dbg/user.o \
+       $(OBJECTS_KDBG)
 
 # Loader
 OBJECTS_LDR = \
@@ -497,9 +525,6 @@ $(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(TARGETNAME).a $(IE_DATA)
        - $(RM) temp.exp
 
 $(TARGETNAME).exe: $(TARGETNAME).o $(TARGETNAME).a
-       $(STRIP) \
-               --strip-debug \
-               $(TARGETNAME).o
        $(CC) \
                -Wl,-T,ntoskrnl.lnk \
                -nostartfiles -nostdlib \
@@ -520,7 +545,7 @@ $(TARGETNAME).exe: $(TARGETNAME).o $(TARGETNAME).a
                --kill-at
        - $(RM) base.tmp
        $(CC) \
-               -Wl,-T,ntoskrnl.lnk \
+               -Wl,-T,ntoskrnl.lnk -Wl,-s\
                -nostartfiles -nostdlib \
                -mdll \
                -o $(TARGETNAME).exe \
@@ -531,8 +556,9 @@ $(TARGETNAME).exe: $(TARGETNAME).o $(TARGETNAME).a
                -Wl,temp.exp \
                $(TARGETNAME).o -lgcc
        - $(RM) temp.exp
-       $(NM) --numeric-sort $(TARGETNAME).exe > $(TARGETNAME).sym
 
+$(TARGETNAME).sym: $(TARGETNAME).nostrip.exe
+       $(NM) --numeric-sort $(TARGETNAME).nostrip.exe > $(TARGETNAME).sym
 
 $(TARGETNAME).o: $(OBJECTS)
        $(LD) \
@@ -572,18 +598,25 @@ ex/napi.o: ex/napi.c ../include/ntdll/napi.h
 
 ke/main.o: ke/main.c ../include/reactos/buildno.h
 
+mkconfig$(EXE_SUFFIX): mkconfig.c
+       $(HOST_CC) -g -o mkconfig$(EXE_SUFFIX) mkconfig.c
+
+include/internal/config.h: config mkconfig$(EXE_SUFFIX)
+       $(EXE_PREFIX)mkconfig$(EXE_SUFFIX) include/internal/config.h$(CONFIG)
+
+ifneq ($(MAKECMDGOALS),clean)
 include $(D1_FILES)
+endif
 
-.%.d: %.c
-       $(CC) $(CFLAGS) -M $< | sed -f depends.sed | sed -e s#$(*F)$(DOT)o#$(@D)/$(*F).o#g -e s#$(DOT)$(*F)$(DOT)d#$(@D)/.$(*F).d#g > $@
+.%.d: %.c $(EXE_PREFIX)depends$(EXE_POSTFIX)
+       $(CC) $(CFLAGS) -M $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@
 
 .%.d: %.s
-       $(CC) $(CFLAGS) -M $< | sed -f depends.sed | sed -e s#$(*F)$(DOT)o#$(@D)/$(*F).o#g -e s#$(DOT)$(*F)$(DOT)d#$(@D)/.$(*F).d#g > $@
+       $(CC) $(CFLAGS) -M $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@ 
 
 .%.d: %.S
-       $(CC) $(CFLAGS) -M $< | sed -f depends.sed | sed -e s#$(*F)$(DOT)o#$(@D)/$(*F).o#g -e s#$(DOT)$(*F)$(DOT)d#$(@D)/.$(*F).d#g > $@
+       $(CC) $(CFLAGS) -M $< | $(EXE_PREFIX)depends$(EXE_POSTFIX) $(@D) $@
 
 
-include $(PATH_TO_TOP)/rules.mak
 
 # EOF