config.mk 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. #
  2. # (C) Copyright 2003
  3. # Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  4. #
  5. # SPDX-License-Identifier: GPL-2.0+
  6. #
  7. ifdef CONFIG_SYS_BIG_ENDIAN
  8. 32bit-emul := elf32btsmip
  9. 64bit-emul := elf64btsmip
  10. 32bit-bfd := elf32-tradbigmips
  11. 64bit-bfd := elf64-tradbigmips
  12. PLATFORM_CPPFLAGS += -EB
  13. PLATFORM_LDFLAGS += -EB
  14. endif
  15. ifdef CONFIG_SYS_LITTLE_ENDIAN
  16. 32bit-emul := elf32ltsmip
  17. 64bit-emul := elf64ltsmip
  18. 32bit-bfd := elf32-tradlittlemips
  19. 64bit-bfd := elf64-tradlittlemips
  20. PLATFORM_CPPFLAGS += -EL
  21. PLATFORM_LDFLAGS += -EL
  22. endif
  23. ifdef CONFIG_32BIT
  24. PLATFORM_CPPFLAGS += -mabi=32
  25. PLATFORM_LDFLAGS += -m $(32bit-emul)
  26. OBJCOPYFLAGS += -O $(32bit-bfd)
  27. endif
  28. ifdef CONFIG_64BIT
  29. PLATFORM_CPPFLAGS += -mabi=64
  30. PLATFORM_LDFLAGS += -m$(64bit-emul)
  31. OBJCOPYFLAGS += -O $(64bit-bfd)
  32. endif
  33. PLATFORM_CPPFLAGS += -D__MIPS__
  34. #
  35. # From Linux arch/mips/Makefile
  36. #
  37. # GCC uses -G 0 -mabicalls -fpic as default. We don't want PIC in the kernel
  38. # code since it only slows down the whole thing. At some point we might make
  39. # use of global pointer optimizations but their use of $28 conflicts with
  40. # the current pointer optimization.
  41. #
  42. # The DECStation requires an ECOFF kernel for remote booting, other MIPS
  43. # machines may also. Since BFD is incredibly buggy with respect to
  44. # crossformat linking we rely on the elf2ecoff tool for format conversion.
  45. #
  46. # cflags-y += -G 0 -mno-abicalls -fno-pic -pipe
  47. # cflags-y += -msoft-float
  48. # LDFLAGS_vmlinux += -G 0 -static -n -nostdlib
  49. # MODFLAGS += -mlong-calls
  50. #
  51. # On the other hand, we want PIC in the U-Boot code to relocate it from ROM
  52. # to RAM. $28 is always used as gp.
  53. #
  54. ifdef CONFIG_SPL_BUILD
  55. PF_ABICALLS := -mno-abicalls
  56. PF_PIC := -fno-pic
  57. PF_PIE :=
  58. else
  59. PF_ABICALLS := -mabicalls
  60. PF_PIC := -fpic
  61. PF_PIE := -pie
  62. PF_OBJCOPY := -j .got -j .rel.dyn -j .padding
  63. PF_OBJCOPY += -j .dtb.init.rodata
  64. endif
  65. PLATFORM_CPPFLAGS += -G 0 $(PF_ABICALLS) $(PF_PIC)
  66. PLATFORM_CPPFLAGS += -msoft-float
  67. PLATFORM_LDFLAGS += -G 0 -static -n -nostdlib
  68. PLATFORM_RELFLAGS += -ffunction-sections -fdata-sections
  69. LDFLAGS_FINAL += --gc-sections $(PF_PIE)
  70. OBJCOPYFLAGS += -j .text -j .rodata -j .data -j .u_boot_list
  71. OBJCOPYFLAGS += $(PF_OBJCOPY)