1# 2# Makefile for the Linux/MIPS kernel. 3# 4 5extra-y := head.o vmlinux.lds 6 7obj-y += cpu-probe.o branch.o elf.o entry.o genex.o idle.o irq.o \ 8 process.o prom.o ptrace.o reset.o setup.o signal.o \ 9 syscall.o time.o topology.o traps.o unaligned.o watch.o \ 10 vdso.o 11 12ifdef CONFIG_FUNCTION_TRACER 13CFLAGS_REMOVE_ftrace.o = -pg 14CFLAGS_REMOVE_early_printk.o = -pg 15CFLAGS_REMOVE_perf_event.o = -pg 16CFLAGS_REMOVE_perf_event_mipsxx.o = -pg 17endif 18 19obj-$(CONFIG_CEVT_BCM1480) += cevt-bcm1480.o 20obj-$(CONFIG_CEVT_R4K) += cevt-r4k.o 21obj-$(CONFIG_MIPS_MT_SMTC) += cevt-smtc.o 22obj-$(CONFIG_CEVT_DS1287) += cevt-ds1287.o 23obj-$(CONFIG_CEVT_GIC) += cevt-gic.o 24obj-$(CONFIG_CEVT_GT641XX) += cevt-gt641xx.o 25obj-$(CONFIG_CEVT_SB1250) += cevt-sb1250.o 26obj-$(CONFIG_CEVT_TXX9) += cevt-txx9.o 27obj-$(CONFIG_CSRC_BCM1480) += csrc-bcm1480.o 28obj-$(CONFIG_CSRC_GIC) += csrc-gic.o 29obj-$(CONFIG_CSRC_IOASIC) += csrc-ioasic.o 30obj-$(CONFIG_CSRC_POWERTV) += csrc-powertv.o 31obj-$(CONFIG_CSRC_R4K) += csrc-r4k.o 32obj-$(CONFIG_CSRC_SB1250) += csrc-sb1250.o 33obj-$(CONFIG_SYNC_R4K) += sync-r4k.o 34 35obj-$(CONFIG_STACKTRACE) += stacktrace.o 36obj-$(CONFIG_MODULES) += mips_ksyms.o module.o 37obj-$(CONFIG_MODULES_USE_ELF_RELA) += module-rela.o 38 39obj-$(CONFIG_FTRACE_SYSCALLS) += ftrace.o 40obj-$(CONFIG_FUNCTION_TRACER) += mcount.o ftrace.o 41 42obj-$(CONFIG_CPU_R4K_FPU) += r4k_fpu.o r4k_switch.o 43obj-$(CONFIG_CPU_R3000) += r2300_fpu.o r2300_switch.o 44obj-$(CONFIG_CPU_R6000) += r6000_fpu.o r4k_switch.o 45obj-$(CONFIG_CPU_TX39XX) += r2300_fpu.o r2300_switch.o 46obj-$(CONFIG_CPU_CAVIUM_OCTEON) += octeon_switch.o 47 48obj-$(CONFIG_SMP) += smp.o 49obj-$(CONFIG_SMP_UP) += smp-up.o 50obj-$(CONFIG_CPU_BMIPS) += smp-bmips.o bmips_vec.o 51 52obj-$(CONFIG_MIPS_MT) += mips-mt.o 53obj-$(CONFIG_MIPS_MT_FPAFF) += mips-mt-fpaff.o 54obj-$(CONFIG_MIPS_MT_SMTC) += smtc.o smtc-asm.o smtc-proc.o 55obj-$(CONFIG_MIPS_MT_SMP) += smp-mt.o 56obj-$(CONFIG_MIPS_CMP) += smp-cmp.o cpc.o 57obj-$(CONFIG_CPU_MIPSR2) += spram.o 58 59obj-$(CONFIG_MIPS_VPE_LOADER) += vpe.o 60obj-$(CONFIG_MIPS_VPE_APSP_API) += rtlx.o 61 62obj-$(CONFIG_I8259) += i8259.o 63obj-$(CONFIG_IRQ_CPU) += irq_cpu.o 64obj-$(CONFIG_IRQ_CPU_RM7K) += irq-rm7000.o 65obj-$(CONFIG_MIPS_MSC) += irq-msc01.o 66obj-$(CONFIG_IRQ_TXX9) += irq_txx9.o 67obj-$(CONFIG_IRQ_GT641XX) += irq-gt641xx.o 68obj-$(CONFIG_IRQ_GIC) += irq-gic.o 69 70obj-$(CONFIG_KPROBES) += kprobes.o 71obj-$(CONFIG_32BIT) += scall32-o32.o 72obj-$(CONFIG_64BIT) += scall64-64.o 73obj-$(CONFIG_MIPS32_COMPAT) += linux32.o ptrace32.o signal32.o 74obj-$(CONFIG_MIPS32_N32) += binfmt_elfn32.o scall64-n32.o signal_n32.o 75obj-$(CONFIG_MIPS32_O32) += binfmt_elfo32.o scall64-o32.o 76 77obj-$(CONFIG_KGDB) += kgdb.o 78obj-$(CONFIG_PROC_FS) += proc.o 79 80obj-$(CONFIG_64BIT) += cpu-bugs64.o 81 82obj-$(CONFIG_I8253) += i8253.o 83 84obj-$(CONFIG_GPIO_TXX9) += gpio_txx9.o 85 86obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o crash.o 87obj-$(CONFIG_CRASH_DUMP) += crash_dump.o 88obj-$(CONFIG_EARLY_PRINTK) += early_printk.o 89obj-$(CONFIG_SPINLOCK_TEST) += spinlock_test.o 90obj-$(CONFIG_MIPS_MACHINE) += mips_machine.o 91obj-$(CONFIG_MIPS_INCOMPATIBLE_ARCH_EMULATION) += mips-r2-emul.o 92 93CFLAGS_cpu-bugs64.o = $(shell if $(CC) $(KBUILD_CFLAGS) -Wa,-mdaddi -c -o /dev/null -x c /dev/null >/dev/null 2>&1; then echo "-DHAVE_AS_SET_DADDI"; fi) 94 95obj-$(CONFIG_HAVE_STD_PC_SERIAL_PORT) += 8250-platform.o 96 97obj-$(CONFIG_PERF_EVENTS) += perf_event.o 98obj-$(CONFIG_HW_PERF_EVENTS) += perf_event_mipsxx.o 99 100obj-$(CONFIG_JUMP_LABEL) += jump_label.o 101 102# 103# DSP ASE supported for MIPS32 or MIPS64 Release 2 cores only. It is not 104# safe to unconditionnaly use the assembler -mdsp / -mdspr2 switches 105# here because the compiler may use DSP ASE instructions (such as lwx) in 106# code paths where we cannot check that the CPU we are running on supports it. 107# Proper abstraction using HAVE_AS_DSP and macros is done in 108# arch/mips/include/asm/mipsregs.h. 109# 110ifeq ($(CONFIG_CPU_MIPSR2), y) 111CFLAGS_DSP = -DHAVE_AS_DSP 112 113CFLAGS_signal.o = $(CFLAGS_DSP) 114CFLAGS_signal32.o = $(CFLAGS_DSP) 115CFLAGS_process.o = $(CFLAGS_DSP) 116CFLAGS_branch.o = $(CFLAGS_DSP) 117CFLAGS_ptrace.o = $(CFLAGS_DSP) 118endif 119 120CPPFLAGS_vmlinux.lds := $(KBUILD_CFLAGS) 121