source: mainline/boot/arch/mips32/loader/Makefile@ 1ea99cc

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 1ea99cc was 1ea99cc, checked in by Jiri Svoboda <jiri@…>, 16 years ago

Merge changes from original Subversion dynload branch.

  • Property mode set to 100644
File size: 5.3 KB
RevLine 
[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]29include ../../../../version
[fa024ce]30-include ../../../../Makefile.config
[22f851e]31
[032a9b3]32## Toolchain configuration
33#
34
[ddb0df5]35ifndef CROSS_PREFIX
36 CROSS_PREFIX = /usr/local
37endif
38
[e19d667]39BFD_ARCH = mips
[032a9b3]40TARGET = mipsel-linux-gnu
[ddb0df5]41TOOLCHAIN_DIR = $(CROSS_PREFIX)/mipsel/bin
[032a9b3]42
[656b789]43ifeq ($(MACHINE),lgxemul)
44 BFD_NAME = elf32-tradlittlemips
45 BFD = ecoff-littlemips
46endif
47ifeq ($(MACHINE),bgxemul)
48 BFD_NAME = elf32-tradbigmips
49 BFD = ecoff-bigmips
50 TOOLCHAIN_DIR = $(CROSS_PREFIX)/mips/bin
51 TARGET = mips-linux-gnu
52endif
53ifeq ($(MACHINE),msim)
54 BFD_NAME = elf32-tradlittlemips
55 BFD = binary
56endif
57
[67f5fbd9]58ifeq ($(COMPILER),gcc_native)
[032a9b3]59 CC = gcc
60 AS = as
61 LD = ld
62 OBJCOPY = objcopy
63 OBJDUMP = objdump
[67f5fbd9]64endif
65
66ifeq ($(COMPILER),gcc_cross)
[032a9b3]67 CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
68 AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
69 LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
70 OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
71 OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
72endif
73
[fa024ce]74CFLAGS = -DRELEASE=$(RELEASE) -I. -I../../../generic -imacros ../../../../config.h -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mno-abicalls -G 0 -fno-zero-initialized-in-bss -mhard-float -mips3 -pipe
[032a9b3]75
76SOURCES = \
77 main.c \
78 msim.c \
[e19d667]79 _components.c \
[282f4724]80 ../../../generic/printf.c \
[89b1b64]81 ../../../generic/string.c \
[032a9b3]82 asm.S \
83 boot.S
84
[25f089b]85COMPONENTS = \
86 $(KERNELDIR)/kernel.bin \
[00acd66]87 $(USPACEDIR)/srv/ns/ns \
[c98e6ee]88 $(USPACEDIR)/srv/loader/loader \
[aaa70841]89 $(USPACEDIR)/app/init/init \
90 $(USPACEDIR)/srv/devmap/devmap \
[e7645de]91 $(USPACEDIR)/srv/bd/rd/rd \
[656b789]92 $(USPACEDIR)/srv/vfs/vfs
[d849cd6]93ifeq ($(RDFMT),tmpfs)
94 COMPONENTS += $(USPACEDIR)/srv/fs/tmpfs/tmpfs
95endif
96ifeq ($(RDFMT),fat)
97 COMPONENTS += $(USPACEDIR)/srv/fs/fat/fat
98endif
[aaa70841]99
[de9c5cb]100RD_SRVS = \
[00acd66]101 $(USPACEDIR)/srv/fb/fb \
102 $(USPACEDIR)/srv/kbd/kbd \
103 $(USPACEDIR)/srv/console/console \
[a095d20]104 $(USPACEDIR)/srv/fs/devfs/devfs \
[d849cd6]105 $(USPACEDIR)/srv/fs/tmpfs/tmpfs \
[44a53fd]106 $(USPACEDIR)/srv/fs/fat/fat \
[2a18193c]107 $(USPACEDIR)/srv/bd/file_bd/file_bd \
[44a53fd]108 $(USPACEDIR)/srv/bd/gxe_bd/gxe_bd
[de9c5cb]109
110RD_APPS = \
[815bf9a5]111 $(USPACEDIR)/app/getvc/getvc \
[00acd66]112 $(USPACEDIR)/app/tetris/tetris \
113 $(USPACEDIR)/app/tester/tester \
[1ea99cc]114 $(USPACEDIR)/app/dload/dload \
115 $(USPACEDIR)/app/dltest/dltest \
116 $(USPACEDIR)/app/dltest2/dltest2 \
[9a1b20c]117 $(USPACEDIR)/app/trace/trace \
[80791a7]118 $(USPACEDIR)/app/bdsh/bdsh \
[00acd66]119 $(USPACEDIR)/app/klog/klog
[25f089b]120
[1ea99cc]121RD_LIBS = \
122 $(USPACEDIR)/lib/libc/shared/libc.so.0 \
123 $(USPACEDIR)/lib/libtest/libtest.so.0
124
[032a9b3]125OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
[25f089b]126COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(COMPONENTS))))
[032a9b3]127
128.PHONY: all clean depend
129
130all: image.boot
131
132-include Makefile.depend
133
[656b789]134image.boot: image.raw
135 $(OBJCOPY) -O $(BFD) $< $@
136
137image.raw: depend _components.h _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS)
138 $(LD) -no-check-sections -N -T _link.ld -o $@ $(COMPONENT_OBJECTS) initrd.o $(OBJECTS)
[032a9b3]139
140depend:
[6198611]141 -makedepend -f - -- $(DEFS) $(CFLAGS) -- $(SOURCES) > Makefile.depend 2> /dev/null
[032a9b3]142
143clean:
[de9c5cb]144 -for file in $(RD_SRVS) ; do \
145 rm -f $(USPACEDIR)/dist/srv/`basename $$file` ; \
146 done
147 -for file in $(RD_APPS) ; do \
148 rm -f $(USPACEDIR)/dist/app/`basename $$file` ; \
[aaa70841]149 done
[656b789]150 -rm -f _components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) initrd.img image.raw image.boot Makefile.depend
[aaa70841]151
[1ea99cc]152_components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o: $(COMPONENTS) $(RD_SRVS) $(RD_LIBS) $(RD_APPS) _link.ld.in
[de9c5cb]153 for file in $(RD_SRVS) ; do \
154 cp $$file $(USPACEDIR)/dist/srv/ ; \
155 done
[1ea99cc]156 for lib in $(RD_LIBS) ; do \
157 cp $$lib $(USPACEDIR)/dist/lib/ ; \
158 done
[de9c5cb]159 for file in $(RD_APPS) ; do \
160 cp $$file $(USPACEDIR)/dist/app/ ; \
[aaa70841]161 done
[d849cd6]162ifeq ($(RDFMT),tmpfs)
[619e7c9b]163 ../../../../tools/mktmpfs.py $(USPACEDIR)/dist/ initrd.fs
[d849cd6]164endif
165ifeq ($(RDFMT),fat)
[95b730c2]166 ../../../../tools/mkfat.py $(USPACEDIR)/dist/ initrd.fs
[d849cd6]167endif
[619e7c9b]168 ../../../../tools/mkhord.py 16384 initrd.fs initrd.img
169 rm initrd.fs
[aaa70841]170 ../../../tools/pack.py $(OBJCOPY) $(BFD_NAME) $(BFD_ARCH) 16384 "unsigned int" $(COMPONENTS) ./initrd.img
[960f8476]171
[032a9b3]172%.o: %.S
173 $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
174
175%.o: %.c
176 $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
Note: See TracBrowser for help on using the repository browser.