Usermode/libc - Fix strchr and strrchr behavior
[tpg/acess2.git] / Makefile
index 0d265c4..cb21b45 100644 (file)
--- a/Makefile
+++ b/Makefile
 
 SUBMAKE = $(MAKE) --no-print-directory
 
-USRLIBS := crt0.o acess.ld ld-acess.so libc.so
+USRLIBS := crt0.o ld-acess.so libc.so libposix.so libc++.so libpthread.so
 USRLIBS += libreadline.so libnet.so liburi.so libpsocket.so
-USRLIBS += libimage_sif.so
+USRLIBS += libimage_sif.so libunicode.so libm.so
+USRLIBS += libaxwin4.so
 
-USRAPPS := init login CLIShell cat ls mount
+EXTLIBS := 
+#libspiderscript
+# zlib libpng
+
+USRAPPS := init login CLIShell cat ls mount automounter
+USRAPPS += insmod
 USRAPPS += bomb lspci
 USRAPPS += ip dhcpclient ping telnet irc wget telnetd
-USRAPPS += axwin3 gui_ate
-
-ALL_DYNMODS = $(addprefix all-,$(DYNMODS))
-ALL_MODULES := $(addprefix all-,$(MODULES))
-ALL_USRLIBS := $(addprefix all-,$(USRLIBS))
-ALL_USRAPPS := $(addprefix all-,$(USRAPPS))
-CLEAN_DYNMODS := $(addprefix clean-,$(DYNMODS))
-CLEAN_MODULES := $(addprefix clean-,$(MODULES))
-CLEAN_USRLIBS := $(addprefix clean-,$(USRLIBS))
-CLEAN_USRAPPS := $(addprefix clean-,$(USRAPPS))
-INSTALL_DYNMODS := $(addprefix install-,$(DYNMODS))
-INSTALL_MODULES := $(addprefix install-,$(MODULES))
-INSTALL_USRLIBS := $(addprefix install-,$(USRLIBS))
-INSTALL_USRAPPS := $(addprefix install-,$(USRAPPS))
-AI_DYNMODS := $(addprefix allinstall-,$(DYNMODS))
-AI_MODULES := $(addprefix allinstall-,$(MODULES))
-AI_USRLIBS := $(addprefix allinstall-,$(USRLIBS))
-AI_USRAPPS := $(addprefix allinstall-,$(USRAPPS))
+USRAPPS += axwin3 gui_ate gui_terminal
+USRAPPS += axwin4
 
-.PHONY: all clean install \
-       kmode all-kmode clean-kmode \
-       all-user clean-user \
-       $(ALL_MODULES) all-Kernel $(ALL_USRLIBS) $(ALL_USRAPPS) \
-       $(AI_MODULES) allinstall-Kernel $(AI_USRLIBS) $(AI_USRAPPS) \
-       $(CLEAN_MODULES) clean-Kernel $(CLEAN_USRLIBS) $(CLEAN_USRAPPS) \
-       $(INSTALL_MODULES) install-Kernel $(INSTALL_USRLIBS) $(INSTALL_USRAPPS)
-
-kmode: $(AI_MODULES) $(AI_DYNMODS) allinstall-Kernel
-all-kmode:     $(ALL_MODULES) $(ALL_DYNMODS) all-Kernel
-clean-kmode:   $(CLEAN_MODULES) $(CLEAN_DYNMODS) clean-Kernel
+define targetclasses
+ AI_$1      := $$(addprefix allinstall-,$$($1))
+ ALL_$1     := $$(addprefix all-,$$($1))
+ CLEAN_$1   := $$(addprefix clean-,$$($1))
+ INSTALL_$1 := $$(addprefix install-,$$($1))
+endef
 
-all-user: $(ALL_USRLIBS) $(ALL_USRAPPS)
-clean-user: $(CLEAN_USRLIBS) $(CLEAN_USRAPPS)
+$(eval $(call targetclasses,DYNMODS))
+$(eval $(call targetclasses,MODULES))
+$(eval $(call targetclasses,USRLIBS))
+$(eval $(call targetclasses,EXTLIBS))
+$(eval $(call targetclasses,USRAPPS))
 
