| [032a9b3] | 1 | #
|
|---|
| [df4ed85] | 2 | # Copyright (c) 2006 Martin Decky
|
|---|
| [032a9b3] | 3 | # All rights reserved.
|
|---|
| 4 | #
|
|---|
| 5 | # Redistribution and use in source and binary forms, with or without
|
|---|
| 6 | # modification, are permitted provided that the following conditions
|
|---|
| 7 | # are met:
|
|---|
| 8 | #
|
|---|
| 9 | # - Redistributions of source code must retain the above copyright
|
|---|
| 10 | # notice, this list of conditions and the following disclaimer.
|
|---|
| 11 | # - Redistributions in binary form must reproduce the above copyright
|
|---|
| 12 | # notice, this list of conditions and the following disclaimer in the
|
|---|
| 13 | # documentation and/or other materials provided with the distribution.
|
|---|
| 14 | # - The name of the author may not be used to endorse or promote products
|
|---|
| 15 | # derived from this software without specific prior written permission.
|
|---|
| 16 | #
|
|---|
| 17 | # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|---|
| 18 | # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|---|
| 19 | # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|---|
| 20 | # IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|---|
| 21 | # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|---|
| 22 | # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|---|
| 23 | # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|---|
| 24 | # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|---|
| 25 | # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|---|
| 26 | # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|---|
| 27 | #
|
|---|
| 28 |
|
|---|
| [22f851e] | 29 | include ../../../../version
|
|---|
| 30 | include ../../../Makefile.config
|
|---|
| 31 |
|
|---|
| [032a9b3] | 32 | ## Toolchain configuration
|
|---|
| 33 | #
|
|---|
| 34 |
|
|---|
| [e19d667] | 35 | ifeq ($(IMAGE),binary)
|
|---|
| [960f8476] | 36 | LD_IN = binary
|
|---|
| [e19d667] | 37 | endif
|
|---|
| 38 | ifeq ($(IMAGE),ecoff)
|
|---|
| [960f8476] | 39 | LD_IN = ecoff
|
|---|
| [e19d667] | 40 | endif
|
|---|
| 41 | BFD_NAME = elf32-tradlittlemips
|
|---|
| 42 | BFD_ARCH = mips
|
|---|
| [032a9b3] | 43 | TARGET = mipsel-linux-gnu
|
|---|
| 44 | TOOLCHAIN_DIR = /usr/local/mipsel/bin
|
|---|
| 45 |
|
|---|
| [67f5fbd9] | 46 | ifeq ($(COMPILER),gcc_native)
|
|---|
| [032a9b3] | 47 | CC = gcc
|
|---|
| 48 | AS = as
|
|---|
| 49 | LD = ld
|
|---|
| 50 | OBJCOPY = objcopy
|
|---|
| 51 | OBJDUMP = objdump
|
|---|
| [67f5fbd9] | 52 | endif
|
|---|
| 53 |
|
|---|
| 54 | ifeq ($(COMPILER),gcc_cross)
|
|---|
| [032a9b3] | 55 | CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
|
|---|
| 56 | AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
|
|---|
| 57 | LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
|
|---|
| 58 | OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
|
|---|
| 59 | OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
|
|---|
| 60 | endif
|
|---|
| 61 |
|
|---|
| [22f851e] | 62 | CFLAGS = -DRELEASE=\"$(RELEASE)\" -I. -I../../../generic -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mno-abicalls -G 0 -fno-zero-initialized-in-bss -mhard-float -mips3
|
|---|
| 63 |
|
|---|
| 64 | ifdef REVISION
|
|---|
| 65 | CFLAGS += "-DREVISION=\"$(REVISION)\""
|
|---|
| 66 | endif
|
|---|
| 67 |
|
|---|
| 68 | ifdef TIMESTAMP
|
|---|
| 69 | CFLAGS += "-DTIMESTAMP=\"$(TIMESTAMP)\""
|
|---|
| 70 | endif
|
|---|
| [032a9b3] | 71 |
|
|---|
| 72 | SOURCES = \
|
|---|
| 73 | main.c \
|
|---|
| 74 | msim.c \
|
|---|
| [e19d667] | 75 | _components.c \
|
|---|
| [282f4724] | 76 | ../../../generic/printf.c \
|
|---|
| [032a9b3] | 77 | asm.S \
|
|---|
| 78 | boot.S
|
|---|
| 79 |
|
|---|
| [25f089b] | 80 | COMPONENTS = \
|
|---|
| 81 | $(KERNELDIR)/kernel.bin \
|
|---|
| [00acd66] | 82 | $(USPACEDIR)/srv/ns/ns \
|
|---|
| 83 | $(USPACEDIR)/srv/fb/fb \
|
|---|
| 84 | $(USPACEDIR)/srv/kbd/kbd \
|
|---|
| 85 | $(USPACEDIR)/srv/console/console \
|
|---|
| [0e0476ad] | 86 | $(USPACEDIR)/srv/vfs/vfs \
|
|---|
| [2a3db79] | 87 | $(USPACEDIR)/srv/fs/tmpfs/tmpfs \
|
|---|
| [0e0476ad] | 88 | $(USPACEDIR)/srv/fs/fat/fat \
|
|---|
| [13125d3] | 89 | $(USPACEDIR)/srv/devmap/devmap \
|
|---|
| [00acd66] | 90 | $(USPACEDIR)/app/init/init \
|
|---|
| 91 | $(USPACEDIR)/app/tetris/tetris \
|
|---|
| 92 | $(USPACEDIR)/app/tester/tester \
|
|---|
| 93 | $(USPACEDIR)/app/klog/klog
|
|---|
| [25f089b] | 94 |
|
|---|
| [032a9b3] | 95 | OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
|
|---|
| [25f089b] | 96 | COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(COMPONENTS))))
|
|---|
| [032a9b3] | 97 |
|
|---|
| 98 | .PHONY: all clean depend
|
|---|
| 99 |
|
|---|
| 100 | all: image.boot
|
|---|
| 101 |
|
|---|
| 102 | -include Makefile.depend
|
|---|
| 103 |
|
|---|
| [7e2432b] | 104 | image.boot: depend _components.h _link.ld $(COMPONENT_OBJECTS) $(OBJECTS)
|
|---|
| [25f089b] | 105 | $(LD) -no-check-sections -N -T _link.ld $(COMPONENT_OBJECTS) $(OBJECTS) -o $@
|
|---|
| [032a9b3] | 106 |
|
|---|
| 107 | depend:
|
|---|
| 108 | -makedepend $(DEFS) $(CFLAGS) -f - $(SOURCES) > Makefile.depend 2> /dev/null
|
|---|
| 109 |
|
|---|
| 110 | clean:
|
|---|
| [960f8476] | 111 | -rm -f _components.h _components.c _link.ld _link.ld.in $(COMPONENT_OBJECTS) $(OBJECTS) image.boot Makefile.depend
|
|---|
| [032a9b3] | 112 |
|
|---|
| [960f8476] | 113 | _components.h _components.c _link.ld $(COMPONENT_OBJECTS): $(COMPONENTS) _link.ld.in
|
|---|
| 114 | ../../../tools/pack.py $(OBJCOPY) $(BFD_NAME) $(BFD_ARCH) 4096 "unsigned int" $(COMPONENTS)
|
|---|
| 115 |
|
|---|
| 116 | _link.ld.in: _link.ld.in.$(LD_IN)
|
|---|
| 117 | cp $< $@
|
|---|
| [032a9b3] | 118 |
|
|---|
| 119 | %.o: %.S
|
|---|
| 120 | $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
|
|---|
| 121 |
|
|---|
| 122 | %.o: %.c
|
|---|
| 123 | $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
|
|---|