Subversion Repositories HelenOS

Rev

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

Rev 2452 Rev 2453
1
#
1
#
2
# Copyright (c) 2005 Martin Decky
2
# Copyright (c) 2005 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
 
29
 
30
## Include configuration
30
## Include configuration
31
#
31
#
32
 
32
 
33
-include ../version
33
-include ../version
34
-include Makefile.config
34
-include Makefile.config
35
 
35
 
36
## Common compiler flags
36
## Common compiler flags
37
#
37
#
38
 
38
 
39
DEFS = -D$(ARCH) -DARCH=\"$(ARCH)\" -DRELEASE=\"$(RELEASE)\" "-DNAME=\"$(NAME)\"" -DKERNEL
39
DEFS = -D$(ARCH) -DARCH=\"$(ARCH)\" -DRELEASE=\"$(RELEASE)\" "-DNAME=\"$(NAME)\"" -DKERNEL
40
CFLAGS = -fno-builtin -fomit-frame-pointer -Wall -Wmissing-prototypes -Werror -O3 -nostdlib -nostdinc -Igeneric/include/
40
CFLAGS = -fno-builtin -fomit-frame-pointer -Wall -Wmissing-prototypes -Werror -O3 -nostdlib -nostdinc -Igeneric/include/
-
 
41
 
41
#SUNCC_CFLAGS = -xO3 -Igeneric/include/ -xnolib -xc99=all -D__FUNCTION__=__func__
42
#SUNCC_CFLAGS = -xO3 -Igeneric/include/ -xnolib -xc99=all \
-
 
43
#-D__FUNCTION__=__func__ -features=extensions \
-
 
44
#-erroff=E_ZERO_SIZED_STRUCT_UNION
-
 
45
 
42
LFLAGS = -M
46
LFLAGS = -M
43
AFLAGS =
47
AFLAGS =
44
 
48
 
45
ifdef REVISION
49
ifdef REVISION
46
	DEFS += "-DREVISION=\"$(REVISION)\""
50
	DEFS += "-DREVISION=\"$(REVISION)\""
47
endif
51
endif
48
 
52
 
49
ifdef TIMESTAMP
53
ifdef TIMESTAMP
50
	DEFS += "-DTIMESTAMP=\"$(TIMESTAMP)\""
54
	DEFS += "-DTIMESTAMP=\"$(TIMESTAMP)\""
51
endif
55
endif
52
 
56
 
53
## Setup kernel configuration
57
## Setup kernel configuration
54
#
58
#
55
 
59
 
56
-include arch/$(ARCH)/Makefile.inc
60
-include arch/$(ARCH)/Makefile.inc
57
-include genarch/Makefile.inc
61
-include genarch/Makefile.inc
58
 
62
 
59
ifeq ($(CONFIG_DEBUG),y)
63
ifeq ($(CONFIG_DEBUG),y)
60
	DEFS += -DCONFIG_DEBUG
64
	DEFS += -DCONFIG_DEBUG
61
endif
65
endif
62
 
66
 
63
ifeq ($(CONFIG_DEBUG_SPINLOCK),y)
67
ifeq ($(CONFIG_DEBUG_SPINLOCK),y)
64
	DEFS += -DCONFIG_DEBUG_SPINLOCK
68
	DEFS += -DCONFIG_DEBUG_SPINLOCK
65
endif
69
endif
66
 
70
 
67
ifeq ($(CONFIG_DEBUG_AS_WATCHPOINT),y)
71
ifeq ($(CONFIG_DEBUG_AS_WATCHPOINT),y)
68
	DEFS += -DCONFIG_DEBUG_AS_WATCHPOINT
72
	DEFS += -DCONFIG_DEBUG_AS_WATCHPOINT
69
endif
73
endif
70
 
74
 
71
ifeq ($(CONFIG_FPU_LAZY),y)
75
ifeq ($(CONFIG_FPU_LAZY),y)
72
	DEFS += -DCONFIG_FPU_LAZY
