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 |
|
---|
29 | include ../../../../version
|
---|
30 | include ../../../Makefile.config
|
---|
31 |
|
---|
32 | ## Toolchain configuration
|
---|
33 | #
|
---|
34 |
|
---|
35 | TARGET = sparc64-linux-gnu
|
---|
36 | TOOLCHAIN_DIR = /usr/local/sparc64/bin
|
---|
37 |
|
---|
38 | ifeq ($(COMPILER),gcc_native)
|
---|
39 | CC = gcc
|
---|
40 | AS = as
|
---|
41 | LD = ld
|
---|
42 | OBJCOPY = objcopy
|
---|
43 | OBJDUMP = objdump
|
---|
44 | endif
|
---|
45 |
|
---|
46 | ifeq ($(COMPILER),icc_native)
|
---|
47 | CC = icc
|
---|
48 | AS = as
|
---|
49 | LD = ld
|
---|
50 | OBJCOPY = objcopy
|
---|
51 | OBJDUMP = objdump
|
---|
52 | endif
|
---|
53 |
|
---|
54 | ifeq ($(COMPILER),gcc_cross)
|
---|
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 |
|
---|
62 | CFLAGS = -DRELEASE=\"$(RELEASE)\" -I. -I../../../generic -I../../../genarch -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mcpu=ultrasparc -m64
|
---|
63 |
|
---|
64 | ifdef REVISION
|
---|
65 | CFLAGS += "-DREVISION=\"$(REVISION)\""
|
---|
66 | endif
|
---|
67 |
|
---|
68 | ifdef TIMESTAMP
|
---|
69 | CFLAGS += "-DTIMESTAMP=\"$(TIMESTAMP)\""
|
---|
70 | endif
|
---|
71 |
|
---|
72 | SOURCES = \
|
---|
73 | main.c \
|
---|
74 | ../../../generic/printf.c \
|
---|
75 | ../../../generic/string.c \
|
---|
76 | ../../../genarch/balloc.c \
|
---|
77 | ../../../genarch/ofw.c \
|
---|
78 | ../../../genarch/ofw_tree.c \
|
---|
79 | ofwarch.c \
|
---|
80 | asm.S \
|
---|
81 | boot.S
|
---|
82 |
|
---|
83 | COMPONENTS = \
|
---|
84 | $(KERNELDIR)/kernel.bin \
|
---|
85 | $(USPACEDIR)/srv/ns/ns \
|
---|
86 | $(USPACEDIR)/srv/fb/fb \
|
---|
87 | $(USPACEDIR)/srv/kbd/kbd \
|
---|
88 | $(USPACEDIR)/srv/console/console \
|
---|
89 | $(USPACEDIR)/srv/vfs/vfs \
|
---|
90 | $(USPACEDIR)/srv/fs/fat/fat \
|
---|
91 | $(USPACEDIR)/srv/devmap/devmap \
|
---|
92 | $(USPACEDIR)/app/init/init \
|
---|
93 | $(USPACEDIR)/app/tetris/tetris \
|
---|
94 | $(USPACEDIR)/app/tester/tester \
|
---|
95 | $(USPACEDIR)/app/klog/klog
|
---|
96 |
|
---|
97 | OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
|
---|
98 | COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(COMPONENTS))))
|
---|
99 |
|
---|
100 | .PHONY: all clean depend
|
---|
101 |
|
---|
102 | all: image.boot disasm
|
---|
103 |
|
---|
104 | -include Makefile.depend
|
---|
105 |
|
---|
106 | image.boot: depend _components.h _link.ld $(COMPONENT_OBJECTS) $(OBJECTS)
|
---|
107 | $(LD) -Map image.map -no-check-sections -N -T _link.ld $(COMPONENT_OBJECTS) $(OBJECTS) -o $@
|
---|
108 |
|
---|
109 | depend:
|
---|
110 | -makedepend $(DEFS) $(CFLAGS) -f - $(SOURCES) > Makefile.depend 2> /dev/null
|
---|
111 |
|
---|
112 | clean:
|
---|
113 | -rm -f _components.h _link.ld $(COMPONENT_OBJECTS) $(OBJECTS) image.boot boot.disasm Makefile.depend
|
---|
114 |
|
---|
115 | _components.h _link.ld $(COMPONENT_OBJECTS): $(COMPONENTS)
|
---|
116 | ./pack $(IMAGE) $(OBJCOPY) $(COMPONENTS)
|
---|
117 |
|
---|
118 | %.o: %.S
|
---|
119 | $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
|
---|
120 |
|
---|
121 | %.o: %.c
|
---|
122 | $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
|
---|
123 |
|
---|
124 | disasm: image.boot
|
---|
125 | $(OBJDUMP) -d image.boot > boot.disasm
|
---|