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