2 # Makefile for the linux kernel.
5 extra-y := head.o init_task.o vmlinux.lds
7 obj-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 paravirt_patchlist.o patch.o process.o perfmon.o ptrace.o sal.o \
9 salinfo.o setup.o signal.o sys_ia64.o time.o traps.o unaligned.o \
10 unwind.o mca.o mca_asm.o topology.o dma-mapping.o
12 obj-$(CONFIG_IA64_BRL_EMU) += brl_emu.o
13 obj-$(CONFIG_IA64_GENERIC) += acpi-ext.o
14 obj-$(CONFIG_IA64_HP_ZX1) += acpi-ext.o
15 obj-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += acpi-ext.o
17 ifneq ($(CONFIG_ACPI_PROCESSOR),)
18 obj-y += acpi-processor.o
21 obj-$(CONFIG_IA64_PALINFO) += palinfo.o
22 obj-$(CONFIG_IOSAPIC) += iosapic.o
23 obj-$(CONFIG_MODULES) += module.o
24 obj-$(CONFIG_SMP) += smp.o smpboot.o
25 obj-$(CONFIG_NUMA) += numa.o
26 obj-$(CONFIG_PERFMON) += perfmon_default_smpl.o
27 obj-$(CONFIG_IA64_CYCLONE) += cyclone.o
28 obj-$(CONFIG_CPU_FREQ) += cpufreq/
29 obj-$(CONFIG_IA64_MCA_RECOVERY) += mca_recovery.o
30 obj-$(CONFIG_KPROBES) += kprobes.o jprobes.o
31 obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o crash.o
32 obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
33 obj-$(CONFIG_IA64_UNCACHED_ALLOCATOR) += uncached.o
34 obj-$(CONFIG_AUDIT) += audit.o
35 obj-$(CONFIG_PCI_MSI) += msi_ia64.o
36 mca_recovery-y += mca_drv.o mca_drv_asm.o
37 obj-$(CONFIG_IA64_MC_ERR_INJECT)+= err_inject.o
39 obj-$(CONFIG_PARAVIRT) += paravirt.o paravirtentry.o \
42 obj-$(CONFIG_IA64_ESI) += esi.o
43 ifneq ($(CONFIG_IA64_ESI),)
44 obj-y += esi_stub.o # must be in kernel proper
46 obj-$(CONFIG_DMAR) += pci-dma.o
47 obj-$(CONFIG_SWIOTLB) += pci-swiotlb.o
49 # fp_emulate() expects f2-f5,f16-f31 to contain the user-level state.
50 CFLAGS_traps.o += -mfixed-range=f2-f5,f16-f31
52 # The gate DSO image is built using a special linker script.
53 include $(srctree)/arch/ia64/kernel/Makefile.gate
54 # tell compiled for native
55 CPPFLAGS_gate.lds += -D__IA64_GATE_PARAVIRTUALIZED_NATIVE
57 # Calculate NR_IRQ = max(IA64_NATIVE_NR_IRQS, XEN_NR_IRQS, ...) based on config
59 "/^->/{s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; s:->::; p;}"
61 quiet_cmd_nr_irqs = GEN $@
64 echo "#ifndef __ASM_NR_IRQS_H__"; \
65 echo "#define __ASM_NR_IRQS_H__"; \
67 echo " * DO NOT MODIFY."; \
69 echo " * This file was generated by Kbuild"; \
73 sed -ne $(sed-y) $<; \
78 # We use internal kbuild rules to avoid the "is up to date" message from make
79 arch/$(SRCARCH)/kernel/nr-irqs.s: $(srctree)/arch/$(SRCARCH)/kernel/nr-irqs.c \
80 $(wildcard $(srctree)/include/asm-ia64/*/irq.h)
81 $(Q)mkdir -p $(dir $@)
82 $(call if_changed_dep,cc_s_c)
84 include/asm-ia64/nr-irqs.h: arch/$(SRCARCH)/kernel/nr-irqs.s
85 $(Q)mkdir -p $(dir $@)
88 clean-files += $(objtree)/include/asm-ia64/nr-irqs.h
91 # native ivt.S, entry.S and fsys.S
93 ASM_PARAVIRT_OBJS = ivt.o entry.o fsys.o
94 define paravirtualized_native
95 AFLAGS_$(1) += -D__IA64_ASM_PARAVIRTUALIZED_NATIVE
96 AFLAGS_pvchk-sed-$(1) += -D__IA64_ASM_PARAVIRTUALIZED_PVCHECK
99 $(foreach obj,$(ASM_PARAVIRT_OBJS),$(eval $(call paravirtualized_native,$(obj))))
102 # Checker for paravirtualizations of privileged operations.
104 quiet_cmd_pv_check_sed = PVCHK $@
105 define cmd_pv_check_sed
106 sed -f $(srctree)/arch/$(SRCARCH)/scripts/pvcheck.sed $< > $@
109 $(obj)/pvchk-sed-%.s: $(src)/%.S $(srctree)/arch/$(SRCARCH)/scripts/pvcheck.sed FORCE
110 $(call if_changed_dep,as_s_S)
111 $(obj)/pvchk-%.s: $(obj)/pvchk-sed-%.s FORCE
112 $(call if_changed,pv_check_sed)
113 $(obj)/pvchk-%.o: $(obj)/pvchk-%.s FORCE
114 $(call if_changed,as_o_S)
115 .PRECIOUS: $(obj)/pvchk-sed-%.s $(obj)/pvchk-%.s $(obj)/pvchk-%.o