Merge branch 'master' of ssh://waterman@scm.millennium.berkeley.edu/project/cs/radlab...
[akaros.git] / GNUmakefile
index ad88d09..ea810f6 100644 (file)
 #      Recursive Make Considered Harmful
 #      http://aegis.sourceforge.net/auug97.pdf
 #
+
 OBJDIR := obj
 
-ifdef LAB
-SETTINGLAB := true
-else
--include conf/lab.mk
-endif
+# Make sure that 'all' is the first target
+all: symlinks
 
--include conf/env.mk
+# User defined constants passed on the command line 
+TARGET_ARCH := i386
+COMPILER := IVY
 
-ifndef SOL
-SOL := 0
-endif
-ifndef LABADJUST
-LABADJUST := 0
-endif
-
-ifndef LABSETUP
-LABSETUP := ./
-endif
+-include Makelocal
 
+TOP_DIR := .
+ARCH_DIR := $(TOP_DIR)/kern/arch
+INCLUDE_DIR := $(TOP_DIR)/kern/include
 
-TOP = .
+UNAME=$(shell uname -m)
+V = @
 
 # Cross-compiler ros toolchain
 #
 # This Makefile will automatically use the cross-compiler toolchain
-# installed as 'i386-ros-elf-*', if one exists.  If the host tools ('gcc',
+# installed as 'i386-ros-*', if one exists.  If the host tools ('gcc',
 # 'objdump', and so forth) compile for a 32-bit x86 ELF target, that will
 # be detected as well.  If you have the right compiler toolchain installed
-# using a different name, set GCCPREFIX explicitly in conf/env.mk
+# using a different name, set GCCPREFIX explicitly in your Makelocal file
 
 # try to infer the correct GCCPREFIX
 ifndef GCCPREFIX