-all:   SyscallList $(ALL_USRLIBS) $(ALL_USRAPPS) $(ALL_MODULES) all-Kernel $(ALL_DYNMODS)
-all-install:   install-Filesystem SyscallList $(AI_USRLIBS) $(AI_USRAPPS) $(AI_MODULES) allinstall-Kernel $(AI_DYNMODS)
-clean: $(CLEAN_DYNMODS) $(CLEAN_MODULES) clean-Kernel $(CLEAN_USRLIBS) $(CLEAN_USRAPPS)
-install:       install-Filesystem SyscallList $(INSTALL_USRLIBS) $(INSTALL_USRAPPS) $(INSTALL_DYNMODS) $(INSTALL_MODULES) install-Kernel
+targetvars := $$(AI_$1) $$(ALL_$1) $$(CLEAN_$1) $$(INSTALL_$1)
+
+.PHONY: all clean install \
+       ai-kmode all-kmode clean-kmode install-kmode \
+       ai-user all-user clean-user install-user \
+       utest mtest
+
+.PHONY: allinstall-Kernel all-Kernel clean-Kernel install-Kernel \
+       $(call targetvars,DYNMODS) \
+       $(call targetvars,MODULES) \
+       $(call targetvars,USRLIBS) \
+       $(call targetvars,EXTLIBS) \
+       $(call targetvars,USRAPPS)
+
+ai-kmode:      $(AI_MODULES) allinstall-Kernel $(AI_DYNMODS)
+all-kmode:     $(ALL_MODULES) all-Kernel $(ALL_DYNMODS)
+clean-kmode:   $(CLEAN_MODULES) $(CLEAN_DYNMODS) clean-Kernel
+install-kmode: $(INSTALL_MODULES) install-Kernel $(INSTALL_DYNMODS)
+
+ai-user:       $(AI_USRLIBS) $(AI_EXTLIBS) $(AI_USRAPPS)
+all-user:      $(ALL_USRLIBS) $(ALL_EXTLIBS) $(ALL_USRAPPS)
+clean-user:    $(CLEAN_USRLIBS) $(CLEAN_EXTLIBS) $(CLEAN_USRAPPS)
+install-user:  $(INSTALL_USRLIBS) $(INSTALL_EXTLIBS) $(INSTALL_USRAPPS)
+
+all:   SyscallList all-user all-kmode
+all-install:   install-Filesystem SyscallList ai-user ai-kmode
+clean: clean-kmode clean-user
+install:       install-Filesystem SyscallList install-user install-kmode
+
+utest-build: $(USRLIBS:%=utest-build-%)
+utest-run: $(USRLIBS:%=utest-run-%)
+utest: utest-build utest-run
+
+utest-build-%:
+       @CC=$(NCC) $(SUBMAKE) -C Usermode/Libraries/$*_src generate_exp
+       @CC=$(NCC) $(SUBMAKE) -C Usermode/Libraries/$*_src utest-build
+utest-run-%:
+       @CC=$(NCC) $(SUBMAKE) -C Usermode/Libraries/$*_src utest-run -k
+
+# TODO: Module tests using DiskTool and NetTest
+mtest: mtest-build mtest-run
+       @echo > /dev/null
+mtest-build:
+       # Network
+       @echo "== Build Module Tests"
+       @echo "-- nativelib"
+       @CC=$(NCC) $(SUBMAKE) -C Tools/nativelib
+       @echo "-- NetTest"
+       @CC=$(NCC) $(SUBMAKE) -C Tools/NetTest
+       @echo "-- NetTest Runner"
+       @CC=$(NCC) $(SUBMAKE) -C Tools/NetTest_Runner
+mtest-run:
+       @echo "=== Network Module Test ==="
+       @cd Tools && ./nettest_runner
 
 SyscallList: include/syscalls.h
 include/syscalls.h: KernelLand/Kernel/Makefile KernelLand/Kernel/syscalls.lst
@@ -62,59 +100,42 @@ include/syscalls.h: KernelLand/Kernel/Makefile KernelLand/Kernel/syscalls.lst
 
 _build_dynmod := BUILDTYPE=dynamic $(SUBMAKE) -C KernelLand/Modules/
 _build_stmod  := BUILDTYPE=static $(SUBMAKE) -C KernelLand/Modules/