76
	DEFS += -DCONFIG_FPU_LAZY
73
endif
77
endif
74
 
78
 
75
ifeq ($(CONFIG_DEBUG_ALLREGS),y)
79
ifeq ($(CONFIG_DEBUG_ALLREGS),y)
76
	DEFS += -DCONFIG_DEBUG_ALLREGS
80
	DEFS += -DCONFIG_DEBUG_ALLREGS
77
endif
81
endif
78
 
82
 
79
ifeq ($(CONFIG_VHPT),y)
83
ifeq ($(CONFIG_VHPT),y)
80
	DEFS += -DCONFIG_VHPT
84
	DEFS += -DCONFIG_VHPT
81
endif
85
endif
82
 
86
 
83
ifeq ($(CONFIG_TSB),y)
87
ifeq ($(CONFIG_TSB),y)
84
	DEFS += -DCONFIG_TSB
88
	DEFS += -DCONFIG_TSB
85
endif
89
endif
86
 
90
 
87
ifeq ($(CONFIG_Z8530),y)
91
ifeq ($(CONFIG_Z8530),y)
88
	DEFS += -DCONFIG_Z8530
92
	DEFS += -DCONFIG_Z8530
89
endif
93
endif
90
 
94
 
91
ifeq ($(CONFIG_NS16550),y)
95
ifeq ($(CONFIG_NS16550),y)
92
	DEFS += -DCONFIG_NS16550
96
	DEFS += -DCONFIG_NS16550
93
endif
97
endif
94
 
98
 
95
ifeq ($(CONFIG_VIRT_IDX_DCACHE),y)
99
ifeq ($(CONFIG_VIRT_IDX_DCACHE),y)
96
	DEFS += -DCONFIG_VIRT_IDX_DCACHE
100
	DEFS += -DCONFIG_VIRT_IDX_DCACHE
97
endif
101
endif
98
 
102
 
99
ifeq ($(CONFIG_FB),y)
103
ifeq ($(CONFIG_FB),y)
100
	ifeq ($(ARCH),ia32)
104
	ifeq ($(ARCH),ia32)
101
		DEFS += -DCONFIG_VESA_WIDTH=$(CONFIG_VESA_WIDTH)
105
		DEFS += -DCONFIG_VESA_WIDTH=$(CONFIG_VESA_WIDTH)
102
		DEFS += -DCONFIG_VESA_HEIGHT=$(CONFIG_VESA_HEIGHT)
106
		DEFS += -DCONFIG_VESA_HEIGHT=$(CONFIG_VESA_HEIGHT)
103
		DEFS += -DCONFIG_VESA_BPP=$(CONFIG_VESA_BPP)
107
		DEFS += -DCONFIG_VESA_BPP=$(CONFIG_VESA_BPP)
104
	endif
108
	endif
105
	
109
	
106
	ifeq ($(ARCH),amd64)
110
	ifeq ($(ARCH),amd64)
107
		DEFS += -DCONFIG_VESA_WIDTH=$(CONFIG_VESA_WIDTH)
111
		DEFS += -DCONFIG_VESA_WIDTH=$(CONFIG_VESA_WIDTH)
108
		DEFS += -DCONFIG_VESA_HEIGHT=$(CONFIG_VESA_HEIGHT)
112
		DEFS += -DCONFIG_VESA_HEIGHT=$(CONFIG_VESA_HEIGHT)
109
		DEFS += -DCONFIG_VESA_BPP=$(CONFIG_VESA_BPP)
113
		DEFS += -DCONFIG_VESA_BPP=$(CONFIG_VESA_BPP)
110
	endif
114
	endif
111
	
115
	
112
	ifeq ($(ARCH),ia32xen)
116
	ifeq ($(ARCH),ia32xen)
113
		DEFS += -DCONFIG_VESA_WIDTH=$(CONFIG_VESA_WIDTH)
117
		DEFS += -DCONFIG_VESA_WIDTH=$(CONFIG_VESA_WIDTH)