-GCCPREFIX := $(shell if i386-ros-elf-objdump -i 2>&1 | grep '^elf32-i386$$' >/dev/null 2>&1; \
-       then echo 'i386-ros-elf-'; \
+GCCPREFIX := $(shell if i386-ros-objdump -i 2>&1 | grep '^elf32-i386$$' >/dev/null 2>&1; \
+       then echo 'i386-ros-'; \
        elif objdump -i 2>&1 | grep 'elf32-i386' >/dev/null 2>&1; \
        then echo ''; \
        else echo "***" 1>&2; \
        echo "*** Error: Couldn't find an i386-*-elf version of GCC/binutils." 1>&2; \
-       echo "*** Is the directory with i386-ros-elf-gcc in your PATH?" 1>&2; \
+       echo "*** Is the directory with i386-ros-gcc in your PATH?" 1>&2; \
        echo "*** If your i386-*-elf toolchain is installed with a command" 1>&2; \
-       echo "*** prefix other than 'i386-ros-elf-', set your GCCPREFIX" 1>&2; \
+       echo "*** prefix other than 'i386-ros-', set your GCCPREFIX" 1>&2; \
        echo "*** environment variable to that prefix and run 'make' again." 1>&2; \
        echo "*** To turn off this error, run 'gmake GCCPREFIX= ...'." 1>&2; \
        echo "***" 1>&2; exit 1; fi)
 endif
 
-CC     := $(GCCPREFIX)gcc -pipe
-GCC_LIB := $(shell $(CC) -print-libgcc-file-name)
-AS     := $(GCCPREFIX)as
-AR     := $(GCCPREFIX)ar
-LD     := $(GCCPREFIX)ld
+# Default programs for compilation
+ifeq ($(COMPILER),IVY)
+KERN_CFLAGS := --deputy\
+                  --no-rc-sharc\
+                  --sc-dynamic-is-error\
+                  --sc-ops=$(INCLUDE_DIR)/ivy/sharc.h\
+                  --sc-all-in-thread\
+                  --enable-precompile\
+#                  --enable-error-db\
+
+USER_CFLAGS := --deputy --enable-error-db
+CC         := ivycc --gcc=$(GCCPREFIX)gcc
+else
+CC         := $(GCCPREFIX)gcc 
+endif
+
+AS         := $(GCCPREFIX)as
+AR         := $(GCCPREFIX)ar
+LD         := $(GCCPREFIX)ld
 OBJCOPY        := $(GCCPREFIX)objcopy
 OBJDUMP        := $(GCCPREFIX)objdump
-NM     := $(GCCPREFIX)nm
-ARCH ?= NONE
+NM         := $(GCCPREFIX)nm
+PERL    := perl
 
-# Native commands
-NCC    := gcc $(CC_VER) -pipe
-TAR    := gtar
-PERL   := perl
+EXTRAARGS ?= -std=gnu99 -Wno-attributes -fno-stack-protector -fgnu89-inline
 
-# Compiler flags
+# Universal compiler flags
 # -fno-builtin is required to avoid refs to undefined functions in the kernel.
 # Only optimize to -O1 to discourage inlining, which complicates backtraces.
-CFLAGS := $(CFLAGS) $(DEFS) $(LABDEFS) -D$(ARCH) -O -fno-builtin -fno-stack-protector -I$(TOP) -MD -Wall -Wno-format -Wno-unused -gstabs #-save-temps
+CFLAGS := $(CFLAGS) -D$(TARGET_ARCH) $(EXTRAARGS)
+CFLAGS += -O2 -pipe -MD -fno-builtin -gstabs
+CFLAGS += -Wall -Wno-format -Wno-unused -fno-strict-aliasing
+#CFLAGS += -nostdinc -Igccinclude/$(TARGET_ARCH)
 
-# 64 Bit machines need these settings to compile and link
-UNAME=$(shell uname -m)
-ifeq ($(UNAME),x86_64)
-       LD += -melf_i386
-       CFLAGS += -m32
-       GCC_LIB = $(shell $(CC) -print-libgcc-file-name | sed 's/libgcc.a/32\/libgcc.a/')
-endif
+# Universal loader flags
+LDFLAGS := -nostdlib
 
-# Linker flags for ROS user programs
-ULDFLAGS := -T user/user.ld -nostdlib
-ULDFLAGS := -T user_newlib/user_newlib.ld -nostdlib
+# GCC Library path 
+GCC_LIB := $(shell $(CC) -print-libgcc-file-name)
 
-# Lists that the */Makefrag makefile fragments will add to
+# List of directories that the */Makefrag makefile fragments will add to
 OBJDIRS :=
 
-# Make sure that 'all' is the first target
-all:
+symlinks:
+       @rm -f kern/include/arch
+       @ln -s ../arch/$(TARGET_ARCH)/ kern/include/arch
+       @rm -f kern/boot
+       @ln -s arch/$(TARGET_ARCH)/boot/ kern/boot
+
+# Include Makefrags for subdirectories
+include user/Makefrag
+include kern/Makefrag
 
 # Eliminate default suffix rules
 .SUFFIXES:
@@ -97,53 +107,41 @@ all:
 # Delete target files if there is an error (or make is interrupted)
 .DELETE_ON_ERROR:
 
-# make it so that no intermediate .o files are ever deleted
-.PRECIOUS: %.o $(OBJDIR)/boot/%.o $(OBJDIR)/kern/%.o \
-       $(OBJDIR)/lib/%.o $(OBJDIR)/fs/%.o $(OBJDIR)/user/%.o \
-       $(OBJDIR)/newlib/%.o $(OBJDIR)/user_newlib/%.o
-
-KERN_CFLAGS := $(CFLAGS) -DROS_KERNEL -gstabs -nostdinc
-USER_CFLAGS := $(CFLAGS) -DROS_USER -gstabs
-
-# Include Makefrags for subdirectories
-include boot/Makefrag
-include lib/Makefrag
-include newlib/Makefrag
-include ivylib/Makefrag
-include kern/Makefrag
-include user/Makefrag
-include user_newlib/Makefrag
--include Makelocal
-
-IMAGES = $(OBJDIR)/kern/bochs.img
-
-# For deleting the build
-clean:
-       rm -rf $(OBJDIR)
-
-realclean: clean
-       rm -rf lab$(LAB).tar.gz bochs.out bochs.log
-
-distclean: realclean
-       rm -rf conf/gcc.mk
-
-usb: $(IMAGES)
-       sudo mount /dev/sde4 /media/usb
-       sudo cp obj/kern/kernel /media/usb/
-       sudo umount /media/usb
-
 # This magic automatically generates makefile dependencies
 # for header files included from C source files we compile,
 # and keeps those dependencies up-to-date every time we recompile.
 # See 'mergedep.pl' for more information.
 $(OBJDIR)/.deps: $(foreach dir, $(OBJDIRS), $(wildcard $(OBJDIR)/$(dir)/*.d))
        @mkdir -p $(@D)
-       @$(PERL) mergedep.pl $@ $^
+       @$(PERL) scripts/mergedep.pl $@ $^
 
+# By including this file we automatically force the target that generates it 
+# to be rerun
 -include $(OBJDIR)/.deps
 
+# Use doxygen to make documentation for ROS
+docs: 
+       @doxygen doc/rosdoc.cfg
+       @if [ ! -d doc/rosdoc/html/img ];          \
+        then                                      \
+               ln -s ../../img doc/rosdoc/html;       \
+        fi
+
+doxyclean:
+       rm -rf doc/rosdoc
+
+augment-gcc: symlinks
+       scripts/augment-gcc $(dir $(shell which $(CC))).. $(TARGET_ARCH)
+
+# For deleting the build
+clean:
+       @rm -rf $(OBJDIR)
+       @rm -f kern/boot
+       @rm -f kern/include/arch
+       @echo All clean and pretty!
+
 always:
        @:
 
-.PHONY: all always \
-       handin tarball clean realclean clean-labsetup distclean grade labsetup
+.PHONY: all always docs clean
+