2003-08-11 Casper S. Hornstrup <chorns@users.sourceforge.net>
[reactos.git] / reactos / ntoskrnl / Makefile
index a98d6e3..3b6b602 100644 (file)
@@ -1,4 +1,4 @@
-# $Id: Makefile,v 1.89 2003/01/07 17:48:11 robd Exp $
+# $Id: Makefile,v 1.104 2003/08/11 18:50:12 chorns 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/kdb_stabs.o
+                dbg/i386/kdb_help.o dbg/kdb_stabs.o dbg/profile.o
 else
 OBJECTS_KDBG :=
 endif
@@ -40,6 +40,12 @@ ASFLAGS += -I./include -I$(SDK_PATH_INC)
 CFLAGS += -I./include -I$(SDK_PATH_INC) -D__NTOSKRNL__ $(CFLAGS_DBG) -Wall -Werror
 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
+
 #
 # Build configuration
 #
@@ -89,16 +95,11 @@ OBJECTS_RTL = \
        rtl/error.o \
        rtl/handle.o \
        rtl/largeint.o \
-       rtl/math.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/random.o \
        rtl/regio.o \
        rtl/sprintf.o \
        rtl/stdlib.o \
@@ -108,7 +109,6 @@ OBJECTS_RTL = \
        rtl/timezone.o \
        rtl/unicode.o \
        rtl/wstring.o \
-       rtl/memcmp.o \
        rtl/capture.o
 
 OBJECTS_RTL := $(filter-out $(RTL_EXCLUDE_FILTER), $(OBJECTS_RTL))
@@ -198,6 +198,7 @@ OBJECTS_IO = \
        io/pnproot.o \
        io/process.o \
        io/queue.o \
+       io/rawfs.o \
        io/resource.o \
        io/rw.o \
        io/share.o \
@@ -215,7 +216,8 @@ OBJECTS_OB = \
        ob/namespc.o \
        ob/ntobj.o \
        ob/object.o \
-       ob/security.o
+       ob/security.o \
+       ob/symlink.o
 
 # Process Manager (Ps)
 OBJECTS_PS = \
@@ -270,6 +272,7 @@ OBJECTS_FS = \
 OBJECTS_SE = \
        se/access.o \
        se/acl.o \
+       se/audit.o \
        se/lsa.o \
        se/luid.o \
        se/priv.o \
@@ -318,9 +321,6 @@ OBJECTS_LPC = \
        lpc/reply.o \
        lpc/send.o
 
-# Nation Language Support Library (Nls)
-OBJECTS_NLS = nls/nls.o
-
 # Power Management (Po)
 OBJECTS_PO = po/power.o
 
@@ -340,6 +340,11 @@ OBJECTS_KD = \
     kd/gdbstub.o \
     kd/mda.o
 
+# Boot video (Inbv)
+OBJECTS_INBV = \
+       inbv/inbv.o \
+       inbv/bootvid.o
+
 DEP_OBJECTS := $(OBJECTS_NT) $(OBJECTS_MM) $(OBJECTS_ARCH) \
        $(OBJECTS_IO) $(OBJECTS_KE) $(OBJECTS_OB) \
        $(OBJECTS_PS) $(OBJECTS_EX) $(OBJECTS_CC) $(OBJECTS_FS) $(OBJECTS_SE) \
@@ -453,12 +458,6 @@ $(OBJECTS_PATH)/lpc.o: $(OBJECTS_LPC)
                -o $(OBJECTS_PATH)/lpc.o \
                $(OBJECTS_LPC)
 
-$(OBJECTS_PATH)/nls.o: $(OBJECTS_NLS)
-       $(LD) \
-               -r \
-               -o $(OBJECTS_PATH)/nls.o \
-               $(OBJECTS_NLS)
-
 $(OBJECTS_PATH)/nt.o: $(OBJECTS_NT)
        $(LD) \
                -r \
@@ -483,6 +482,12 @@ $(OBJECTS_PATH)/kd.o: $(OBJECTS_KD)
                -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 \
@@ -497,17 +502,17 @@ OBJECTS := \
        $(OBJECTS_PATH)/kd.o \
        $(OBJECTS_PATH)/ldr.o \
        $(OBJECTS_PATH)/mm.o \
-       $(OBJECTS_PATH)/nls.o \
        $(OBJECTS_PATH)/nt.o \
        $(OBJECTS_PATH)/ob.o \
        $(OBJECTS_PATH)/po.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)
+$(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA) $(SDK_PATH_LIB)/string.a $(SDK_PATH_LIB)/rosrtl.a 
        $(CC) \
                -Wl,-T,ntoskrnl.lnk \
                -nostartfiles \
@@ -518,8 +523,11 @@ $(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA)
                -Wl,--image-base,0xc0000000 \
                -Wl,--file-alignment,0x1000 \
                -Wl,--section-alignment,0x1000 \
+               -Wl,--entry,_NtProcessStartup \
                -Wl,--base-file,base.tmp \
                $(TARGETNAME).o -lgcc \
+               $(SDK_PATH_LIB)/string.a \
+               $(SDK_PATH_LIB)/rosrtl.a \
                $(DDK_PATH_LIB)/hal.a
        - $(RM) junk.tmp
        $(DLLTOOL) \
