-# $Id: Makefile,v 1.65 2002/01/23 23:39:24 chorns Exp $
+# $Id: Makefile,v 1.104 2003/08/11 18:50:12 chorns Exp $
#
# ReactOS Operating System
#
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 dbg/profile.o
else
OBJECTS_KDBG :=
endif
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
#
bugcodes.rc \
$(TARGETNAME).nostrip.exe \
$(TARGETNAME).exe \
- $(TARGETNAME).sym
+ $(TARGETNAME).sym \
+ ntoskrnl.map
#
# Architecture specific Makefile
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 \
rtl/mem.o \
- rtl/memchr.o \
- rtl/memcpy.o \
- rtl/memmove.o \
- rtl/memset.o \
rtl/message.o \
rtl/nls.o \
- rtl/qsort.o \
+ rtl/purecall.o \
+ rtl/random.o \
rtl/regio.o \
- rtl/seh.o \
rtl/sprintf.o \
rtl/stdlib.o \
rtl/string.o \
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 \
OBJECTS_MM = \
mm/aspace.o \
mm/cont.o \
+ mm/drvlck.o \
mm/freelist.o \
mm/iospace.o \
mm/marea.o \
mm/pageop.o \
mm/balance.o \
mm/rmap.o \
- mm/slab.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/pnproot.o \
io/process.o \
io/queue.o \
+ io/rawfs.o \
io/resource.o \
io/rw.o \
io/share.o \
ob/namespc.o \
ob/ntobj.o \
ob/object.o \
- ob/security.o
+ ob/security.o \
+ ob/symlink.o
# Process Manager (Ps)
OBJECTS_PS = \
ps/tinfo.o \
ps/debug.o \
ps/suspend.o \
- ps/win32.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/power.o \
ex/resource.o \
ex/time.o \
+ ex/stree.o \
ex/sysinfo.o \
ex/win32k.o \
ex/work.o \
OBJECTS_SE = \
se/access.o \
se/acl.o \
+ se/audit.o \
se/lsa.o \
se/luid.o \
se/priv.o \
lpc/reply.o \
lpc/send.o
-# Nation Language Support Library (Nls)
-OBJECTS_NLS = nls/nls.o
-
# Power Management (Po)
OBJECTS_PO = po/power.o
kd/kdebug.o \
kd/service.o \
kd/dlog.o \
- kd/gdbstub.o
+ 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_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
$(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) \
-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 \
$(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)
+
+$(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)/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)
-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 bugcodes.rc msg?????.bin $(DEP_FILES)
-$(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 \
-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) \
-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 \
-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) \
-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 \
-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) \
-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
$(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 bugcodes.rc \
$(TARGETNAME).mc
-implib:
+$(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
+
+clean:
+ - $(RM) $(OBJECTS_PATH)/*.o cc/*.o cm/*.o dbg/*.o dbg/i386/*.o ex/*.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) \
+ $(TAG_OBJECTS)
+
-.PHONY: 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)/symbols/$(TARGETNAME).sym: $(TARGETNAME).sym
$(CP) $(TARGETNAME).sym $(INSTALL_DIR)/symbols/$(TARGETNAME).sym
+endif # BOOTCD_INSTALL
+
+
.PHONY: install
dist: $(DIST_DIR)/$(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
%.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