fixed makefile error if no ivycc
[akaros.git] / GNUmakefile
index 273147a..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
+OBJDIR := obj
 
--include conf/env.mk
+# Make sure that 'all' is the first target
+all: symlinks
 
-ifndef SOL
-SOL := 0
-endif
-ifndef LABADJUST
-LABADJUST := 0
-endif
+# User defined constants passed on the command line 
+TARGET_ARCH := i386
+COMPILER := IVY
 
-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 jos toolchain
+# Cross-compiler ros toolchain
 #
 # This Makefile will automatically use the cross-compiler toolchain
-# installed as 'i386-jos-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-jos-elf-objdump -i 2>&1 | grep '^elf32-i386$$' >/dev/null 2>&1; \
-       then echo 'i386-jos-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-jos-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-jos-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
+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)
 
-# Linker flags for ROS user programs
-ULDFLAGS := -T user/user.ld
+# Universal loader flags
+LDFLAGS := -nostdlib
 
-# Lists that the */Makefrag makefile fragments will add to
+# GCC Library path 
+GCC_LIB := $(shell $(CC) -print-libgcc-file-name)
+
+# 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:
@@ -88,73 +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
-
-KERN_CFLAGS := $(CFLAGS) -DROS_KERNEL -gstabs
-USER_CFLAGS := $(CFLAGS) -DROS_USER -gstabs
-
-
-
-
-# Include Makefrags for subdirectories
-include boot/Makefrag
-include lib/Makefrag
-include ivylib/Makefrag
-include kern/Makefrag
-include user/Makefrag
-
-
-IMAGES = $(OBJDIR)/kern/bochs.img
-
-bochs: $(IMAGES)
-       bochs 'display_library: nogui'
-
-# 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
-
-grade: $(LABSETUP)grade.sh
-       $(V)$(MAKE) clean >/dev/null 2>/dev/null
-       $(MAKE) all
-       sh $(LABSETUP)grade.sh
-
-handin: tarball
-       turnin --submit porterde cs372h-lab$(LAB) lab$(LAB)-handin.tar.gz
-
-tarball: realclean
-       tar cf - `find . -type f | grep -v '^\.*$$' | grep -v '/CVS/' | grep -v '/\.svn/' | grep -v 'lab[0-9].*\.tar\.gz'` | gzip > lab$(LAB)-handin.tar.gz
-
-# For test runs
-run-%:
-       $(V)rm -f $(OBJDIR)/kern/init.o $(IMAGES)
-       $(V)$(MAKE) "DEFS=-DTEST=_binary_obj_user_$*_start -DTESTSIZE=_binary_obj_user_$*_size" $(IMAGES)
-       bochs -q 'display_library: nogui'
-
-xrun-%:
-       $(V)rm -f $(OBJDIR)/kern/init.o $(IMAGES)
-       $(V)$(MAKE) "DEFS=-DTEST=_binary_obj_user_$*_start -DTESTSIZE=_binary_obj_user_$*_size" $(IMAGES)
-       bochs -q
-
 # 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
+