Makefile 4.3 KB

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