@@ -539,12 +547,15 @@ $(TARGETNAME).nostrip.exe: $(TARGETNAME).o $(IE_DATA)
                -Wl,--image-base,0xc0000000 \
                -Wl,--file-alignment,0x1000 \
                -Wl,--section-alignment,0x1000 \
+               -Wl,--entry,_NtProcessStartup \
                -Wl,temp.exp \
                $(TARGETNAME).o -lgcc \
+               $(SDK_PATH_LIB)/string.a \
+               $(SDK_PATH_LIB)/rosrtl.a \
                $(DDK_PATH_LIB)/hal.a
        - $(RM) temp.exp
 
-$(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(DDK_PATH_LIB)/hal.a
+$(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(DDK_PATH_LIB)/hal.a $(SDK_PATH_LIB)/string.a $(SDK_PATH_LIB)/rosrtl.a
        - $(CC) \
                -Wl,-T,$(LINKER_SCRIPT) \
                -nostartfiles \
@@ -555,8 +566,11 @@ $(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(DDK_PATH_LIB)/hal.a
                -Wl,--image-base,0xc0000000 \
                -Wl,--file-alignment,0x1000 \
                -Wl,--section-alignment,0x1000 \
+               -Wl,--entry,_NtProcessStartup \
                -Wl,--base-file,base.tmp \
                $(TARGETNAME).o -lgcc \
+               $(SDK_PATH_LIB)/string.a \
+               $(SDK_PATH_LIB)/rosrtl.a \
                $(DDK_PATH_LIB)/hal.a
        - $(RM) junk.tmp
        $(DLLTOOL) \
@@ -576,15 +590,18 @@ $(TARGETNAME).exe: $(TARGETNAME).o $(LINKER_SCRIPT) $(DDK_PATH_LIB)/hal.a
                -Wl,--image-base,0xc0000000 \
                -Wl,--file-alignment,0x1000 \
                -Wl,--section-alignment,0x1000 \
+               -Wl,--entry,_NtProcessStartup \
                -Wl,temp.exp \
                $(TARGETNAME).o -lgcc \
+               $(SDK_PATH_LIB)/string.a \
+               $(SDK_PATH_LIB)/rosrtl.a \
                $(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
+$(TARGETNAME).dbg: $(TARGETNAME).dbg.o $(TARGETNAME).a $(TARGETNAME).dbg.lnk $(DDK_PATH_LIB)/hal.a $(SDK_PATH_LIB)/string.a $(SDK_PATH_LIB)/rosrtl.a
        $(CC) \
                -Wl,-T,$(TARGETNAME).dbg.lnk \
                -nostartfiles \
@@ -595,8 +612,11 @@ $(TARGETNAME).dbg: $(TARGETNAME).dbg.o $(TARGETNAME).a $(TARGETNAME).dbg.lnk
                -Wl,--image-base,0xc0000000 \
                -Wl,--file-alignment,0x1000 \
                -Wl,--section-alignment,0x1000 \
+               -Wl,--entry,_NtProcessStartup \
                -Wl,--base-file,base.tmp \
                $(TARGETNAME).dbg.o -lgcc \
+               $(SDK_PATH_LIB)/string.a \
+               $(SDK_PATH_LIB)/rosrtl.a \
                $(DDK_PATH_LIB)/hal.a
        - $(RM) junk.tmp
        $(DLLTOOL) \
@@ -616,8 +636,11 @@ $(TARGETNAME).dbg: $(TARGETNAME).dbg.o $(TARGETNAME).a $(TARGETNAME).dbg.lnk
                -Wl,--image-base,0xc0000000 \
                -Wl,--file-alignment,0x1000 \
                -Wl,--section-alignment,0x1000 \
+               -Wl,--entry,_NtProcessStartup \
                -Wl,temp.exp \
                $(TARGETNAME).dbg.o -lgcc \
+               $(SDK_PATH_LIB)/string.a \
+               $(SDK_PATH_LIB)/rosrtl.a \
                $(DDK_PATH_LIB)/hal.a
        - $(RM) temp.exp
 
@@ -653,8 +676,8 @@ implib: $(DDK_PATH_LIB)/$(TARGETNAME).a
 
 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 nls/*.o \
+              ex/i386/*.o inbv/*.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) \
@@ -663,6 +686,15 @@ clean:
 
 .PHONY: clean
 
+ifneq ($(BOOTCD_INSTALL),)
+
+install: all $(INSTALL_DIR)/$(TARGETNAME).exe
+
+$(INSTALL_DIR)/$(TARGETNAME).exe: $(TARGETNAME).exe
+       $(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
@@ -671,6 +703,9 @@ $(INSTALL_DIR)/system32/$(TARGETNAME).exe: $(TARGETNAME).exe
 $(INSTALL_DIR)/symbols/$(TARGETNAME).sym: $(TARGETNAME).sym
        $(CP) $(TARGETNAME).sym $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
 
+endif # BOOTCD_INSTALL
+
+
 .PHONY: install
 
 dist: $(DIST_DIR)/$(TARGETNAME).exe
@@ -680,6 +715,14 @@ $(DIST_DIR)/$(TARGETNAME).exe: $(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
+
+.PHONY: bootcd
+
+
 ex/napi.o: ex/napi.c $(PATH_TO_TOP)/include/ntdll/napi.h
 
 ke/main.o: ke/main.c $(PATH_TO_TOP)/include/reactos/buildno.h