114
		DEFS += -DCONFIG_VESA_HEIGHT=$(CONFIG_VESA_HEIGHT)
118
		DEFS += -DCONFIG_VESA_HEIGHT=$(CONFIG_VESA_HEIGHT)
115
		DEFS += -DCONFIG_VESA_BPP=$(CONFIG_VESA_BPP)
119
		DEFS += -DCONFIG_VESA_BPP=$(CONFIG_VESA_BPP)
116
	endif
120
	endif
117
endif
121
endif
118
 
122
 
119
## Toolchain configuration
123
## Toolchain configuration
120
#
124
#
121
 
125
 
122
ifeq ($(COMPILER),gcc_native)
126
ifeq ($(COMPILER),gcc_native)
123
	CC = gcc
127
	CC = gcc
124
	AS_CC = gcc
128
	AS_CC = gcc
125
	AS = as
129
	AS = as
126
	LD = ld
130
	LD = ld
127
	OBJCOPY = objcopy
131
	OBJCOPY = objcopy
128
	OBJDUMP = objdump
132
	OBJDUMP = objdump
129
	LIBDIR = /usr/lib
133
	LIBDIR = /usr/lib
130
endif
134
endif
131
 
135
 
132
ifeq ($(COMPILER),icc_native)
136
ifeq ($(COMPILER),icc_native)
133
	CC = icc
137
	CC = icc
134
	AS_CC = gcc
138
	AS_CC = gcc
135
	AS = as
139
	AS = as
136
	LD = ld
140
	LD = ld
137
	OBJCOPY = objcopy
141
	OBJCOPY = objcopy
138
	OBJDUMP = objdump
142
	OBJDUMP = objdump
139
	LIBDIR = /usr/lib
143
	LIBDIR = /usr/lib
140
endif
144
endif
141
 
145
 
142
ifeq ($(COMPILER),suncc_native)
146
ifeq ($(COMPILER),suncc_native)
143
	CC = suncc
147
	CC = suncc
144
	AS_CC = gcc
148
	AS_CC = gcc
145
	AS = as
149
	AS = as
146
	LD = ld
150
	LD = ld
147
	OBJCOPY = objcopy
151
	OBJCOPY = objcopy
148
	OBJDUMP = objdump
152
	OBJDUMP = objdump
149
	LIBDIR = /usr/lib
153
	LIBDIR = /usr/lib
150
endif
154
endif
151
 
155
 
152
ifeq ($(COMPILER),gcc_cross)
156
ifeq ($(COMPILER),gcc_cross)
153
	CC = $(TOOLCHAIN_DIR)/bin/$(TARGET)-gcc
157
	CC = $(TOOLCHAIN_DIR)/bin/$(TARGET)-gcc
154
	AS_CC = $(CC)
158
	AS_CC = $(CC)
155
	AS = $(TOOLCHAIN_DIR)/bin/$(TARGET)-as
159
	AS = $(TOOLCHAIN_DIR)/bin/$(TARGET)-as
156
	LD = $(TOOLCHAIN_DIR)/bin/$(TARGET)-ld
160
	LD = $(TOOLCHAIN_DIR)/bin/$(TARGET)-ld
157
	OBJCOPY = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objcopy
161
	OBJCOPY = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objcopy
158
	OBJDUMP = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objdump
162
	OBJDUMP = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objdump
159
	LIBDIR = $(TOOLCHAIN_DIR)/lib
163
	LIBDIR = $(TOOLCHAIN_DIR)/lib
160
endif
164
endif
161
 
165
 
162
## Generic kernel sources
166
## Generic kernel sources
163
#
167
#
164
 
168
 
165
GENERIC_SOURCES = \
169
GENERIC_SOURCES = \
166
	generic/src/adt/bitmap.c \
170
	generic/src/adt/bitmap.c \
167
	generic/src/adt/btree.c \
171
	generic/src/adt/btree.c \
168
	generic/src/adt/hash_table.c \
172
	generic/src/adt/hash_table.c \
169
	generic/src/adt/list.c \
173
	generic/src/adt/list.c \
170
	generic/src/console/chardev.c \
174
	generic/src/console/chardev.c \
171
	generic/src/console/console.c \
175
	generic/src/console/console.c \
172
	generic/src/console/kconsole.c \
176
	generic/src/console/kconsole.c \
173
	generic/src/console/klog.c \
177
	generic/src/console/klog.c \
174
	generic/src/console/cmd.c \
178
	generic/src/console/cmd.c \
175
	generic/src/cpu/cpu.c \
179
	generic/src/cpu/cpu.c \
176
	generic/src/ddi/ddi.c \
180
	generic/src/ddi/ddi.c \
177
	generic/src/ddi/irq.c \
181
	generic/src/ddi/irq.c \
178
	generic/src/ddi/device.c \
182
	generic/src/ddi/device.c \
179
	generic/src/interrupt/interrupt.c \
183
	generic/src/interrupt/interrupt.c \
180
	generic/src/main/main.c \
184
	generic/src/main/main.c \
181
	generic/src/main/kinit.c \
185
	generic/src/main/kinit.c \
182
	generic/src/main/uinit.c \
186
	generic/src/main/uinit.c \
183
	generic/src/main/version.c \
187
	generic/src/main/version.c \
184
	generic/src/main/shutdown.c \
188
	generic/src/main/shutdown.c \
185
	generic/src/proc/scheduler.c \
189
	generic/src/proc/scheduler.c \
186
	generic/src/proc/thread.c \
190
	generic/src/proc/thread.c \
187
	generic/src/proc/task.c \
191
	generic/src/proc/task.c \
188
	generic/src/proc/the.c \
192
	generic/src/proc/the.c \
189
	generic/src/syscall/syscall.c \
193
	generic/src/syscall/syscall.c \
190
	generic/src/syscall/copy.c \
194
	generic/src/syscall/copy.c \
191
	generic/src/mm/buddy.c \
195
	generic/src/mm/buddy.c \
192
	generic/src/mm/frame.c \
196
	generic/src/mm/frame.c \
193
	generic/src/mm/page.c \
197
	generic/src/mm/page.c \
194
	generic/src/mm/tlb.c \
198
	generic/src/mm/tlb.c \
195
	generic/src/mm/as.c \
199
	generic/src/mm/as.c \
196
	generic/src/mm/backend_anon.c \
200
	generic/src/mm/backend_anon.c \
197
	generic/src/mm/backend_elf.c \
201
	generic/src/mm/backend_elf.c \
198
	generic/src/mm/backend_phys.c \
202
	generic/src/mm/backend_phys.c \
199
	generic/src/mm/slab.c \
203
	generic/src/mm/slab.c \
200
	generic/src/lib/func.c \
204
	generic/src/lib/func.c \
201
	generic/src/lib/memstr.c \
205
	generic/src/lib/memstr.c \
202
	generic/src/lib/sort.c \
206
	generic/src/lib/sort.c \
203
	generic/src/lib/elf.c \
207
	generic/src/lib/elf.c \
204
	generic/src/lib/rd.c \
208
	generic/src/lib/rd.c \
205
	generic/src/printf/printf_core.c \
209
	generic/src/printf/printf_core.c \
206
	generic/src/printf/printf.c \
210
	generic/src/printf/printf.c \
207
	generic/src/printf/sprintf.c \
211
	generic/src/printf/sprintf.c \
208
	generic/src/printf/snprintf.c \
212
	generic/src/printf/snprintf.c \
209
	generic/src/printf/vprintf.c \
213
	generic/src/printf/vprintf.c \
210
	generic/src/printf/vsprintf.c \
214
	generic/src/printf/vsprintf.c \
211
	generic/src/printf/vsnprintf.c \
215
	generic/src/printf/vsnprintf.c \
212
	generic/src/debug/symtab.c \
216
	generic/src/debug/symtab.c \
213
	generic/src/time/clock.c \
217
	generic/src/time/clock.c \
214
	generic/src/time/timeout.c \
218
	generic/src/time/timeout.c \
215
	generic/src/time/delay.c \
219
	generic/src/time/delay.c \
216
	generic/src/preempt/preemption.c \
220
	generic/src/preempt/preemption.c \
217
	generic/src/synch/spinlock.c \
221
	generic/src/synch/spinlock.c \
218
	generic/src/synch/condvar.c \
222
	generic/src/synch/condvar.c \
219
	generic/src/synch/rwlock.c \
223
	generic/src/synch/rwlock.c \
220
	generic/src/synch/mutex.c \
224
	generic/src/synch/mutex.c \
221
	generic/src/synch/semaphore.c \
225
	generic/src/synch/semaphore.c \
222
	generic/src/synch/waitq.c \
226
	generic/src/synch/waitq.c \
223
	generic/src/synch/futex.c \
227
	generic/src/synch/futex.c \
224
	generic/src/smp/ipi.c \
228
	generic/src/smp/ipi.c \
225
	generic/src/smp/smp.c \
229
	generic/src/smp/smp.c \
226
	generic/src/ipc/ipc.c \
230
	generic/src/ipc/ipc.c \
227
	generic/src/ipc/sysipc.c \
231
	generic/src/ipc/sysipc.c \
228
	generic/src/ipc/ipcrsc.c \
232
	generic/src/ipc/ipcrsc.c \
229
	generic/src/ipc/irq.c \
233
	generic/src/ipc/irq.c \
230
	generic/src/security/cap.c \
234
	generic/src/security/cap.c \
231
	generic/src/sysinfo/sysinfo.c
235
	generic/src/sysinfo/sysinfo.c
232
 
236
 
233
## Test sources
237
## Test sources
234
#
238
#
235
 
239
 
236
ifeq ($(CONFIG_TEST),y)
240
ifeq ($(CONFIG_TEST),y)
237
	DEFS += -DCONFIG_TEST
241
	DEFS += -DCONFIG_TEST
238
	CFLAGS += -Itest/
242
	CFLAGS += -Itest/
239
	GENERIC_SOURCES += \
243
	GENERIC_SOURCES += \
240
		test/test.c \
244
		test/test.c \
241
		test/atomic/atomic1.c \
245
		test/atomic/atomic1.c \
242
		test/btree/btree1.c \
246
		test/btree/btree1.c \
243
		test/debug/mips1.c \
247
		test/debug/mips1.c \
244
		test/fault/fault1.c \
248
		test/fault/fault1.c \
245
		test/fpu/fpu1.c \
249
		test/fpu/fpu1.c \
246
		test/fpu/sse1.c \
250
		test/fpu/sse1.c \
247
		test/fpu/mips2.c \
251
		test/fpu/mips2.c \
248
		test/mm/falloc1.c \
252
		test/mm/falloc1.c \
249
		test/mm/falloc2.c \
253
		test/mm/falloc2.c \
250
		test/mm/mapping1.c \
254
		test/mm/mapping1.c \
251
		test/mm/slab1.c \
255
		test/mm/slab1.c \
252
		test/mm/slab2.c \
256
		test/mm/slab2.c \
253
		test/mm/purge1.c \
257
		test/mm/purge1.c \
254
		test/synch/rwlock1.c \
258
		test/synch/rwlock1.c \
255
		test/synch/rwlock2.c \
259
		test/synch/rwlock2.c \
256
		test/synch/rwlock3.c \
260
		test/synch/rwlock3.c \
257
		test/synch/rwlock4.c \
261
		test/synch/rwlock4.c \
258
		test/synch/rwlock5.c \
262
		test/synch/rwlock5.c \
259
		test/synch/semaphore1.c \
263
		test/synch/semaphore1.c \
260
		test/synch/semaphore2.c \
264
		test/synch/semaphore2.c \
261
		test/print/print1.c \
265
		test/print/print1.c \
262
		test/thread/thread1.c \
266
		test/thread/thread1.c \
263
		test/sysinfo/sysinfo1.c
267
		test/sysinfo/sysinfo1.c
264
endif
268
endif
265
 
269
 
266
## Experimental features
270
## Experimental features
267
#
271
#
268
 
272
 
269
ifeq ($(CONFIG_EXPERIMENTAL),y)
273
ifeq ($(CONFIG_EXPERIMENTAL),y)
270
	GENERIC_SOURCES += generic/src/lib/objc_ext.c \
274
	GENERIC_SOURCES += generic/src/lib/objc_ext.c \
271
		generic/src/lib/objc.c
275
		generic/src/lib/objc.c
272
	EXTRA_OBJECTS = $(LIBDIR)/libobjc.a
276
	EXTRA_OBJECTS = $(LIBDIR)/libobjc.a
273
	EXTRA_FLAGS += -x objective-c
277
	EXTRA_FLAGS += -x objective-c
274
endif
278
endif
275
 
279
 
276
GENERIC_OBJECTS := $(addsuffix .o,$(basename $(GENERIC_SOURCES)))
280
GENERIC_OBJECTS := $(addsuffix .o,$(basename $(GENERIC_SOURCES)))
277
ARCH_OBJECTS := $(addsuffix .o,$(basename $(ARCH_SOURCES)))
281
ARCH_OBJECTS := $(addsuffix .o,$(basename $(ARCH_SOURCES)))
278
GENARCH_OBJECTS := $(addsuffix .o,$(basename $(GENARCH_SOURCES)))
282
GENARCH_OBJECTS := $(addsuffix .o,$(basename $(GENARCH_SOURCES)))
279
 
283
 
280
.PHONY: all build config distclean clean archlinks depend disasm
284
.PHONY: all build config distclean clean archlinks depend disasm
281
 
285
 
282
all:
286
all:
283
	../tools/config.py kernel.config default $(ARCH) $(COMPILER) $(CONFIG_DEBUG) $(MACHINE)
287
	../tools/config.py kernel.config default $(ARCH) $(COMPILER) $(CONFIG_DEBUG) $(MACHINE)
284
	$(MAKE) -C . build
288
	$(MAKE) -C . build
285
 
289
 
286
build: kernel.bin disasm
290
build: kernel.bin disasm
287
 
291
 
288
config:
292
config:
289
	-rm Makefile.depend
293
	-rm Makefile.depend
290
	../tools/config.py kernel.config
294
	../tools/config.py kernel.config
291
 
295
 
292
-include Makefile.depend
296
-include Makefile.depend
293
 
297
 
294
distclean: clean
298
distclean: clean
295
	-rm Makefile.config
299
	-rm Makefile.config
296
 
300
 
297
clean:
301
clean:
298
	-rm -f kernel.bin kernel.raw kernel.map kernel.map.pre kernel.objdump kernel.disasm generic/src/debug/real_map.bin Makefile.depend* generic/include/arch generic/include/genarch arch/$(ARCH)/_link.ld
302
	-rm -f kernel.bin kernel.raw kernel.map kernel.map.pre kernel.objdump kernel.disasm generic/src/debug/real_map.bin Makefile.depend* generic/include/arch generic/include/genarch arch/$(ARCH)/_link.ld
299
	find generic/src/ arch/*/src/ genarch/src/ test/ -name '*.o' -follow -exec rm \{\} \;
303
	find generic/src/ arch/*/src/ genarch/src/ test/ -name '*.o' -follow -exec rm \{\} \;
300
	for arch in arch/* ; do \
304
	for arch in arch/* ; do \
301
	    [ -e $$arch/_link.ld ] && rm $$arch/_link.ld 2>/dev/null ; \
305
	    [ -e $$arch/_link.ld ] && rm $$arch/_link.ld 2>/dev/null ; \
302
	done ; exit 0
306
	done ; exit 0
303
 
307
 
304
archlinks:
308
archlinks:
305
	ln -sfn ../../arch/$(ARCH)/include/ generic/include/arch
309
	ln -sfn ../../arch/$(ARCH)/include/ generic/include/arch
306
	ln -sfn ../../genarch/include/ generic/include/genarch
310
	ln -sfn ../../genarch/include/ generic/include/genarch
307
 
311
 
308
depend: archlinks
312
depend: archlinks
309
	-makedepend $(DEFS) $(CFLAGS) -f - $(ARCH_SOURCES) $(GENARCH_SOURCES) $(GENERIC_SOURCES) > Makefile.depend 2> /dev/null
313
	-makedepend $(DEFS) $(CFLAGS) -f - $(ARCH_SOURCES) $(GENARCH_SOURCES) $(GENERIC_SOURCES) > Makefile.depend 2> /dev/null
310
 
314
 
311
arch/$(ARCH)/_link.ld: arch/$(ARCH)/_link.ld.in
315
arch/$(ARCH)/_link.ld: arch/$(ARCH)/_link.ld.in
312
	$(CC) $(DEFS) $(CFLAGS) -D__ASM__ -D__LINKER__ -E -x c $< | grep -v "^\#" > $@
316
	$(CC) $(DEFS) $(CFLAGS) -D__ASM__ -D__LINKER__ -E -x c $< | grep -v "^\#" > $@
313
 
317
 
314
generic/src/debug/real_map.bin: depend arch/$(ARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS)
318
generic/src/debug/real_map.bin: depend arch/$(ARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS)
315
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab Makefile generic/src/debug/empty_map.o
319
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab Makefile generic/src/debug/empty_map.o
316
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/empty_map.o  -o $@ -Map kernel.map.pre
320
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/empty_map.o  -o $@ -Map kernel.map.pre
317
	$(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump
321
	$(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump
318
	tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin 
322
	tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin 
319
	# Do it once again, this time to get correct even the symbols
323
	# Do it once again, this time to get correct even the symbols
320
	# on architectures, that have bss after symtab
324
	# on architectures, that have bss after symtab
321
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab generic/src/debug/real_map.bin generic/src/debug/sizeok_map.o
325
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab generic/src/debug/real_map.bin generic/src/debug/sizeok_map.o
322
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/sizeok_map.o -o $@ -Map kernel.map.pre
326
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/sizeok_map.o -o $@ -Map kernel.map.pre
323
	$(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump
327
	$(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump
324
	tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin 
328
	tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin 
325
 
329
 
326
generic/src/debug/real_map.o: generic/src/debug/real_map.bin
330
generic/src/debug/real_map.o: generic/src/debug/real_map.bin
327
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab $< $@
331
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab $< $@
328
 
332
 
329
kernel.raw: depend arch/$(ARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) generic/src/debug/real_map.o
333
kernel.raw: depend arch/$(ARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) generic/src/debug/real_map.o
330
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/real_map.o -o $@ -Map kernel.map
334
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/real_map.o -o $@ -Map kernel.map
331
 
335
 
332
kernel.bin: kernel.raw
336
kernel.bin: kernel.raw
333
	$(OBJCOPY) -O $(BFD) kernel.raw kernel.bin
337
	$(OBJCOPY) -O $(BFD) kernel.raw kernel.bin
334
 
338
 
335
disasm: kernel.raw
339
disasm: kernel.raw
336
	$(OBJDUMP) -d kernel.raw > kernel.disasm
340
	$(OBJDUMP) -d kernel.raw > kernel.disasm
337
 
341
 
338
%.o: %.S
342
%.o: %.S
339
	$(AS_CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
343
	$(AS_CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
340
 
344
 
341
%.o: %.s
345
%.o: %.s
342
	$(AS) $(AFLAGS) $< -o $@
346
	$(AS) $(AFLAGS) $< -o $@
343
 
347
 
344
%.o: %.c
348
%.o: %.c
345
	$(CC) $(DEFS) $(CFLAGS) $(EXTRA_FLAGS) -c $< -o $@
349
	$(CC) $(DEFS) $(CFLAGS) $(EXTRA_FLAGS) -c $< -o $@
346
 
350