Rev 4377 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 4377 | Rev 4692 | ||
---|---|---|---|
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 | -include ../config.defs |
35 | -include ../config.defs |
36 | 36 | ||
37 | INCLUDES = generic/include |
37 | INCLUDES = generic/include |
38 | OPTIMIZATION = 3 |
38 | OPTIMIZATION = 3 |
39 | 39 | ||
40 | ifndef CROSS_PREFIX |
40 | ifndef CROSS_PREFIX |
41 | CROSS_PREFIX = /usr/local |
41 | CROSS_PREFIX = /usr/local |
42 | endif |
42 | endif |
43 | 43 | ||
44 | ## Common compiler flags |
44 | ## Common compiler flags |
45 | # |
45 | # |
46 | 46 | ||
47 | DEFS = -DKERNEL -DRELEASE=$(RELEASE) "-DNAME=$(NAME)" |
47 | DEFS = -DKERNEL -DRELEASE=$(RELEASE) "-DNAME=$(NAME)" -D__$(BITS)_BITS__ -D__$(ENDIANESS)__ |
48 | 48 | ||
49 | GCC_CFLAGS = -I$(INCLUDES) -O$(OPTIMIZATION) -imacros ../config.h \ |
49 | GCC_CFLAGS = -I$(INCLUDES) -O$(OPTIMIZATION) -imacros ../config.h \ |
50 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32 -finput-charset=UTF-8 \ |
50 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \ |
51 | -fno-builtin -Wall -Wextra -Wno-unused-parameter -Wmissing-prototypes -Werror \ |
51 | -finput-charset=UTF-8 -fno-builtin -Wall -Wextra -Wno-unused-parameter \ |
52 | -nostdlib -nostdinc -pipe |
52 | -Wmissing-prototypes -Werror -nostdlib -nostdinc -pipe |
53 | 53 | ||
54 | ICC_CFLAGS = -I$(INCLUDES) -O$(OPTIMIZATION) -imacros ../config.h \ |
54 | ICC_CFLAGS = -I$(INCLUDES) -O$(OPTIMIZATION) -imacros ../config.h \ |
55 | -fno-builtin -Wall -Wmissing-prototypes -Werror \ |
55 | -fno-builtin -Wall -Wmissing-prototypes -Werror \ |
56 | -nostdlib -nostdinc \ |
56 | -nostdlib -nostdinc \ |
57 | -wd170 |
57 | -wd170 |
58 | 58 | ||
59 | SUNCC_CFLAGS = -I$(INCLUDES) -xO$(OPTIMIZATION) \ |
59 | SUNCC_CFLAGS = -I$(INCLUDES) -xO$(OPTIMIZATION) \ |
60 | -xnolib -xc99=all -features=extensions \ |
60 | -xnolib -xc99=all -features=extensions \ |
61 | -erroff=E_ZERO_SIZED_STRUCT_UNION |
61 | -erroff=E_ZERO_SIZED_STRUCT_UNION |
62 | 62 | ||
63 | LFLAGS = -M |
63 | LFLAGS = -M |
64 | AFLAGS = |
64 | AFLAGS = |
65 | 65 | ||
66 | -include arch/$(KARCH)/Makefile.inc |
66 | -include arch/$(KARCH)/Makefile.inc |
67 | -include genarch/Makefile.inc |
67 | -include genarch/Makefile.inc |
68 | 68 | ||
69 | ## The at-sign |
69 | ## The at-sign |
70 | # |
70 | # |
71 | # The $(ATSIGN) variable holds the ASCII character representing the at-sign |
71 | # The $(ATSIGN) variable holds the ASCII character representing the at-sign |
72 | # ('@') used in various $(AS) constructs (e.g. @progbits). On architectures that |
72 | # ('@') used in various $(AS) constructs (e.g. @progbits). On architectures that |
73 | # don't use '@' for starting a comment, $(ATSIGN) is merely '@'. However, on |
73 | # don't use '@' for starting a comment, $(ATSIGN) is merely '@'. However, on |
74 | # those that do use it for starting a comment (e.g. arm32), $(ATSIGN) must be |
74 | # those that do use it for starting a comment (e.g. arm32), $(ATSIGN) must be |
75 | # defined as the percentile-sign ('%') in the architecture-dependent |
75 | # defined as the percentile-sign ('%') in the architecture-dependent |
76 | # Makefile.inc. |
76 | # Makefile.inc. |
77 | # |
77 | # |
78 | ATSIGN ?= @ |
78 | ATSIGN ?= @ |
79 | 79 | ||
80 | ## Cross-platform assembly to start a symtab.data section |
80 | ## Cross-platform assembly to start a symtab.data section |
81 | # |
81 | # |
82 | SYMTAB_SECTION=".section symtab.data, \"a\", $(ATSIGN)progbits;" |
82 | SYMTAB_SECTION=".section symtab.data, \"a\", $(ATSIGN)progbits;" |
83 | 83 | ||
84 | ## Simple detection for the type of the host system |
84 | ## Simple detection for the type of the host system |
85 | # |
85 | # |
86 | HOST = $(shell uname) |
86 | HOST = $(shell uname) |
87 | 87 | ||
88 | ## On Solaris, some utilities have slightly different names |
88 | ## On Solaris, some utilities have slightly different names |
89 | # |
89 | # |
90 | ifeq ($(HOST),SunOS) |
90 | ifeq ($(HOST),SunOS) |
91 | BINUTILS_PREFIX = "g" |
91 | BINUTILS_PREFIX = "g" |
92 | else |
92 | else |
93 | BINUTILS_PREFIX = "" |
93 | BINUTILS_PREFIX = "" |
94 | endif |
94 | endif |
95 | 95 | ||
96 | ## Toolchain configuration |
96 | ## Toolchain configuration |
97 | # |
97 | # |
98 | 98 | ||
99 | ifeq ($(COMPILER),gcc_native) |
99 | ifeq ($(COMPILER),gcc_native) |
100 | CC = gcc |
100 | CC = gcc |
101 | GCC = gcc |
101 | GCC = gcc |
102 | AS = $(BINUTILS_PREFIX)as |
102 | AS = $(BINUTILS_PREFIX)as |
103 | LD = $(BINUTILS_PREFIX)ld |
103 | LD = $(BINUTILS_PREFIX)ld |
104 | OBJCOPY = $(BINUTILS_PREFIX)objcopy |
104 | OBJCOPY = $(BINUTILS_PREFIX)objcopy |
105 | OBJDUMP = $(BINUTILS_PREFIX)objdump |
105 | OBJDUMP = $(BINUTILS_PREFIX)objdump |
106 | LIBDIR = /usr/lib |
106 | LIBDIR = /usr/lib |
107 | CFLAGS = $(GCC_CFLAGS) |
107 | CFLAGS = $(GCC_CFLAGS) |
108 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) |
108 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) |
109 | endif |
109 | endif |
110 | 110 | ||
111 | ifeq ($(COMPILER),icc_native) |
111 | ifeq ($(COMPILER),icc_native) |
112 | CC = icc |
112 | CC = icc |
113 | GCC = gcc |
113 | GCC = gcc |
114 | AS = as |
114 | AS = as |
115 | LD = ld |
115 | LD = ld |
116 | OBJCOPY = objcopy |
116 | OBJCOPY = objcopy |
117 | OBJDUMP = objdump |
117 | OBJDUMP = objdump |
118 | LIBDIR = /usr/lib |
118 | LIBDIR = /usr/lib |
119 | CFLAGS = $(ICC_CFLAGS) |
119 | CFLAGS = $(ICC_CFLAGS) |
120 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) |
120 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) |
121 | endif |
121 | endif |
122 | 122 | ||
123 | ifeq ($(COMPILER),suncc_native) |
123 | ifeq ($(COMPILER),suncc_native) |
124 | CC = suncc |
124 | CC = suncc |
125 | GCC = gcc |
125 | GCC = gcc |
126 | AS = $(BINUTILS_PREFIX)as |
126 | AS = $(BINUTILS_PREFIX)as |
127 | LD = $(BINUTILS_PREFIX)ld |
127 | LD = $(BINUTILS_PREFIX)ld |
128 | OBJCOPY = $(BINUTILS_PREFIX)objcopy |
128 | OBJCOPY = $(BINUTILS_PREFIX)objcopy |
129 | OBJDUMP = $(BINUTILS_PREFIX)objdump |
129 | OBJDUMP = $(BINUTILS_PREFIX)objdump |
130 | LIBDIR = /usr/lib |
130 | LIBDIR = /usr/lib |
131 | CFLAGS = $(SUNCC_CFLAGS) |
131 | CFLAGS = $(SUNCC_CFLAGS) |
132 | DEFS += $(CONFIG_DEFS) |
132 | DEFS += $(CONFIG_DEFS) |
133 | DEPEND_DEFS = $(DEFS) |
133 | DEPEND_DEFS = $(DEFS) |
134 | endif |
134 | endif |
135 | 135 | ||
136 | ifeq ($(COMPILER),gcc_cross) |
136 | ifeq ($(COMPILER),gcc_cross) |
137 | CC = $(TOOLCHAIN_DIR)/bin/$(TARGET)-gcc |
137 | CC = $(TOOLCHAIN_DIR)/bin/$(TARGET)-gcc |
138 | GCC = $(CC) |
138 | GCC = $(CC) |
139 | AS = $(TOOLCHAIN_DIR)/bin/$(TARGET)-as |
139 | AS = $(TOOLCHAIN_DIR)/bin/$(TARGET)-as |
140 | LD = $(TOOLCHAIN_DIR)/bin/$(TARGET)-ld |
140 | LD = $(TOOLCHAIN_DIR)/bin/$(TARGET)-ld |
141 | OBJCOPY = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objcopy |
141 | OBJCOPY = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objcopy |
142 | OBJDUMP = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objdump |
142 | OBJDUMP = $(TOOLCHAIN_DIR)/bin/$(TARGET)-objdump |
143 | LIBDIR = $(TOOLCHAIN_DIR)/lib |
143 | LIBDIR = $(TOOLCHAIN_DIR)/lib |
144 | CFLAGS = $(GCC_CFLAGS) |
144 | CFLAGS = $(GCC_CFLAGS) |
145 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) |
145 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) |
146 | endif |
146 | endif |
147 | 147 | ||
148 | ## Generic kernel sources |
148 | ## Generic kernel sources |
149 | # |
149 | # |
150 | 150 | ||
151 | GENERIC_SOURCES = \ |
151 | GENERIC_SOURCES = \ |
152 | generic/src/adt/avl.c \ |
152 | generic/src/adt/avl.c \ |
153 | generic/src/adt/bitmap.c \ |
153 | generic/src/adt/bitmap.c \ |
154 | generic/src/adt/btree.c \ |
154 | generic/src/adt/btree.c \ |
155 | generic/src/adt/hash_table.c \ |
155 | generic/src/adt/hash_table.c \ |
156 | generic/src/adt/list.c \ |
156 | generic/src/adt/list.c \ |
157 | generic/src/console/chardev.c \ |
157 | generic/src/console/chardev.c \ |
158 | generic/src/console/console.c \ |
158 | generic/src/console/console.c \ |
159 | generic/src/cpu/cpu.c \ |
159 | generic/src/cpu/cpu.c \ |
160 | generic/src/ddi/ddi.c \ |
160 | generic/src/ddi/ddi.c \ |
161 | generic/src/ddi/irq.c \ |
161 | generic/src/ddi/irq.c \ |
162 | generic/src/ddi/device.c \ |
162 | generic/src/ddi/device.c \ |
163 | generic/src/debug/symtab.c \ |
163 | generic/src/debug/symtab.c \ |
164 | generic/src/interrupt/interrupt.c \ |
164 | generic/src/interrupt/interrupt.c \ |
165 | generic/src/main/main.c \ |
165 | generic/src/main/main.c \ |
166 | generic/src/main/kinit.c \ |
166 | generic/src/main/kinit.c \ |
167 | generic/src/main/uinit.c \ |
167 | generic/src/main/uinit.c \ |
168 | generic/src/main/version.c \ |
168 | generic/src/main/version.c \ |
169 | generic/src/main/shutdown.c \ |
169 | generic/src/main/shutdown.c \ |
170 | generic/src/proc/program.c \ |
170 | generic/src/proc/program.c \ |
171 | generic/src/proc/scheduler.c \ |
171 | generic/src/proc/scheduler.c \ |
172 | generic/src/proc/thread.c \ |
172 | generic/src/proc/thread.c \ |
173 | generic/src/proc/task.c \ |
173 | generic/src/proc/task.c \ |
174 | generic/src/proc/the.c \ |
174 | generic/src/proc/the.c \ |
175 | generic/src/proc/tasklet.c \ |
175 | generic/src/proc/tasklet.c \ |
176 | generic/src/syscall/syscall.c \ |
176 | generic/src/syscall/syscall.c \ |
177 | generic/src/syscall/copy.c \ |
177 | generic/src/syscall/copy.c \ |
178 | generic/src/mm/buddy.c \ |
178 | generic/src/mm/buddy.c \ |
179 | generic/src/mm/frame.c \ |
179 | generic/src/mm/frame.c \ |
180 | generic/src/mm/page.c \ |
180 | generic/src/mm/page.c \ |
181 | generic/src/mm/tlb.c \ |
181 | generic/src/mm/tlb.c \ |
182 | generic/src/mm/as.c \ |
182 | generic/src/mm/as.c \ |
183 | generic/src/mm/backend_anon.c \ |
183 | generic/src/mm/backend_anon.c \ |
184 | generic/src/mm/backend_elf.c \ |
184 | generic/src/mm/backend_elf.c \ |
185 | generic/src/mm/backend_phys.c \ |
185 | generic/src/mm/backend_phys.c \ |
186 | generic/src/mm/slab.c \ |
186 | generic/src/mm/slab.c \ |
187 | generic/src/lib/func.c \ |
187 | generic/src/lib/func.c \ |
188 | generic/src/lib/memstr.c \ |
188 | generic/src/lib/memstr.c \ |
189 | generic/src/lib/sort.c \ |
189 | generic/src/lib/sort.c \ |
190 | generic/src/lib/string.c \ |
190 | generic/src/lib/string.c \ |
191 | generic/src/lib/elf.c \ |
191 | generic/src/lib/elf.c \ |
192 | generic/src/lib/rd.c \ |
192 | generic/src/lib/rd.c \ |
193 | generic/src/printf/printf_core.c \ |
193 | generic/src/printf/printf_core.c \ |
194 | generic/src/printf/printf.c \ |
194 | generic/src/printf/printf.c \ |
195 | generic/src/printf/snprintf.c \ |
195 | generic/src/printf/snprintf.c \ |
196 | generic/src/printf/vprintf.c \ |
196 | generic/src/printf/vprintf.c \ |
197 | generic/src/printf/vsnprintf.c \ |
197 | generic/src/printf/vsnprintf.c \ |
198 | generic/src/time/clock.c \ |
198 | generic/src/time/clock.c \ |
199 | generic/src/time/timeout.c \ |
199 | generic/src/time/timeout.c \ |
200 | generic/src/time/delay.c \ |
200 | generic/src/time/delay.c \ |
201 | generic/src/preempt/preemption.c \ |
201 | generic/src/preempt/preemption.c \ |
202 | generic/src/synch/spinlock.c \ |
202 | generic/src/synch/spinlock.c \ |
203 | generic/src/synch/condvar.c \ |
203 | generic/src/synch/condvar.c \ |
204 | generic/src/synch/rwlock.c \ |
204 | generic/src/synch/rwlock.c \ |
205 | generic/src/synch/mutex.c \ |
205 | generic/src/synch/mutex.c \ |
206 | generic/src/synch/semaphore.c \ |
206 | generic/src/synch/semaphore.c \ |
207 | generic/src/synch/smc.c \ |
207 | generic/src/synch/smc.c \ |
208 | generic/src/synch/waitq.c \ |
208 | generic/src/synch/waitq.c \ |
209 | generic/src/synch/futex.c \ |
209 | generic/src/synch/futex.c \ |
210 | generic/src/smp/ipi.c \ |
210 | generic/src/smp/ipi.c \ |
211 | generic/src/smp/smp.c \ |
211 | generic/src/smp/smp.c \ |
212 | generic/src/ipc/ipc.c \ |
212 | generic/src/ipc/ipc.c \ |
213 | generic/src/ipc/sysipc.c \ |
213 | generic/src/ipc/sysipc.c \ |
214 | generic/src/ipc/ipcrsc.c \ |
214 | generic/src/ipc/ipcrsc.c \ |
215 | generic/src/ipc/irq.c \ |
215 | generic/src/ipc/irq.c \ |
216 | generic/src/ipc/event.c \ |
216 | generic/src/ipc/event.c \ |
217 | generic/src/security/cap.c \ |
217 | generic/src/security/cap.c \ |
218 | generic/src/sysinfo/sysinfo.c |
218 | generic/src/sysinfo/sysinfo.c |
219 | 219 | ||
220 | ## Kernel console support |
220 | ## Kernel console support |
221 | # |
221 | # |
222 | 222 | ||
223 | ifeq ($(CONFIG_KCONSOLE),y) |
223 | ifeq ($(CONFIG_KCONSOLE),y) |
224 | GENERIC_SOURCES += \ |
224 | GENERIC_SOURCES += \ |
225 | generic/src/console/kconsole.c \ |
225 | generic/src/console/kconsole.c \ |
226 | generic/src/console/cmd.c |
226 | generic/src/console/cmd.c |
227 | endif |
227 | endif |
228 | 228 | ||
229 | ## Udebug interface sources |
229 | ## Udebug interface sources |
230 | # |
230 | # |
231 | 231 | ||
232 | ifeq ($(CONFIG_UDEBUG),y) |
232 | ifeq ($(CONFIG_UDEBUG),y) |
233 | GENERIC_SOURCES += \ |
233 | GENERIC_SOURCES += \ |
234 | generic/src/ipc/kbox.c \ |
234 | generic/src/ipc/kbox.c \ |
235 | generic/src/mm/as_debug.c \ |
235 | generic/src/mm/as_debug.c \ |
236 | generic/src/udebug/udebug.c \ |
236 | generic/src/udebug/udebug.c \ |
237 | generic/src/udebug/udebug_ops.c \ |
237 | generic/src/udebug/udebug_ops.c \ |
238 | generic/src/udebug/udebug_ipc.c |
238 | generic/src/udebug/udebug_ipc.c |
239 | endif |
239 | endif |
240 | 240 | ||
241 | ## Test sources |
241 | ## Test sources |
242 | # |
242 | # |
243 | 243 | ||
244 | ifeq ($(CONFIG_TEST),y) |
244 | ifeq ($(CONFIG_TEST),y) |
245 | CFLAGS += -Itest/ |
245 | CFLAGS += -Itest/ |
246 | GENERIC_SOURCES += \ |
246 | GENERIC_SOURCES += \ |
247 | test/test.c \ |
247 | test/test.c \ |
248 | test/atomic/atomic1.c \ |
248 | test/atomic/atomic1.c \ |
249 | test/btree/btree1.c \ |
249 | test/btree/btree1.c \ |
250 | test/avltree/avltree1.c \ |
250 | test/avltree/avltree1.c \ |
251 | test/fault/fault1.c \ |
251 | test/fault/fault1.c \ |
252 | test/mm/falloc1.c \ |
252 | test/mm/falloc1.c \ |
253 | test/mm/falloc2.c \ |
253 | test/mm/falloc2.c \ |
254 | test/mm/mapping1.c \ |
254 | test/mm/mapping1.c \ |
255 | test/mm/slab1.c \ |
255 | test/mm/slab1.c \ |
256 | test/mm/slab2.c \ |
256 | test/mm/slab2.c \ |
257 | test/synch/rwlock1.c \ |
257 | test/synch/rwlock1.c \ |
258 | test/synch/rwlock2.c \ |
258 | test/synch/rwlock2.c \ |
259 | test/synch/rwlock3.c \ |
259 | test/synch/rwlock3.c \ |
260 | test/synch/rwlock4.c \ |
260 | test/synch/rwlock4.c \ |
261 | test/synch/rwlock5.c \ |
261 | test/synch/rwlock5.c \ |
262 | test/synch/semaphore1.c \ |
262 | test/synch/semaphore1.c \ |
263 | test/synch/semaphore2.c \ |
263 | test/synch/semaphore2.c \ |
264 | test/print/print1.c \ |
264 | test/print/print1.c \ |
265 | test/print/print2.c \ |
265 | test/print/print2.c \ |
266 | test/print/print3.c \ |
266 | test/print/print3.c \ |
267 | test/print/print4.c \ |
267 | test/print/print4.c \ |
268 | test/thread/thread1.c \ |
268 | test/thread/thread1.c \ |
269 | test/sysinfo/sysinfo1.c |
269 | test/sysinfo/sysinfo1.c |
270 | 270 | ||
271 | ifeq ($(KARCH),mips32) |
271 | ifeq ($(KARCH),mips32) |
272 | GENERIC_SOURCES += test/debug/mips1.c |
272 | GENERIC_SOURCES += test/debug/mips1.c |
273 | else |
273 | else |
274 | GENERIC_SOURCES += test/debug/mips1_skip.c |
274 | GENERIC_SOURCES += test/debug/mips1_skip.c |
275 | endif |
275 | endif |
276 | 276 | ||
277 | ifeq ($(KARCH),ia64) |
277 | ifeq ($(KARCH),ia64) |
278 | GENERIC_SOURCES += test/mm/purge1.c |
278 | GENERIC_SOURCES += test/mm/purge1.c |
279 | else |
279 | else |
280 | GENERIC_SOURCES += test/mm/purge1_skip.c |
280 | GENERIC_SOURCES += test/mm/purge1_skip.c |
281 | endif |
281 | endif |
282 | 282 | ||
283 | ifeq ($(CONFIG_FPU),y) |
283 | ifeq ($(CONFIG_FPU),y) |
284 | ifeq ($(KARCH),ia32) |
284 | ifeq ($(KARCH),ia32) |
285 | TEST_FPU1 = y |
285 | TEST_FPU1 = y |
286 | TEST_SSE1 = y |
286 | TEST_SSE1 = y |
287 | GENERIC_SOURCES += test/fpu/fpu1_x86.c |
287 | GENERIC_SOURCES += test/fpu/fpu1_x86.c |
288 | endif |
288 | endif |
289 | 289 | ||
290 | ifeq ($(KARCH),amd64) |
290 | ifeq ($(KARCH),amd64) |
291 | TEST_FPU1 = y |
291 | TEST_FPU1 = y |
292 | TEST_SSE1 = y |
292 | TEST_SSE1 = y |
293 | GENERIC_SOURCES += test/fpu/fpu1_x86.c |
293 | GENERIC_SOURCES += test/fpu/fpu1_x86.c |
294 | endif |
294 | endif |
295 | 295 | ||
296 | ifeq ($(KARCH),ia64) |
296 | ifeq ($(KARCH),ia64) |
297 | TEST_FPU1 = y |
297 | TEST_FPU1 = y |
298 | GENERIC_SOURCES += test/fpu/fpu1_ia64.c |
298 | GENERIC_SOURCES += test/fpu/fpu1_ia64.c |
299 | endif |
299 | endif |
300 | 300 | ||
301 | ifeq ($(KARCH),mips32) |
301 | ifeq ($(KARCH),mips32) |
302 | TEST_MIPS2 = y |
302 | TEST_MIPS2 = y |
303 | endif |
303 | endif |
304 | endif |
304 | endif |
305 | 305 | ||
306 | ifneq ($(TEST_FPU1),y) |
306 | ifneq ($(TEST_FPU1),y) |
307 | GENERIC_SOURCES += test/fpu/fpu1_skip.c |
307 | GENERIC_SOURCES += test/fpu/fpu1_skip.c |
308 | endif |
308 | endif |
309 | 309 | ||
310 | ifeq ($(TEST_SSE1),y) |
310 | ifeq ($(TEST_SSE1),y) |
311 | GENERIC_SOURCES += test/fpu/sse1.c |
311 | GENERIC_SOURCES += test/fpu/sse1.c |
312 | else |
312 | else |
313 | GENERIC_SOURCES += test/fpu/sse1_skip.c |
313 | GENERIC_SOURCES += test/fpu/sse1_skip.c |
314 | endif |
314 | endif |
315 | 315 | ||
316 | ifeq ($(TEST_MIPS2),y) |
316 | ifeq ($(TEST_MIPS2),y) |
317 | GENERIC_SOURCES += test/fpu/mips2.c |
317 | GENERIC_SOURCES += test/fpu/mips2.c |
318 | else |
318 | else |
319 | GENERIC_SOURCES += test/fpu/mips2_skip.c |
319 | GENERIC_SOURCES += test/fpu/mips2_skip.c |
320 | endif |
320 | endif |
321 | 321 | ||
322 | endif |
322 | endif |
323 | 323 | ||
324 | GENERIC_OBJECTS := $(addsuffix .o,$(basename $(GENERIC_SOURCES))) |
324 | GENERIC_OBJECTS := $(addsuffix .o,$(basename $(GENERIC_SOURCES))) |
325 | ARCH_OBJECTS := $(addsuffix .o,$(basename $(ARCH_SOURCES))) |
325 | ARCH_OBJECTS := $(addsuffix .o,$(basename $(ARCH_SOURCES))) |
326 | GENARCH_OBJECTS := $(addsuffix .o,$(basename $(GENARCH_SOURCES))) |
326 | GENARCH_OBJECTS := $(addsuffix .o,$(basename $(GENARCH_SOURCES))) |
327 | 327 | ||
328 | ifeq ($(CONFIG_SYMTAB),y) |
328 | ifeq ($(CONFIG_SYMTAB),y) |
329 | SYMTAB_OBJECTS := generic/src/debug/real_map.o |
329 | SYMTAB_OBJECTS := generic/src/debug/real_map.o |
330 | else |
330 | else |
331 | SYMTAB_OBJECTS := |
331 | SYMTAB_OBJECTS := |
332 | endif |
332 | endif |
333 | 333 | ||
334 | .PHONY: all build clean archlinks depend disasm |
334 | .PHONY: all build clean archlinks depend disasm |
335 | 335 | ||
336 | all: ../Makefile.config ../config.h ../config.defs |
336 | all: ../Makefile.config ../config.h ../config.defs |
337 | -rm Makefile.depend |
337 | -rm Makefile.depend |
338 | $(MAKE) -C . build |
338 | $(MAKE) -C . build |
339 | 339 | ||
340 | build: kernel.bin disasm |
340 | build: kernel.bin disasm |
341 | 341 | ||
342 | -include Makefile.depend |
342 | -include Makefile.depend |
343 | 343 | ||
344 | clean: |
344 | clean: |
345 | -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/$(KARCH)/_link.ld |
345 | -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/$(KARCH)/_link.ld |
346 | find generic/src/ arch/*/src/ genarch/src/ test/ -name '*.o' -follow -exec rm \{\} \; |
346 | find generic/src/ arch/*/src/ genarch/src/ test/ -name '*.o' -follow -exec rm \{\} \; |
347 | for arch in arch/* ; do \ |
347 | for arch in arch/* ; do \ |
348 | [ -e $$arch/_link.ld ] && rm $$arch/_link.ld 2>/dev/null ; \ |
348 | [ -e $$arch/_link.ld ] && rm $$arch/_link.ld 2>/dev/null ; \ |
349 | done ; exit 0 |
349 | done ; exit 0 |
350 | 350 | ||
351 | archlinks: |
351 | archlinks: |
352 | ln -sfn ../../arch/$(KARCH)/include/ generic/include/arch |
352 | ln -sfn ../../arch/$(KARCH)/include/ generic/include/arch |
353 | ln -sfn ../../genarch/include/ generic/include/genarch |
353 | ln -sfn ../../genarch/include/ generic/include/genarch |
354 | 354 | ||
355 | depend: archlinks |
355 | depend: archlinks |
356 | -makedepend -f - -- $(DEPEND_DEFS) $(CFLAGS) -- $(ARCH_SOURCES) $(GENARCH_SOURCES) $(GENERIC_SOURCES) > Makefile.depend 2> /dev/null |
356 | -makedepend -f - -- $(DEPEND_DEFS) $(CFLAGS) -- $(ARCH_SOURCES) $(GENARCH_SOURCES) $(GENERIC_SOURCES) > Makefile.depend 2> /dev/null |
357 | 357 | ||
358 | arch/$(KARCH)/_link.ld: arch/$(KARCH)/_link.ld.in |
358 | arch/$(KARCH)/_link.ld: arch/$(KARCH)/_link.ld.in |
359 | $(GCC) $(DEFS) $(GCC_CFLAGS) -D__ASM__ -D__LINKER__ -E -x c $< | grep -v "^\#" > $@ |
359 | $(GCC) $(DEFS) $(GCC_CFLAGS) -D__ASM__ -D__LINKER__ -E -x c $< | grep -v "^\#" > $@ |
360 | 360 | ||
361 | generic/src/debug/real_map.bin: depend arch/$(KARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) |
361 | generic/src/debug/real_map.bin: depend arch/$(KARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) |
362 | echo $(SYMTAB_SECTION) | $(AS) $(AFLAGS) -o generic/src/debug/empty_map.o |
362 | echo $(SYMTAB_SECTION) | $(AS) $(AFLAGS) -o generic/src/debug/empty_map.o |
363 | $(LD) -T arch/$(KARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/empty_map.o -o $@ -Map kernel.map.pre |
363 | $(LD) -T arch/$(KARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/empty_map.o -o $@ -Map kernel.map.pre |
364 | $(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump |
364 | $(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump |
365 | tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin |
365 | tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin |
366 | # Do it once again, this time to get correct even the symbols |
366 | # Do it once again, this time to get correct even the symbols |
367 | # on architectures, that have bss after symtab |
367 | # on architectures, that have bss after symtab |
368 | echo $(SYMTAB_SECTION)" .incbin \"$@\"" | $(AS) $(AFLAGS) -o generic/src/debug/sizeok_map.o |
368 | echo $(SYMTAB_SECTION)" .incbin \"$@\"" | $(AS) $(AFLAGS) -o generic/src/debug/sizeok_map.o |
369 | $(LD) -T arch/$(KARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/sizeok_map.o -o $@ -Map kernel.map.pre |
369 | $(LD) -T arch/$(KARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) generic/src/debug/sizeok_map.o -o $@ -Map kernel.map.pre |
370 | $(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump |
370 | $(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump |
371 | tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin |
371 | tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin |
372 | 372 | ||
373 | generic/src/debug/real_map.o: generic/src/debug/real_map.bin |
373 | generic/src/debug/real_map.o: generic/src/debug/real_map.bin |
374 | echo $(SYMTAB_SECTION)" .incbin \"$<\"" | $(AS) $(AFLAGS) -o $@ |
374 | echo $(SYMTAB_SECTION)" .incbin \"$<\"" | $(AS) $(AFLAGS) -o $@ |
375 | 375 | ||
376 | kernel.raw: depend arch/$(KARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(SYMTAB_OBJECTS) |
376 | kernel.raw: depend arch/$(KARCH)/_link.ld $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(SYMTAB_OBJECTS) |
377 | $(LD) -T arch/$(KARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) $(SYMTAB_OBJECTS) -o $@ -Map kernel.map |
377 | $(LD) -T arch/$(KARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) $(EXTRA_OBJECTS) $(SYMTAB_OBJECTS) -o $@ -Map kernel.map |
378 | 378 | ||
379 | kernel.bin: kernel.raw |
379 | kernel.bin: kernel.raw |
380 | $(OBJCOPY) -O $(BFD) kernel.raw kernel.bin |
380 | $(OBJCOPY) -O $(BFD) kernel.raw kernel.bin |
381 | 381 | ||
382 | disasm: kernel.raw |
382 | disasm: kernel.raw |
383 | $(OBJDUMP) -d kernel.raw > kernel.disasm |
383 | $(OBJDUMP) -d kernel.raw > kernel.disasm |
384 | 384 | ||
385 | %.o: %.S |
385 | %.o: %.S |
386 | $(GCC) $(DEFS) $(GCC_CFLAGS) -D__ASM__ -c $< -o $@ |
386 | $(GCC) $(DEFS) $(GCC_CFLAGS) -D__ASM__ -c $< -o $@ |
387 | 387 | ||
388 | %.o: %.s |
388 | %.o: %.s |
389 | $(AS) $(AFLAGS) $< -o $@ |
389 | $(AS) $(AFLAGS) $< -o $@ |
390 | 390 | ||
391 | # |
391 | # |
392 | # The FPU tests are the only objects for which we allow the compiler to generate |
392 | # The FPU tests are the only objects for which we allow the compiler to generate |
393 | # FPU instructions. |
393 | # FPU instructions. |
394 | # |
394 | # |
395 | test/fpu/%.o: test/fpu/%.c |
395 | test/fpu/%.o: test/fpu/%.c |
396 | $(CC) $(DEFS) $(CFLAGS) $(EXTRA_FLAGS) -c $< -o $@ |
396 | $(CC) $(DEFS) $(CFLAGS) $(EXTRA_FLAGS) -c $< -o $@ |
397 | 397 | ||
398 | # |
398 | # |
399 | # Ordinary objects. |
399 | # Ordinary objects. |
400 | # |
400 | # |
401 | %.o: %.c |
401 | %.o: %.c |
402 | $(CC) $(DEFS) $(CFLAGS) $(EXTRA_FLAGS) $(FPU_NO_CFLAGS) -c $< -o $@ |
402 | $(CC) $(DEFS) $(CFLAGS) $(EXTRA_FLAGS) $(FPU_NO_CFLAGS) -c $< -o $@ |
403 | 403 |