source: mainline/boot/arch/sparc64/loader/Makefile@ d9f4c76

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since d9f4c76 was abc4982, checked in by Martin Decky <martin@…>, 16 years ago

group fhc and obio under a common directory

  • Property mode set to 100644
File size: 5.1 KB
Line 
1#
2# Copyright (c) 2006 Martin Decky
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
29include ../../../../version
30-include ../../../../Makefile.config
31
32## Toolchain configuration
33#
34
35ifndef CROSS_PREFIX
36 CROSS_PREFIX = /usr/local
37endif
38
39BFD_NAME = elf64-sparc
40BFD_ARCH = sparc
41TARGET = sparc64-linux-gnu
42TOOLCHAIN_DIR = $(CROSS_PREFIX)/sparc64/bin
43
44ifeq ($(COMPILER),gcc_native)
45 CC = gcc
46 AS = as
47 LD = ld
48 OBJCOPY = objcopy
49 OBJDUMP = objdump
50endif
51
52ifeq ($(COMPILER),gcc_cross)
53 CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
54 AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
55 LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
56 OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
57 OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
58endif
59
60CFLAGS = -DRELEASE=$(RELEASE) -I. -I../../../generic -I../../../genarch -imacros ../../../../config.h -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mcpu=ultrasparc -m64 -mno-fpu -pipe
61
62SOURCES = \
63 main.c \
64 _components.c \
65 ../../../generic/printf.c \
66 ../../../generic/string.c \
67 ../../../genarch/balloc.c \
68 ../../../genarch/ofw.c \
69 ../../../genarch/ofw_tree.c \
70 ofwarch.c \
71 asm.S \
72 boot.S
73
74#
75# All components that go to image.boot without the ramdisk.
76#
77COMPONENTS = \
78 $(KERNELDIR)/kernel.bin \
79 $(USPACEDIR)/srv/ns/ns \
80 $(USPACEDIR)/app/init/init \
81 $(USPACEDIR)/srv/loader/loader \
82 $(USPACEDIR)/srv/devmap/devmap \
83 $(USPACEDIR)/srv/bd/rd/rd \
84 $(USPACEDIR)/srv/vfs/vfs
85ifeq ($(RDFMT),tmpfs)
86 COMPONENTS += $(USPACEDIR)/srv/fs/tmpfs/tmpfs
87endif
88ifeq ($(RDFMT),fat)
89 COMPONENTS += $(USPACEDIR)/srv/fs/fat/fat
90endif
91
92#
93# Final list of all components that go to image.boot.
94#
95ALL_COMPONENTS = $(COMPONENTS)
96ifeq ($(CONFIG_RD_EXTERNAL),n)
97 ALL_COMPONENTS += ./initrd.img
98endif
99
100RD_SRVS = \
101 $(USPACEDIR)/srv/fb/fb \
102 $(USPACEDIR)/srv/kbd/kbd \
103 $(USPACEDIR)/srv/console/console \
104 $(USPACEDIR)/srv/fs/devfs/devfs \
105 $(USPACEDIR)/srv/fs/tmpfs/tmpfs
106
107ifeq ($(MACHINE),generic)
108RD_SRVS += \
109 $(USPACEDIR)/srv/fs/fat/fat \
110 $(USPACEDIR)/srv/cir/fhc/fhc \
111 $(USPACEDIR)/srv/cir/obio/obio
112endif
113
114RD_APPS = \
115 $(USPACEDIR)/app/getvc/getvc \
116 $(USPACEDIR)/app/tetris/tetris \
117 $(USPACEDIR)/app/trace/trace \
118 $(USPACEDIR)/app/bdsh/bdsh \
119 $(USPACEDIR)/app/klog/klog
120
121ifeq ($(MACHINE),generic)
122RD_APPS += \
123 $(USPACEDIR)/app/tester/tester
124endif
125
126OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
127ALL_COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(ALL_COMPONENTS))))
128
129.PHONY: all clean depend
130
131all: image.boot disasm
132
133-include Makefile.depend
134
135image.boot: depend _components.h _link.ld $(ALL_COMPONENT_OBJECTS) $(OBJECTS)
136 $(LD) -Map image.map -no-check-sections -N -T _link.ld $(ALL_COMPONENT_OBJECTS) $(OBJECTS) -o $@
137
138depend:
139 -makedepend -f - -- $(DEFS) $(CFLAGS) -- $(SOURCES) > Makefile.depend 2> /dev/null
140
141clean:
142 -for file in $(RD_SRVS) ; do \
143 rm -f $(USPACEDIR)/dist/srv/`basename $$file` ; \
144 done
145 -for file in $(RD_APPS) ; do \
146 rm -f $(USPACEDIR)/dist/app/`basename $$file` ; \
147 done
148 -rm -f _components.h _components.c _link.ld $(ALL_COMPONENT_OBJECTS) $(OBJECTS) initrd.img image.boot image.map image.disasm Makefile.depend
149
150_components.h _components.c _link.ld $(ALL_COMPONENT_OBJECTS): $(COMPONENTS) $(RD_SRVS) $(RD_APPS) _link.ld.in
151 for file in $(RD_SRVS) ; do \
152 cp $$file $(USPACEDIR)/dist/srv/ ; \
153 done
154 for file in $(RD_APPS) ; do \
155 cp $$file $(USPACEDIR)/dist/app/ ; \
156 done
157ifeq ($(RDFMT),tmpfs)
158 ../../../../tools/mktmpfs.py $(USPACEDIR)/dist/ initrd.fs
159endif
160ifeq ($(RDFMT),fat)
161 ../../../../tools/mkfat.py $(USPACEDIR)/dist/ initrd.fs
162endif
163 ../../../../tools/mkhord.py 16384 initrd.fs initrd.img
164 rm initrd.fs
165 ../../../tools/pack.py $(OBJCOPY) $(BFD_NAME) $(BFD_ARCH) 1 "unsigned long" $(ALL_COMPONENTS)
166
167%.o: %.S
168 $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
169
170%.o: %.c
171 $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
172
173disasm: image.boot
174 $(OBJDUMP) -d image.boot > image.disasm
Note: See TracBrowser for help on using the repository browser.