x86: changes LAPIC timer divisor to 32
[akaros.git] / GNUmakefile
index 0dc9f82..0c67d05 100644 (file)
@@ -1,6 +1,9 @@
 # The ROS Top level Makefile
 # Make sure that 'all' is the first target
 
+# Keep make quiet.  Make sure you call make via $(MAKE), and not directly
+MAKE += -s 
+
 ############################################################################# 
 ########## Initial Setup so that we can build for different TARGETS #########
 ############################################################################# 
@@ -13,12 +16,12 @@ endif
 ifeq ($(TARGET_ARCH),)
 busted:
        @echo "You must initially specify your target in the form TARGET_ARCH=<target>"
-       @echo "Current valid values for TARGET_ARCH are 'i686' and 'sparc'"
+       @echo "Current valid values for TARGET_ARCH are 'i686', 'sparc', and 'riscv'."
        @echo "Subsequent calls for the same target can be made by simply invoking 'make'"
 endif
 
-$(TARGET_ARCH):
-       @if [ "$(ARCH_LINK)" != "$@" ];\
+real-$(TARGET_ARCH):
+       @if [ "$(ARCH_LINK)" != "$(TARGET_ARCH)" ];\
        then\
          $(MAKE) realclean;\
          $(MAKE) realall -j $(MAKE_JOBS);\
@@ -26,6 +29,9 @@ $(TARGET_ARCH):
          $(MAKE) all -j $(MAKE_JOBS);\
        fi
 
+# So all recursive calls to make know what the target arch is
+MAKE += TARGET_ARCH=$(TARGET_ARCH)
+
 ############################################################################# 
 ########## Beginning of the guts of the real Makefile #######################
 ############################################################################# 
@@ -43,6 +49,7 @@ MAKE_JOBS :=
 
 # Give it a reasonable default path for initramfs to avoid build breakage
 INITRAMFS_PATHS = kern/kfs
+FIRST_INITRAMFS_PATH = $(firstword $(INITRAMFS_PATHS))
 
 # Then grab the users Makelocal file to let them override Make system variables
 # and set up other Make targets
@@ -88,6 +95,7 @@ endif
 
 # Default programs for compilation
 USER_CFLAGS += -O2 -std=gnu99
+USER_CXXFLAGS += -O2
 ifeq ($(COMPILER),IVY)
 KERN_CFLAGS += --deputy \
                --no-rc-sharc \
@@ -103,6 +111,7 @@ else
 CC         := $(GCCPREFIX)gcc 
 endif
 
+CPP        := $(GCCPREFIX)g++
 AS         := $(GCCPREFIX)as
 AR         := $(GCCPREFIX)ar
 LD         := $(GCCPREFIX)ld
@@ -123,9 +132,11 @@ endif
 # -fno-builtin is required to avoid refs to undefined functions in the kernel.
 # Only optimize to -O1 to discourage inlining, which complicates backtraces.
 KERN_CFLAGS += -D$(TARGET_ARCH) $(EXTRAARGS)
-KERN_CFLAGS += -O2 -pipe -MD -fno-builtin -gstabs
+KERN_CFLAGS += -O2 -pipe -MD -fno-builtin -gstabs -static
 KERN_CFLAGS += -Wall -Wno-format -Wno-unused -fno-strict-aliasing
 KERN_CFLAGS += -nostdinc -I$(dir $(GCC_LIB))/include
+# Our backtraces need the frame pointer
+KERN_CFLAGS += -fno-omit-frame-pointer
 
 # Universal loader flags
 LDFLAGS := -nostdlib
@@ -141,7 +152,7 @@ arch:
 symlinks: error
        ln -fs ../arch/$(ROS_ARCH_DIR) kern/include/arch
        ln -fs arch/$(ROS_ARCH_DIR)/boot kern/boot
-       ln -fs $(ROS_ARCH_DIR) user/include/arch
+       ln -fs $(ROS_ARCH_DIR) user/parlib/include/arch
        @$(MAKE) -j $(MAKE_JOBS) all
 
 # Include Makefrags for subdirectories
@@ -153,27 +164,40 @@ endif
 ifeq ($(GCCPREFIX),$(TARGET_ARCH)-ros-)
 GCC_ROOT := $(shell which $(GCCPREFIX)gcc | xargs dirname)/../
 tests/: tests
-tests:
+tests: install-libs
        @$(MAKE) -j $(MAKE_JOBS) realtests
-realtests: $(TESTS_EXECS)
+
+realtests: $(TESTS_EXECS_C) $(TESTS_EXECS_CPP)
 # No longer automatically copying to the FS dir (deprecated)
 #      @mkdir -p fs/$(TARGET_ARCH)/tests
 #      cp -R $(OBJDIR)/$(TESTS_DIR)/* $(TOP_DIR)/fs/$(TARGET_ARCH)/tests
 
+USER_LIBS = parlib pthread
+# for now, c3po can't be built for non-i686
+ifeq ($(TARGET_ARCH),i686)
+USER_LIBS += c3po
+endif
 install-libs: 
-       @rm -rf $(firstword $(INITRAMFS_PATHS))/lib
-       @cp -R $(GCC_ROOT)/$(TARGET_ARCH)-ros/lib $(firstword $(INITRAMFS_PATHS))
-       @cd user/parlib; $(MAKE); $(MAKE) install
-       @cd user/pthread; $(MAKE); $(MAKE) install
-       @cd user/c3po; $(MAKE); $(MAKE) install
+       @for i in $(USER_LIBS) ; do     \
+               cd user/$$i;            \
+               $(MAKE);                \
+               $(MAKE) install;        \
+               cd ../..;               \
+       done
+
+fill-kfs: install-libs
+       @rm -rf $(FIRST_INITRAMFS_PATH)/lib
+       @cp -R $(GCC_ROOT)/$(TARGET_ARCH)-ros/lib $(FIRST_INITRAMFS_PATH)
+endif
 
 userclean:
-       @cd user/parlib; $(MAKE) clean;
-       @cd user/pthread; $(MAKE) clean;
-       @cd user/c3po; $(MAKE) clean;
+       @for i in $(USER_LIBS) ; do \
+               cd user/$$i;            \
+               $(MAKE) clean;          \
+               cd ../..;               \
+       done
        @rm -rf $(OBJDIR)/$(TESTS_DIR)
 .PHONY: tests
-endif
 
 # Eliminate default suffix rules
 .SUFFIXES:
@@ -205,13 +229,15 @@ doxyclean:
        rm -rf $(DOXYGEN_DIR)/rosdoc
 
 clean:
+       @$(MAKE) userclean
+       @echo + clean [KERNEL/TESTS]
        @rm -rf $(OBJDIR)
        @echo All clean and pretty!
 
 realclean: clean
        @rm -f kern/boot
        @rm -f kern/include/arch
-       @rm -f user/include/arch
+       @rm -f user/parlib/include/arch
 
 always:
        @: