Subversion Repositories HelenOS

Rev

Rev 3244 | Rev 3324 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 3244 Rev 3258
1
#
1
#
2
# Copyright (c) 2006 Martin Decky
2
# Copyright (c) 2006 Martin Decky
3
# All rights reserved.
3
# All rights reserved.
4
#
4
#
5
# Redistribution and use in source and binary forms, with or without
5
# Redistribution and use in source and binary forms, with or without
6
# modification, are permitted provided that the following conditions
6
# modification, are permitted provided that the following conditions
7
# are met:
7
# are met:
8
#
8
#
9
# - Redistributions of source code must retain the above copyright
9
# - Redistributions of source code must retain the above copyright
10
#   notice, this list of conditions and the following disclaimer.
10
#   notice, this list of conditions and the following disclaimer.
11
# - Redistributions in binary form must reproduce the above copyright
11
# - Redistributions in binary form must reproduce the above copyright
12
#   notice, this list of conditions and the following disclaimer in the
12
#   notice, this list of conditions and the following disclaimer in the
13
#   documentation and/or other materials provided with the distribution.
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
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.
15
#   derived from this software without specific prior written permission.
16
#
16
#
17
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
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
18
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20
# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20
# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
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
23
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
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
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.
26
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
#
27
#
28
 
28
 
29
include ../../../../version
29
include ../../../../version
30
include ../../../Makefile.config
30
include ../../../Makefile.config
31
 
31
 
32
## Toolchain configuration
32
## Toolchain configuration
33
#
33
#
34
 
34
 
35
BFD_NAME = elf64-sparc
35
BFD_NAME = elf64-sparc
36
BFD_ARCH = sparc
36
BFD_ARCH = sparc
37
TARGET = sparc64-linux-gnu
37
TARGET = sparc64-linux-gnu
38
TOOLCHAIN_DIR = /usr/local/sparc64/bin
38
TOOLCHAIN_DIR = /usr/local/sparc64/bin
39
 
39
 
40
ifeq ($(COMPILER),gcc_native)
40
ifeq ($(COMPILER),gcc_native)
41
	CC = gcc
41
	CC = gcc
42
	AS = as
42
	AS = as
43
	LD = ld
43
	LD = ld
44
	OBJCOPY = objcopy
44
	OBJCOPY = objcopy
45
	OBJDUMP = objdump
45
	OBJDUMP = objdump
46
endif
46
endif
47
 
47
 
48
ifeq ($(COMPILER),gcc_cross)
48
ifeq ($(COMPILER),gcc_cross)
49
	CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
49
	CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
50
	AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
50
	AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
51
	LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
51
	LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
52
	OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
52
	OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
53
	OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
53
	OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
54
endif
54
endif
55
 
55
 
56
CFLAGS = -DRELEASE=\"$(RELEASE)\" -I. -I../../../generic -I../../../genarch -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mcpu=ultrasparc -m64
56
CFLAGS = -DRELEASE=\"$(RELEASE)\" -I. -I../../../generic -I../../../genarch -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mcpu=ultrasparc -m64
57
 
57
 
58
ifdef REVISION
58
ifdef REVISION
59
	CFLAGS += "-DREVISION=\"$(REVISION)\""
59
	CFLAGS += "-DREVISION=\"$(REVISION)\""
60
endif
60
endif
61
 
61
 
62
ifdef TIMESTAMP
62
ifdef TIMESTAMP
63
	CFLAGS += "-DTIMESTAMP=\"$(TIMESTAMP)\""
63
	CFLAGS += "-DTIMESTAMP=\"$(TIMESTAMP)\""
64
endif
64
endif
65
 
65
 
66
SOURCES = \
66
SOURCES = \
67
	main.c \
67
	main.c \
68
	_components.c \
68
	_components.c \
69
	../../../generic/printf.c \
69
	../../../generic/printf.c \
70
	../../../generic/string.c \
70
	../../../generic/string.c \
71
	../../../genarch/balloc.c \
71
	../../../genarch/balloc.c \
72
	../../../genarch/ofw.c \
72
	../../../genarch/ofw.c \
73
	../../../genarch/ofw_tree.c \
73
	../../../genarch/ofw_tree.c \
74
	ofwarch.c \
74
	ofwarch.c \
75
	asm.S \
75
	asm.S \
76
	boot.S
76
	boot.S
77
 
77
 
78
COMPONENTS = \
78
COMPONENTS = \
79
	$(KERNELDIR)/kernel.bin \
79
	$(KERNELDIR)/kernel.bin \
80
	$(USPACEDIR)/srv/ns/ns \
80
	$(USPACEDIR)/srv/ns/ns \
81
	$(USPACEDIR)/app/init/init \
81
	$(USPACEDIR)/app/init/init \
82
	$(USPACEDIR)/srv/loader/loader \
82
	$(USPACEDIR)/srv/loader/loader \
83
	$(USPACEDIR)/srv/devmap/devmap \
83
	$(USPACEDIR)/srv/devmap/devmap \
84
	$(USPACEDIR)/srv/rd/rd \
84
	$(USPACEDIR)/srv/rd/rd \
85
	$(USPACEDIR)/srv/vfs/vfs \
85
	$(USPACEDIR)/srv/vfs/vfs \
86
	$(USPACEDIR)/srv/fs/tmpfs/tmpfs
86
	$(USPACEDIR)/srv/fs/tmpfs/tmpfs
87
 
87
 
88
RD_TASKS = \
88
RD_TASKS = \
89
	$(USPACEDIR)/srv/fb/fb \
89
	$(USPACEDIR)/srv/fb/fb \
90
	$(USPACEDIR)/srv/kbd/kbd \
90
	$(USPACEDIR)/srv/kbd/kbd \
91
	$(USPACEDIR)/srv/console/console \
91
	$(USPACEDIR)/srv/console/console \
92
	$(USPACEDIR)/srv/fs/fat/fat \
92
	$(USPACEDIR)/srv/fs/fat/fat \
93
	$(USPACEDIR)/app/tetris/tetris \
93
	$(USPACEDIR)/app/tetris/tetris \
94
	$(USPACEDIR)/app/tester/tester \
94
	$(USPACEDIR)/app/tester/tester \
95
	$(USPACEDIR)/app/cli/cli \
95
	$(USPACEDIR)/app/cli/cli \
96
	$(USPACEDIR)/app/klog/klog
96
	$(USPACEDIR)/app/klog/klog
97
 
97
 
98
OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
98
OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
99
COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(COMPONENTS))))
99
COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(COMPONENTS))))
100
 
100
 
101
.PHONY: all clean depend
101
.PHONY: all clean depend
102
 
102
 
103
all: image.boot disasm
103
all: image.boot disasm
104
 
104
 
105
-include Makefile.depend
105
-include Makefile.depend
106
 
106
 
107
image.boot: depend _components.h _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS)
107
image.boot: depend _components.h _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS)
108
	$(LD) -Map image.map -no-check-sections -N -T _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) -o $@
108
	$(LD) -Map image.map -no-check-sections -N -T _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) -o $@
109
 
109
 
110
depend:
110
depend:
111
	-makedepend $(DEFS) $(CFLAGS) -f - $(SOURCES) > Makefile.depend 2> /dev/null
111
	-makedepend $(DEFS) $(CFLAGS) -f - $(SOURCES) > Makefile.depend 2> /dev/null
112
 
112
 
113
clean:
113
clean:
114
	-for task in $(RD_TASKS) ; do \
114
	-for task in $(RD_TASKS) ; do \
115
		rm -f $(USPACEDIR)/dist/sbin/`basename $$task` ; \
115
		rm -f $(USPACEDIR)/dist/sbin/`basename $$task` ; \
116
	done
116
	done
117
	-rm -f _components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) initrd.img image.boot image.map image.disasm Makefile.depend
117
	-rm -f _components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) initrd.img image.boot image.map image.disasm Makefile.depend
118
 
118
 
119
_components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o: $(COMPONENTS) $(RD_TASKS) _link.ld.in
119
_components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o: $(COMPONENTS) $(RD_TASKS) _link.ld.in
120
	for task in $(RD_TASKS) ; do \
120
	for task in $(RD_TASKS) ; do \
121
		cp $$task $(USPACEDIR)/dist/sbin/ ; \
121
		cp $$task $(USPACEDIR)/dist/sbin/ ; \
122
	done
122
	done
123
	../../../../tools/mktmpfs.py $(USPACEDIR)/dist/ initrd.fs.img
123
	../../../../tools/mktmpfs.py $(USPACEDIR)/dist/ initrd.fs
124
	../../../../tools/mkhord.py 16384 initrd.fs.img initrd.img
124
	../../../../tools/mkhord.py 16384 initrd.fs initrd.img
125
	rm initrd.fs.img
125
	rm initrd.fs
126
	../../../tools/pack.py $(OBJCOPY) $(BFD_NAME) $(BFD_ARCH) 1 "unsigned long" $(COMPONENTS) ./initrd.img
126
	../../../tools/pack.py $(OBJCOPY) $(BFD_NAME) $(BFD_ARCH) 1 "unsigned long" $(COMPONENTS) ./initrd.img
127
 
127
 
128
%.o: %.S
128
%.o: %.S
129
	$(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
129
	$(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
130
 
130
 
131
%.o: %.c
131
%.o: %.c
132
	$(CC) $(DEFS) $(CFLAGS) -c $< -o $@
132
	$(CC) $(DEFS) $(CFLAGS) -c $< -o $@
133
 
133
 
134
disasm: image.boot
134
disasm: image.boot
135
	$(OBJDUMP) -d image.boot > image.disasm
135
	$(OBJDUMP) -d image.boot > image.disasm
136
 
136