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