3 include $(srcdir)/Modules.generic
5 SUBSYSTEMS = JABI ABI DRIVERS KERNEL CRT0 BOOT LIBK \
6 CHECKSUM CXXLIB MINILIBC LIBKERN TCBOFFSET SYMBOLS VERSION GBLCFG
8 ifeq ("$(CONFIG_GSTABS)","y")
12 PREPROCESS_PARTS += arch $(CONFIG_ABI) 64bit iofp \
13 $(CONFIG_XARCH) apic abs-timeout-hack \
19 OBJ_SPACE = $(OBJ_SPACE-$(CONFIG_DISABLE_VIRT_OBJ_SPACE))
21 PREPROCESS_PARTS += obj_space_$(OBJ_SPACE)
23 PREPROCESS_PARTS-$(CONFIG_MP) += mp
24 PREPROCESS_PARTS-$(CONFIG_LIST_ALLOC_SANITY) += list_alloc_debug
25 PREPROCESS_PARTS-$(CONFIG_JDB) += debug log
26 PREPROCESS_PARTS-$(CONFIG_SCHED_PIT) += pit_timer
27 PREPROCESS_PARTS-$(CONFIG_SCHED_RTC) += rtc_timer
28 PREPROCESS_PARTS-$(CONFIG_SCHED_APIC) += apic_timer
29 PREPROCESS_PARTS-$(CONFIG_SCHED_HPET) += hpet_timer
30 PREPROCESS_PARTS-$(CONFIG_SERIAL) += serial 16550
31 PREPROCESS_PARTS-$(CONFIG_WATCHDOG) += watchdog
32 PREPROCESS_PARTS-$(CONFIG_PERF_CNT) += perf_cnt
33 PREPROCESS_PARTS-$(CONFIG_CPU_VIRT) += svm vmx
34 PREPROCESS_PARTS-$(CONFIG_SCHED_FIXED_PRIO) += sched_fixed_prio
35 PREPROCESS_PARTS-$(CONFIG_SCHED_WFQ) += sched_wfq
36 PREPROCESS_PARTS-$(CONFIG_SCHED_FP_WFQ) += sched_fp_wfq
38 PREPROCESS_PARTS += $(PREPROCESS_PARTS-y)
43 PRIVATE_INCDIR += types/$(CONFIG_XARCH) types
49 VPATH += abi/$(CONFIG_XARCH) abi
50 INTERFACES_ABI := l4_fpage l4_msg_item l4_buf_desc kip l4_types \
53 kip_IMPL := kip kip-debug kip-amd64 kip-amd64-debug
54 l4_types_IMPL := l4_types l4_types-debug
55 virt_IMPL := virt-ia32-amd64
61 VPATH += jabi/$(CONFIG_XARCH) jabi
62 INTERFACES_JABI := jdb_ktrace
67 DRIVERS := libdrivers.a libgluedriverslibc.a
68 VPATH += drivers/$(CONFIG_XARCH) drivers
69 PRIVATE_INCDIR += drivers/$(CONFIG_XARCH) drivers
70 INTERFACES_DRIVERS := mux_console console keyb io pci vga_console reset \
71 processor delayloop mem
72 ifeq ("$(CONFIG_SERIAL)","y")
73 INTERFACES_DRIVERS += filter_console uart
75 reset_IMPL := reset-amd64
76 uart_IMPL := uart uart-16550
77 CXXSRC_DRIVERS := glue_libc.cc
78 NOOPT += $(patsubst %.o, %, $(OBJ_DRIVERS))
80 keyb_IMPL := keyb keyb-pc
81 io_IMPL := io io-amd64
82 mem_IMPL := mem mem-amd64
83 processor_IMPL := processor processor-amd64
88 KERNEL := fiasco.image
89 VPATH += kern/$(CONFIG_XARCH) kern/ia32/64 kern/ia32 kern
90 PRIVATE_INCDIR += kern/$(CONFIG_XARCH) kern/ia32/64 kern/ia32 kern
92 INTERFACES_KERNEL += __main acpi io_apic irq_chip_ia32 irq_chip_pic \
93 irq_msi io_space apic pit checksum \
94 boot_console x86desc gdt idt tss timer_irq \
97 INTERFACES_KERNEL-$(CONFIG_CPU_VIRT) += svm vmx vm vm_svm vm_vmx
100 apic_IMPL := apic-ia32 apic-ia32-mp
101 boot_console_IMPL := boot_console-ia32-amd64
102 boot_info_IMPL := boot_info boot_info-ia32
103 clock_IMPL := clock clock-ia32
104 config_IMPL := config config-ia32-64 config-ia32
105 context_IMPL := context context-ia32 context-ia32-64 context-vcpu
106 continuation_IMPL := continuation-ia32-64
107 cpu_IMPL := cpu cpu-ia32 cpu-64
108 dirq_IMPL := dirq-ia32-ux
109 entry_frame_IMPL := entry_frame entry_frame-amd64 \
110 entry_frame-abs-timeout-hack
111 fpu_IMPL := fpu fpu-ia32-ux fpu-ia32
112 ipi_IMPL := ipi ipi-ia32
113 kdb_ke_IMPL := kdb_ke kdb_ke-ia32
114 kernel_thread_IMPL := kernel_thread kernel_thread-std kernel_thread-ia32
115 kernel_uart_IMPL := kernel_uart kernel_uart-16550
116 kip_init_IMPL := kip_init-ia32
117 kmem_IMPL := kmem-ia32 kmem-ia32-64
118 kmem_alloc_IMPL := kmem_alloc kmem_alloc-ia32
119 main_IMPL := main-ia32-64 main-ia32
120 mapping_IMPL := mapping-ia32-64 mapping
121 map_util_IMPL := map_util map_util-mem map_util-io map_util-objs
122 mem_layout_IMPL := mem_layout mem_layout-ia32 mem_layout-ia32-64
123 mem_space_IMPL := mem_space mem_space-user mem_space-ia32
124 mem_unit_IMPL := mem_unit-amd64
125 obj_space_IMPL := obj_space obj_space-$(OBJ_SPACE)
126 paging_IMPL := paging-ia32-64 paging-ia32 paging
127 perf_cnt_IMPL := perf_cnt perf_cnt-ia32
128 pic_IMPL := pic pic-i8259
129 pit_IMPL := pit-i8254
130 pmem_alloc_IMPL := pmem_alloc pmem_alloc-ia32-ux
132 sched_context_IMPL := sched_context-wfq sched_context-fixed_prio \
133 sched_context-fp_wfq sched_context
134 sigma0_task_IMPL := sigma0_task sigma0_task-io
135 space_IMPL := space space-ia32 space-io
136 spin_lock_IMPL := spin_lock spin_lock-ia32
137 startup_IMPL := startup startup-ia32
138 task_IMPL := task task-ia32-amd64
139 tb_entry_IMPL := tb_entry tb_entry-ia32-64
140 timer_IMPL := timer timer-ia32-amd64-ux
141 thread_IMPL := thread thread-ia32 thread-ia32-64 \
142 thread-ipc thread-pagefault thread-log \
143 thread-debug thread-dbf thread-vcpu thread-io
144 trap_state_IMPL := trap_state-amd64
145 tss_IMPL := tss-amd64
146 utcb_init_IMPL := utcb_init utcb_init-ia32
147 vmem_alloc_IMPL := vmem_alloc vmem_alloc-ia32
148 vm_factory_IMPL := vm_factory vm_factory-ia32
149 watchdog_IMPL := watchdog watchdog-ia32
151 INTERFACES_KERNEL-$(CONFIG_SERIAL) += uart_console
153 cpu_lock_IMPL := cpu_lock cpu_lock-generic
155 ifeq ("$(CONFIG_SCHED_PIT)","y")
156 timer_IMPL += timer-pit
157 timer_tick_IMPL += timer_tick-single-vector timer_tick-ia32
159 ifeq ("$(CONFIG_SCHED_RTC)","y")
160 timer_IMPL += timer-rtc
161 timer_tick_IMPL += timer_tick-single-vector timer_tick-ia32
162 INTERFACES_KERNEL += rtc
164 ifeq ("$(CONFIG_SCHED_APIC)","y")
165 timer_IMPL += timer-apic
166 timer_tick_IMPL += timer_tick-apic
168 ifeq ("$(CONFIG_SCHED_HPET)","y")
169 timer_IMPL += timer-hpet
170 INTERFACES_KERNEL += hpet
173 ifeq ("$(CONFIG_JDB)","y")
174 JDB := jdb_compound.o
176 VPATH += jdb/ia32/64 jdb/ia32 jdb
177 INTERFACES_KERNEL += jdb_tbuf jdb_trace tb_entry jdb_tbuf_init
178 INTERFACES_JDB += jdb jdb_util jdb_prompt_ext jdb_symbol jdb_lines \
180 jdb_module jdb_core jdb_io_ports \
181 jdb_kern_info jdb_prompt_module jdb_tbuf_output \
182 jdb_input jdb_dump jdb_ptab jdb_misc jdb_mapdb \
183 jdb_tcb jdb_attach_irq \
184 jdb_trace_set jdb_counters jdb_table kern_cnt \
186 jdb_tbuf_show jdb_console_buffer \
187 jdb_list jdb_screen push_console jdb_timeout \
188 jdb_handler_queue jdb_halt_thread \
189 jdb_kern_info_kmem_alloc \
190 jdb_kern_info_kip jdb_kern_info_config \
191 loadcnt jdb_utcb jdb_thread_list \
192 jdb_entry_frame jdb_kobject jdb_space jdb_io_apic \
193 jdb_trap_state jdb_ipi jdb_kobject_names \
194 jdb_rcupdate jdb_bt jdb_ipc_gate jdb_obj_space \
195 jdb_log jdb_factory jdb_iomap \
196 jdb_thread jdb_scheduler jdb_sender_list \
199 CXXSRC_JDB := tb_entry_output.cc
201 apic_IMPL += apic-debug
202 jdb_IMPL := jdb jdb-ia32-amd64 jdb-ansi jdb-ia32-ux jdb-thread \
203 jdb-int3-ia32-amd64 jdb-int3-ia32-ux
204 jdb_bp_IMPL := jdb_bp-ia32-ux jdb_bp-ia32-amd64 jdb_bp-amd64
205 jdb_bt_IMPL := jdb_bt-ia32-ux
206 jdb_entry_frame_IMPL := jdb_entry_frame-ia32
207 jdb_kern_info_IMPL := jdb_kern_info jdb_kern_info-ia32-amd64 \
208 jdb_kern_info-ia32-ux jdb_kern_info-apic \
209 jdb_kern_info-pci jdb_kern_info-bench \
210 jdb_kern_info-bench-ia32-64 \
211 jdb_kern_info-dr jdb_kern_info-mtrr
212 jdb_misc_IMPL := jdb_misc-ia32-amd64
213 jdb_ptab_IMPL := jdb_ptab jdb_ptab-amd64
214 jdb_screen_IMPL := jdb_screen jdb_screen-ia32
215 jdb_tcb_IMPL := jdb_tcb jdb_tcb-amd64
216 jdb_trace_set_IMPL := jdb_trace_set jdb_trace_set-ia32-ux
218 INTERFACES_JDB-$(CONFIG_JDB_MISC) += jdb_tetris
220 INTERFACES_JDB += $(INTERFACES_JDB-y)
224 CXXSRC_KERNEL := kernel_panic.cc libc_backend_lock.cc
225 ASSRC_KERNEL := entry.S entry-native.S shortcut.S
227 ASSRC_KERNEL-$(CONFIG_KIP_SYSCALLS_ABS) += sys_call_page-asm.S
228 ASSRC_KERNEL-$(CONFIG_MP) += tramp-mp.S entry-mp.S
229 ASSRC_KERNEL-$(CONFIG_CPU_VIRT) += vm_svm_asm.S vm_vmx_asm.S
230 ASSRC_KERNEL += $(ASSRC_KERNEL-y)
232 NOOPT += $(filter jdb%,\
233 $(foreach in,$(INTERFACES_KERNEL), \
234 $(if $($(in)_IMPL),$($(in)_IMPL),$(in))))
235 NOOPT += tb_entry_output $(tb_entry_IMPL) $(perf_cnt_IMPL) \
236 kern_cnt loadcnt $(apic_IMPL) $(watchdog_IMPL) kdb \
237 $(kernel_uart_IMPL) push_console thread-dbf \
240 ### When testing with test threads, uncomment the following:
243 # PRIVATE_INCDIR += kern-test
245 # INTERFACES_KERNEL += generic_test_thread test_thread node cpu \
246 # back_trace cpu_guard types
248 # node_IMPL := node node-up
249 # cpu_IMPL := cpu cpu-perf cpu-perfp4
250 # config_IMPL := config config-test
252 # kernel_thread_IMPL := $(filter-out kernel_thread-std,$(kernel_thread_IMPL)) \
255 # Replace this definition with your own test thread.
256 # test_thread_IMPL := test_thread-test26
258 ### End of test-thread section
270 VPATH += boot/$(CONFIG_XARCH) boot
271 PRIVATE_INCDIR += boot boot/amd64
272 CXXSRC_BOOT := boot_libc_glue.cc bootstrap.cc boot_cpu.cc \
273 direct_cons_putchar.cc
274 ASSRC_BOOT := boot.S boot_idt.S
275 NOOPT += $(patsubst %.o, %, $(OBJ_BOOT))
278 # TCBOFFSET subsystem
280 TCBOFFSET := tcboffset.h
281 CXXSRC_TCBOFFSET := tcboffset.cc dump_tcboffsets.cc
292 PROG_LINES := genlines
298 CXXSRC_CHECKSUM := genchecksum.cc
309 OBJ_KERNEL += gblcfg.o
317 INTERFACES_CXXLIB := paranoia s_cruft
323 VPATH += lib/libk/$(CONFIG_XARCH) lib/libk
324 PRIVATE_INCDIR += lib/libk/$(CONFIG_XARCH) lib/libk
325 INTERFACES_LIBK := atomic lock_guard auto_ptr std_macros
326 CXXSRC_LIBK += construction.cc
327 atomic_IMPL := atomic atomic-amd64
334 PRIVATE_INCDIR += lib/kern/include
336 NOOPT += $(patsubst %.o, %, $(OBJ_LIBKERN))
340 # LIBGZIP subsystem (only for Jdb)
342 ifneq ($(CONFIG_JDB_GZIP),)
345 PRIVATE_INCDIR += lib/gzip
346 CSRC_LIBGZIP := adler32.c crc32.c gzip.c trees.c deflate.c zutil.c
347 NOOPT += $(patsubst %.o, %, $(OBJ_LIBGZIP))
351 # LIBDISASM subsystem (only for Jdb)
353 ifeq ("$(CONFIG_JDB_DISASM)","y")
354 # $(srcdir)/lib/disasm may be removed
355 ifeq ($(wildcard $(srcdir)/lib/disasm),)
356 $(error $(srcdir)/lib/disasm is missing, disable CONFIG_JDB_DISASM)
359 SUBSYSTEMS += LIBDISASM
360 KERNEL_EXTRA_LIBS += $(LIBDISASM)
361 PREPROCESS_PARTS += jdb_disasm
363 LIBDISASM := libdisasm.a
364 VPATH += lib/disasm lib/disasm/elf lib/disasm/include \
365 lib/disasm/include/opcode lib/disasm/opcodes \
366 lib/disasm/libiberty lib/disasm/bfd
367 PRIVATE_INCDIR += lib/disasm lib/disasm/elf lib/disasm/include \
368 lib/disasm/include/opcode lib/disasm/opcodes \
369 lib/disasm/libiberty lib/disasm/bfd
370 PRIVATE_INCDIR += lib/disasm
371 CXXSRC_LIBDISASM := disasm.cc
372 CSRC_LIBDISASM := dis-init.c i386-dis.c dis-buf.c
373 NOOPT += $(patsubst %.o, %, $(OBJ_LIBDISASM))
377 # LIBPERFCTR subsystem (only for Jdb)
379 LIBPERFCTR := libperfctr.a
381 PRIVATE_INCDIR += lib/perfctr
382 CSRC_LIBPERFCTR := event_set_p5.c event_set_p6.c event_set_amd.c \
383 event_set_p4.c event_set_x86.c perfctr.c \
385 NOOPT += $(patsubst %.o, %, $(OBJ_LIBPERFCTR))
388 # LIBREGEX subsystem (only for Jdb)
390 LIBREGEX := libregex.a
392 PRIVATE_INCDIR += lib/regex
393 CSRC_LIBREGEX := alloc.c rx.c
394 NOOPT += $(patsubst %.o, %, $(OBJ_LIBREGEX))
400 VPATH += lib/minilibc/$(CONFIG_XARCH) lib/minilibc
401 PRIVATE_INCDIR += lib/minilibc/$(CONFIG_XARCH)/include lib/minilibc/include
402 CSRC_MINILIBC := atexit.c memccpy.c memcmp.c memmove.c memset.c memcpy.c \
403 memchr.c strchr.c strcmp.c strcpy.c strlen.c strncmp.c \
404 strncpy.c strstr.c __assert_fail.c printf.c __v_printf.c \
405 vprintf.c strtol.c strtoul.c lltostr.c __ltostr.c \
406 putchar.c puts.c getchar.c gets.c sprintf.c \
407 snprintf.c vsnprintf.c vsprintf.c longjmp.c isalnum.c \
408 isalpha.c isascii.c isblank.c iscntrl.c isdigit.c \
409 isgraph.c islower.c isprint.c ispunct.c isspace.c \
410 isupper.c isxdigit.c tolower.c strcspn.c strspn.c panic.c
411 ASSRC_MINILIBC := setjmp.S
413 # do not profile all of MINILIBC, because it is used in the BOOT subsystem
414 NOOPT += $(patsubst %.o, %, $(OBJ_MINILIBC))
416 ifeq ("$(CONFIG_JDB)","y")
418 ifneq ($(CONFIG_JDB_GZIP),)
419 ifneq ($(wildcard $(srcdir)/lib/gzip),)
420 SUBSYSTEMS += LIBGZIP
421 KERNEL_EXTRA_LIBS += $(LIBGZIP)
422 INTERFACES_KERNEL += jdb_gzip
426 ifneq ($(wildcard $(srcdir)/lib/perfctr),)
427 SUBSYSTEMS += LIBPERFCTR
428 KERNEL_EXTRA_LIBS += $(LIBPERFCTR)
429 KERNEL_UNRES_SYMS += -u perfctr_set_cputype
432 ifneq ($(wildcard $(srcdir)/lib/regex),)
433 SUBSYSTEMS += LIBREGEX
434 KERNEL_EXTRA_LIBS += $(LIBREGEX)
435 PREPROCESS_PARTS += jdb_regex
440 MODULES_FILES = $(MODULES_FILE) $(MODULES_FILE_BSP)
442 INTERFACES_KERNEL += $(INTERFACES_KERNEL-y)