blob: c381ea9548924149835ba223f758729dea3ebc03 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# Makefile for the linux kernel.
3#
4
5extra-y := head.o init_task.o vmlinux.lds
6
7obj-y := acpi.o entry.o efi.o efi_stub.o gate-data.o fsys.o ia64_ksyms.o irq.o irq_ia64.o \
8 irq_lsapic.o ivt.o machvec.o pal.o patch.o process.o perfmon.o ptrace.o sal.o \
Matthew Wilcox64ac24e2008-03-07 21:55:58 -05009 salinfo.o setup.o signal.o sys_ia64.o time.o traps.o unaligned.o \
Bjorn Helgaas4f705ae2006-04-03 17:09:22 -070010 unwind.o mca.o mca_asm.o topology.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070011
12obj-$(CONFIG_IA64_BRL_EMU) += brl_emu.o
13obj-$(CONFIG_IA64_GENERIC) += acpi-ext.o
14obj-$(CONFIG_IA64_HP_ZX1) += acpi-ext.o
15obj-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += acpi-ext.o
Venkatesh Pallipadic82e6ab2005-12-01 18:16:00 -050016
17ifneq ($(CONFIG_ACPI_PROCESSOR),)
18obj-y += acpi-processor.o
19endif
20
Linus Torvalds1da177e2005-04-16 15:20:36 -070021obj-$(CONFIG_IA64_PALINFO) += palinfo.o
22obj-$(CONFIG_IOSAPIC) += iosapic.o
23obj-$(CONFIG_MODULES) += module.o
John Hawkes9c1cfda2005-09-06 15:18:14 -070024obj-$(CONFIG_SMP) += smp.o smpboot.o
Tony Luck8d7e3512005-07-06 18:18:10 -070025obj-$(CONFIG_NUMA) += numa.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070026obj-$(CONFIG_PERFMON) += perfmon_default_smpl.o
27obj-$(CONFIG_IA64_CYCLONE) += cyclone.o
Venkatesh Pallipadi4db86992005-07-29 16:15:00 -070028obj-$(CONFIG_CPU_FREQ) += cpufreq/
Linus Torvalds1da177e2005-04-16 15:20:36 -070029obj-$(CONFIG_IA64_MCA_RECOVERY) += mca_recovery.o
Anil S Keshavamurthyb2761dc2005-06-23 00:09:28 -070030obj-$(CONFIG_KPROBES) += kprobes.o jprobes.o
Zou Nan haia7956112006-12-07 09:51:35 -080031obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o crash.o
Horms45a98fc2006-12-12 17:49:03 +090032obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
Jes Sorensenf14f75b2005-06-21 17:15:02 -070033obj-$(CONFIG_IA64_UNCACHED_ALLOCATOR) += uncached.o
Al Virob9155432006-07-01 03:56:16 -040034obj-$(CONFIG_AUDIT) += audit.o
Eric W. Biederman03571e12006-10-04 02:17:00 -070035obj-$(CONFIG_PCI_MSI) += msi_ia64.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070036mca_recovery-y += mca_drv.o mca_drv_asm.o
Fenghua Yu539d5172006-12-08 16:16:24 -080037obj-$(CONFIG_IA64_MC_ERR_INJECT)+= err_inject.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070038
Isaku Yamahata4df8d222008-05-27 15:08:01 -070039obj-$(CONFIG_PARAVIRT) += paravirt.o paravirtentry.o
Isaku Yamahata90aeb162008-05-19 22:13:32 +090040
David Mosberger-Tang2ab561a2006-06-21 11:19:22 -070041obj-$(CONFIG_IA64_ESI) += esi.o
42ifneq ($(CONFIG_IA64_ESI),)
43obj-y += esi_stub.o # must be in kernel proper
44endif
Fenghua Yu62fdd762008-10-17 12:14:13 -070045obj-$(CONFIG_DMAR) += pci-dma.o
46ifeq ($(CONFIG_DMAR), y)
47obj-$(CONFIG_SWIOTLB) += pci-swiotlb.o
48endif
David Mosberger-Tang2ab561a2006-06-21 11:19:22 -070049
Linus Torvalds1da177e2005-04-16 15:20:36 -070050# The gate DSO image is built using a special linker script.
51targets += gate.so gate-syms.o
52
53extra-y += gate.so gate-syms.o gate.lds gate.o
54
55# fp_emulate() expects f2-f5,f16-f31 to contain the user-level state.
56CFLAGS_traps.o += -mfixed-range=f2-f5,f16-f31
57
58CPPFLAGS_gate.lds := -P -C -U$(ARCH)
59
60quiet_cmd_gate = GATE $@
61 cmd_gate = $(CC) -nostdlib $(GATECFLAGS_$(@F)) -Wl,-T,$(filter-out FORCE,$^) -o $@
62
Roland McGrath0b0bf7a2006-07-30 03:04:06 -070063GATECFLAGS_gate.so = -shared -s -Wl,-soname=linux-gate.so.1 \
64 $(call ld-option, -Wl$(comma)--hash-style=sysv)
Linus Torvalds1da177e2005-04-16 15:20:36 -070065$(obj)/gate.so: $(obj)/gate.lds $(obj)/gate.o FORCE
66 $(call if_changed,gate)
67
68$(obj)/built-in.o: $(obj)/gate-syms.o
69$(obj)/built-in.o: ld_flags += -R $(obj)/gate-syms.o
70
71GATECFLAGS_gate-syms.o = -r
72$(obj)/gate-syms.o: $(obj)/gate.lds $(obj)/gate.o FORCE
73 $(call if_changed,gate)
74
75# gate-data.o contains the gate DSO image as data in section .data.gate.
76# We must build gate.so before we can assemble it.
77# Note: kbuild does not track this dependency due to usage of .incbin
78$(obj)/gate-data.o: $(obj)/gate.so
Isaku Yamahata1e39d802008-05-19 22:13:35 +090079
Isaku Yamahata213060a2008-05-19 22:13:40 +090080# Calculate NR_IRQ = max(IA64_NATIVE_NR_IRQS, XEN_NR_IRQS, ...) based on config
81define sed-y
82 "/^->/{s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; s:->::; p;}"
83endef
84quiet_cmd_nr_irqs = GEN $@
85define cmd_nr_irqs
86 (set -e; \
87 echo "#ifndef __ASM_NR_IRQS_H__"; \
88 echo "#define __ASM_NR_IRQS_H__"; \
89 echo "/*"; \
90 echo " * DO NOT MODIFY."; \
91 echo " *"; \
92 echo " * This file was generated by Kbuild"; \
93 echo " *"; \
94 echo " */"; \
95 echo ""; \
96 sed -ne $(sed-y) $<; \
97 echo ""; \
98 echo "#endif" ) > $@
99endef
100
101# We use internal kbuild rules to avoid the "is up to date" message from make
102arch/$(SRCARCH)/kernel/nr-irqs.s: $(srctree)/arch/$(SRCARCH)/kernel/nr-irqs.c \
103 $(wildcard $(srctree)/include/asm-ia64/*/irq.h)
104 $(Q)mkdir -p $(dir $@)
105 $(call if_changed_dep,cc_s_c)
106
107include/asm-ia64/nr-irqs.h: arch/$(SRCARCH)/kernel/nr-irqs.s
108 $(Q)mkdir -p $(dir $@)
109 $(call cmd,nr_irqs)
110
111clean-files += $(objtree)/include/asm-ia64/nr-irqs.h
112
Isaku Yamahata1e39d802008-05-19 22:13:35 +0900113#
114# native ivt.S and entry.S
115#
116ASM_PARAVIRT_OBJS = ivt.o entry.o
117define paravirtualized_native
118AFLAGS_$(1) += -D__IA64_ASM_PARAVIRTUALIZED_NATIVE
Isaku Yamahataf8d1f992008-10-17 11:18:13 +0900119AFLAGS_pvchk-sed-$(1) += -D__IA64_ASM_PARAVIRTUALIZED_PVCHECK
120extra-y += pvchk-$(1)
Isaku Yamahata1e39d802008-05-19 22:13:35 +0900121endef
122$(foreach obj,$(ASM_PARAVIRT_OBJS),$(eval $(call paravirtualized_native,$(obj))))
Isaku Yamahataf8d1f992008-10-17 11:18:13 +0900123
124#
125# Checker for paravirtualizations of privileged operations.
126#
127quiet_cmd_pv_check_sed = PVCHK $@
128define cmd_pv_check_sed
129 sed -f $(srctree)/arch/$(SRCARCH)/scripts/pvcheck.sed $< > $@
130endef
131
132$(obj)/pvchk-sed-%.s: $(src)/%.S $(srctree)/arch/$(SRCARCH)/scripts/pvcheck.sed FORCE
133 $(call if_changed_dep,as_s_S)
134$(obj)/pvchk-%.s: $(obj)/pvchk-sed-%.s FORCE
135 $(call if_changed,pv_check_sed)
136$(obj)/pvchk-%.o: $(obj)/pvchk-%.s FORCE
137 $(call if_changed,as_o_S)
138.PRECIOUS: $(obj)/pvchk-sed-%.s $(obj)/pvchk-%.s $(obj)/pvchk-%.o