-_build_kernel := $(SUBMAKE) $1 -C KernelLand/Kernel
-
-# Compile Only
-$(ALL_DYNMODS): all-%:
-       +@echo === Dynamic Module: $* && $(_build_dynmod)$* all
-$(ALL_MODULES): all-%:
-       +@echo === Module: $* && $(_build_stmod)$* all
-all-Kernel:
+_build_kernel := $(SUBMAKE) -C KernelLand/Kernel
+
+define rules
+$$(ALL_$1): all-%: $(CC)
+       +@echo === $2 && $3 all
+$$(AI_$1): allinstall-%: $(CC)
+       +@echo === $2 && $3 all install
+$$(CLEAN_$1): clean-%: $(CC)
+       +@echo === $2 && $3 clean
+$$(INSTALL_$1): install-%: $(CC)
+       +@$3 install
+endef
+
+$(eval $(call rules,DYNMODS,Dynamic Module: $$*,$(_build_dynmod)$$*))
+$(eval $(call rules,MODULES,Module: $$*,$(_build_stmod)$$*))
+$(eval $(call rules,USRLIBS,User Library: $$*,$(SUBMAKE) -C Usermode/Libraries/$$*_src))
+$(eval $(call rules,EXTLIBS,External Library: $$*,$(SUBMAKE) -C Externals/$$*))
+$(eval $(call rules,USRAPPS,User Application: $$*,$(SUBMAKE) -C Usermode/Applications/$$*_src))
+all-Kernel: $(CC)
        +@echo === Kernel && $(_build_kernel) all
-$(ALL_USRLIBS): all-%:
-       +@echo === User Library: $* && $(SUBMAKE) all -C Usermode/Libraries/$*_src
-$(ALL_USRAPPS): all-%:
-       +@echo === User Application: $* && $(SUBMAKE) all -C Usermode/Applications/$*_src
-
-# Compile & Install
-$(AI_DYNMODS): allinstall-%:
-       +@echo === Dynamic Module: $* && $(_build_dynmod)$* all install
-$(AI_MODULES): allinstall-%:
-       +@echo === Module: $* && $(_build_stmod)$* all install
-allinstall-Kernel:
+allinstall-Kernel: $(CC)
        +@echo === Kernel && $(_build_kernel) all install
-$(AI_USRLIBS): allinstall-%:
-       +@echo === User Library: $* && $(SUBMAKE) all install -C Usermode/Libraries/$*_src
-$(AI_USRAPPS): allinstall-%:
-       +@echo === User Application: $* && $(SUBMAKE) all install -C Usermode/Applications/$*_src
-
-# Clean up compilation
-$(CLEAN_DYNMODS): clean-%:
-       +@$(_build_dynmod)$* clean
-$(CLEAN_MODULES): clean-%:
-       +@$(_build_stmod)$* clean
-clean-Kernel:
+clean-Kernel: $(CC)
        +@$(_build_kernel) clean
-$(CLEAN_USRLIBS): clean-%:
-       +@$(SUBMAKE) clean -C Usermode/Libraries/$*_src
-$(CLEAN_USRAPPS): clean-%:
-       +@$(SUBMAKE) clean -C Usermode/Applications/$*_src
-
-# Install
-ifeq ($(ARCH),host)
-install-%:
-       
-else
-$(INSTALL_DYNMODS): install-%:
-       @$(_build_dynmod)$* install
-$(INSTALL_MODULES): install-%:
-       @$(_build_stmod)$* install
-install-Filesystem:
-       @$(SUBMAKE) install -C Usermode/Filesystem
-install-Kernel:
+install-Kernel: $(CC)
        @$(_build_kernel) install
-$(INSTALL_USRLIBS): install-%:
-       @$(SUBMAKE) install -C Usermode/Libraries/$*_src
-$(INSTALL_USRAPPS): install-%:
-       @$(SUBMAKE) install -C Usermode/Applications/$*_src
+install-Filesystem: $(CC)
+       @$(SUBMAKE) install -C Usermode/Filesystem
+
+ifeq ($(ARCHDIR),native)
+.PHONY: $(CC)
+else
+$(CC):
+       @echo ---
+       @echo $(CC) does not exist, recompiling
+       @echo ---
+       for dir in $(USRLIBS:%=Usermode/Libraries/%_src); do $(SUBMAKE) -C $$dir _libs; done
+       make -C Externals/cross-compiler/ -f Makefile.cross
 endif

UCC git Repository :: git.ucc.asn.au