Patrick Georgi | 0c2df6f | 2017-11-22 16:14:09 -0500 | [diff] [blame] | 1 | #################################################################################### |
| 2 | # |
| 3 | # COREBOOT is spun off from the GCC5 template |
| 4 | # |
| 5 | #################################################################################### |
| 6 | |
Patrick Georgi | 214dde0 | 2017-11-30 07:42:47 -0500 | [diff] [blame] | 7 | DEFINE COREBOOT_IA32_PREFIX = @@PREFIX@@/bin/i386-elf- |
| 8 | DEFINE COREBOOT_X64_PREFIX = @@PREFIX@@/bin/x86_64-elf- |
| 9 | DEFINE COREBOOT_ARM_PREFIX = @@PREFIX@@/bin/arm-eabi- |
| 10 | DEFINE COREBOOT_AARCH64_PREFIX = @@PREFIX@@/bin/arch64-elf- |
Patrick Georgi | 0c2df6f | 2017-11-22 16:14:09 -0500 | [diff] [blame] | 11 | |
| 12 | DEFINE COREBOOT_IA32_CC_FLAGS = DEF(GCC5_IA32_CC_FLAGS) |
| 13 | DEFINE COREBOOT_X64_CC_FLAGS = DEF(GCC5_X64_CC_FLAGS) |
| 14 | DEFINE COREBOOT_IA32_X64_DLINK_COMMON = DEF(GCC5_IA32_X64_DLINK_COMMON) |
| 15 | DEFINE COREBOOT_IA32_X64_ASLDLINK_FLAGS = DEF(GCC5_IA32_X64_ASLDLINK_FLAGS) |
| 16 | DEFINE COREBOOT_IA32_X64_DLINK_FLAGS = DEF(GCC5_IA32_X64_DLINK_FLAGS) |
| 17 | DEFINE COREBOOT_IA32_DLINK2_FLAGS = DEF(GCC5_IA32_DLINK2_FLAGS) |
| 18 | DEFINE COREBOOT_X64_DLINK_FLAGS = DEF(GCC5_X64_DLINK_FLAGS) |
| 19 | DEFINE COREBOOT_X64_DLINK2_FLAGS = DEF(GCC5_X64_DLINK2_FLAGS) |
| 20 | DEFINE COREBOOT_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) |
| 21 | DEFINE COREBOOT_ARM_ASM_FLAGS = DEF(GCC5_ARM_ASM_FLAGS) |
| 22 | DEFINE COREBOOT_AARCH64_ASM_FLAGS = DEF(GCC5_AARCH64_ASM_FLAGS) |
| 23 | DEFINE COREBOOT_ARM_CC_FLAGS = DEF(GCC5_ARM_CC_FLAGS) |
| 24 | DEFINE COREBOOT_ARM_CC_XIPFLAGS = DEF(GCC5_ARM_CC_XIPFLAGS) |
| 25 | DEFINE COREBOOT_AARCH64_CC_FLAGS = DEF(GCC5_AARCH64_CC_FLAGS) |
| 26 | DEFINE COREBOOT_AARCH64_CC_XIPFLAGS = DEF(GCC5_AARCH64_CC_XIPFLAGS) |
| 27 | DEFINE COREBOOT_ARM_DLINK_FLAGS = DEF(GCC5_ARM_DLINK_FLAGS) |
| 28 | DEFINE COREBOOT_ARM_DLINK2_FLAGS = DEF(GCC5_ARM_DLINK2_FLAGS) |
| 29 | DEFINE COREBOOT_AARCH64_DLINK_FLAGS = DEF(GCC5_AARCH64_DLINK_FLAGS) |
| 30 | DEFINE COREBOOT_AARCH64_DLINK2_FLAGS = DEF(GCC5_AARCH64_DLINK2_FLAGS) |
| 31 | DEFINE COREBOOT_ARM_ASLDLINK_FLAGS = DEF(GCC5_ARM_ASLDLINK_FLAGS) |
| 32 | DEFINE COREBOOT_AARCH64_ASLDLINK_FLAGS = DEF(GCC5_AARCH64_ASLDLINK_FLAGS) |
| 33 | |
| 34 | #################################################################################### |
| 35 | # |
| 36 | # GCC 5 - This configuration is used to compile under Linux to produce |
| 37 | # PE/COFF binaries using GCC 5 |
| 38 | # |
| 39 | #################################################################################### |
| 40 | *_COREBOOT_*_*_FAMILY = GCC |
| 41 | |
| 42 | *_COREBOOT_*_MAKE_PATH = make |
| 43 | *_COREBOOT_*_*_DLL = ENV(COREBOOT_DLL) |
| 44 | *_COREBOOT_*_ASL_PATH = DEF(UNIX_IASL_BIN) |
| 45 | |
| 46 | *_COREBOOT_*_PP_FLAGS = DEF(GCC_PP_FLAGS) |
| 47 | *_COREBOOT_*_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) |
| 48 | *_COREBOOT_*_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) |
| 49 | *_COREBOOT_*_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) |
| 50 | *_COREBOOT_*_APP_FLAGS = |
| 51 | *_COREBOOT_*_ASL_FLAGS = DEF(IASL_FLAGS) |
| 52 | *_COREBOOT_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS) |
| 53 | |
| 54 | ################## |
| 55 | # COREBOOT IA32 definitions |
| 56 | ################## |
| 57 | *_COREBOOT_IA32_OBJCOPY_PATH = DEF(COREBOOT_IA32_PREFIX)objcopy |
| 58 | *_COREBOOT_IA32_CC_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 59 | *_COREBOOT_IA32_SLINK_PATH = DEF(COREBOOT_IA32_PREFIX)gcc-ar |
| 60 | *_COREBOOT_IA32_DLINK_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 61 | *_COREBOOT_IA32_ASLDLINK_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 62 | *_COREBOOT_IA32_ASM_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 63 | *_COREBOOT_IA32_PP_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 64 | *_COREBOOT_IA32_VFRPP_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 65 | *_COREBOOT_IA32_ASLCC_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 66 | *_COREBOOT_IA32_ASLPP_PATH = DEF(COREBOOT_IA32_PREFIX)gcc |
| 67 | *_COREBOOT_IA32_RC_PATH = DEF(COREBOOT_IA32_PREFIX)objcopy |
| 68 | |
| 69 | *_COREBOOT_IA32_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m32 -fno-lto |
| 70 | *_COREBOOT_IA32_ASLDLINK_FLAGS = DEF(COREBOOT_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386 |
| 71 | *_COREBOOT_IA32_ASM_FLAGS = DEF(COREBOOT_ASM_FLAGS) -m32 -march=i386 |
| 72 | *_COREBOOT_IA32_DLINK2_FLAGS = DEF(COREBOOT_IA32_DLINK2_FLAGS) |
| 73 | *_COREBOOT_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS) |
| 74 | *_COREBOOT_IA32_OBJCOPY_FLAGS = |
| 75 | *_COREBOOT_IA32_NASM_FLAGS = -f elf32 |
| 76 | |
| 77 | DEBUG_COREBOOT_IA32_CC_FLAGS = DEF(COREBOOT_IA32_CC_FLAGS) -flto -Os |
| 78 | DEBUG_COREBOOT_IA32_DLINK_FLAGS = DEF(COREBOOT_IA32_X64_DLINK_FLAGS) -flto -Os -Wl,-m,elf_i386,--oformat=elf32-i386 |
| 79 | |
| 80 | RELEASE_COREBOOT_IA32_CC_FLAGS = DEF(COREBOOT_IA32_CC_FLAGS) -flto -Os -Wno-unused-but-set-variable |
| 81 | RELEASE_COREBOOT_IA32_DLINK_FLAGS = DEF(COREBOOT_IA32_X64_DLINK_FLAGS) -flto -Os -Wl,-m,elf_i386,--oformat=elf32-i386 |
| 82 | |
| 83 | NOOPT_COREBOOT_IA32_CC_FLAGS = DEF(COREBOOT_IA32_CC_FLAGS) -O0 |
| 84 | NOOPT_COREBOOT_IA32_DLINK_FLAGS = DEF(COREBOOT_IA32_X64_DLINK_FLAGS) -Wl,-m,elf_i386,--oformat=elf32-i386 -O0 |
| 85 | |
| 86 | ################## |
| 87 | # COREBOOT X64 definitions |
| 88 | ################## |
| 89 | *_COREBOOT_X64_OBJCOPY_PATH = DEF(COREBOOT_X64_PREFIX)objcopy |
| 90 | *_COREBOOT_X64_CC_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 91 | *_COREBOOT_X64_SLINK_PATH = DEF(COREBOOT_X64_PREFIX)gcc-ar |
| 92 | *_COREBOOT_X64_DLINK_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 93 | *_COREBOOT_X64_ASLDLINK_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 94 | *_COREBOOT_X64_ASM_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 95 | *_COREBOOT_X64_PP_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 96 | *_COREBOOT_X64_VFRPP_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 97 | *_COREBOOT_X64_ASLCC_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 98 | *_COREBOOT_X64_ASLPP_PATH = DEF(COREBOOT_X64_PREFIX)gcc |
| 99 | *_COREBOOT_X64_RC_PATH = DEF(COREBOOT_X64_PREFIX)objcopy |
| 100 | |
| 101 | *_COREBOOT_X64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m64 -fno-lto |
| 102 | *_COREBOOT_X64_ASLDLINK_FLAGS = DEF(COREBOOT_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64 |
| 103 | *_COREBOOT_X64_ASM_FLAGS = DEF(COREBOOT_ASM_FLAGS) -m64 |
| 104 | *_COREBOOT_X64_DLINK2_FLAGS = DEF(COREBOOT_X64_DLINK2_FLAGS) |
| 105 | *_COREBOOT_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS) |
| 106 | *_COREBOOT_X64_OBJCOPY_FLAGS = |
| 107 | *_COREBOOT_X64_NASM_FLAGS = -f elf64 |
| 108 | |
| 109 | DEBUG_COREBOOT_X64_CC_FLAGS = DEF(COREBOOT_X64_CC_FLAGS) -flto -DUSING_LTO -Os |
| 110 | DEBUG_COREBOOT_X64_DLINK_FLAGS = DEF(COREBOOT_X64_DLINK_FLAGS) -flto -Os |
| 111 | |
| 112 | RELEASE_COREBOOT_X64_CC_FLAGS = DEF(COREBOOT_X64_CC_FLAGS) -flto -DUSING_LTO -Os -Wno-unused-but-set-variable |
| 113 | RELEASE_COREBOOT_X64_DLINK_FLAGS = DEF(COREBOOT_X64_DLINK_FLAGS) -flto -Os |
| 114 | |
| 115 | NOOPT_COREBOOT_X64_CC_FLAGS = DEF(COREBOOT_X64_CC_FLAGS) -O0 |
| 116 | NOOPT_COREBOOT_X64_DLINK_FLAGS = DEF(COREBOOT_X64_DLINK_FLAGS) -O0 |
| 117 | |
| 118 | ################## |
| 119 | # COREBOOT ARM definitions |
| 120 | ################## |
| 121 | *_COREBOOT_ARM_CC_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 122 | *_COREBOOT_ARM_SLINK_PATH = ENV(COREBOOT_ARM_PREFIX)gcc-ar |
| 123 | *_COREBOOT_ARM_DLINK_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 124 | *_COREBOOT_ARM_ASLDLINK_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 125 | *_COREBOOT_ARM_ASM_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 126 | *_COREBOOT_ARM_PP_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 127 | *_COREBOOT_ARM_VFRPP_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 128 | *_COREBOOT_ARM_ASLCC_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 129 | *_COREBOOT_ARM_ASLPP_PATH = ENV(COREBOOT_ARM_PREFIX)gcc |
| 130 | *_COREBOOT_ARM_RC_PATH = ENV(COREBOOT_ARM_PREFIX)objcopy |
| 131 | |
| 132 | *_COREBOOT_ARM_ARCHCC_FLAGS = -mthumb |
| 133 | *_COREBOOT_ARM_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) |
| 134 | *_COREBOOT_ARM_ASLDLINK_FLAGS = DEF(COREBOOT_ARM_ASLDLINK_FLAGS) |
| 135 | *_COREBOOT_ARM_ASM_FLAGS = DEF(COREBOOT_ARM_ASM_FLAGS) |
| 136 | *_COREBOOT_ARM_DLINK2_FLAGS = DEF(COREBOOT_ARM_DLINK2_FLAGS) |
| 137 | *_COREBOOT_ARM_PLATFORM_FLAGS = -march=armv7-a |
| 138 | *_COREBOOT_ARM_PP_FLAGS = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) |
| 139 | *_COREBOOT_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS) |
| 140 | *_COREBOOT_ARM_VFRPP_FLAGS = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS) |
| 141 | *_COREBOOT_ARM_CC_XIPFLAGS = DEF(COREBOOT_ARM_CC_XIPFLAGS) |
| 142 | |
| 143 | DEBUG_COREBOOT_ARM_CC_FLAGS = DEF(COREBOOT_ARM_CC_FLAGS) -O0 |
| 144 | DEBUG_COREBOOT_ARM_DLINK_FLAGS = DEF(COREBOOT_ARM_DLINK_FLAGS) |
| 145 | |
| 146 | RELEASE_COREBOOT_ARM_CC_FLAGS = DEF(COREBOOT_ARM_CC_FLAGS) -flto -Wno-unused-but-set-variable |
| 147 | RELEASE_COREBOOT_ARM_DLINK_FLAGS = DEF(COREBOOT_ARM_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=-pass-through=-llto-arm |
| 148 | |
| 149 | NOOPT_COREBOOT_ARM_CC_FLAGS = DEF(COREBOOT_ARM_CC_FLAGS) -O0 |
| 150 | NOOPT_COREBOOT_ARM_DLINK_FLAGS = DEF(COREBOOT_ARM_DLINK_FLAGS) -O0 |
| 151 | |
| 152 | ################## |
| 153 | # COREBOOT AARCH64 definitions |
| 154 | ################## |
| 155 | *_COREBOOT_AARCH64_CC_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 156 | *_COREBOOT_AARCH64_SLINK_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc-ar |
| 157 | *_COREBOOT_AARCH64_DLINK_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 158 | *_COREBOOT_AARCH64_ASLDLINK_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 159 | *_COREBOOT_AARCH64_ASM_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 160 | *_COREBOOT_AARCH64_PP_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 161 | *_COREBOOT_AARCH64_VFRPP_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 162 | *_COREBOOT_AARCH64_ASLCC_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 163 | *_COREBOOT_AARCH64_ASLPP_PATH = ENV(COREBOOT_AARCH64_PREFIX)gcc |
| 164 | *_COREBOOT_AARCH64_RC_PATH = ENV(COREBOOT_AARCH64_PREFIX)objcopy |
| 165 | |
| 166 | *_COREBOOT_AARCH64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) |
| 167 | *_COREBOOT_AARCH64_ASLDLINK_FLAGS = DEF(COREBOOT_AARCH64_ASLDLINK_FLAGS) |
| 168 | *_COREBOOT_AARCH64_ASM_FLAGS = DEF(COREBOOT_AARCH64_ASM_FLAGS) |
| 169 | *_COREBOOT_AARCH64_DLINK2_FLAGS = DEF(COREBOOT_AARCH64_DLINK2_FLAGS) |
| 170 | *_COREBOOT_AARCH64_PLATFORM_FLAGS = |
| 171 | *_COREBOOT_AARCH64_PP_FLAGS = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) |
| 172 | *_COREBOOT_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS) |
| 173 | *_COREBOOT_AARCH64_VFRPP_FLAGS = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS) |
| 174 | *_COREBOOT_AARCH64_CC_XIPFLAGS = DEF(COREBOOT_AARCH64_CC_XIPFLAGS) |
| 175 | |
| 176 | DEBUG_COREBOOT_AARCH64_CC_FLAGS = DEF(COREBOOT_AARCH64_CC_FLAGS) -O0 -mcmodel=small |
| 177 | DEBUG_COREBOOT_AARCH64_DLINK_FLAGS = DEF(COREBOOT_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000 |
| 178 | DEBUG_COREBOOT_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20 |
| 179 | |
| 180 | RELEASE_COREBOOT_AARCH64_CC_FLAGS = DEF(COREBOOT_AARCH64_CC_FLAGS) -flto -Wno-unused-but-set-variable -mcmodel=tiny -fomit-frame-pointer |
| 181 | RELEASE_COREBOOT_AARCH64_DLINK_FLAGS = DEF(COREBOOT_AARCH64_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=-pass-through=-llto-aarch64 -Wno-lto-type-mismatch |
| 182 | |
| 183 | NOOPT_COREBOOT_AARCH64_CC_FLAGS = DEF(COREBOOT_AARCH64_CC_FLAGS) -O0 -mcmodel=small |
| 184 | NOOPT_COREBOOT_AARCH64_DLINK_FLAGS = DEF(COREBOOT_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000 -O0 |
| 185 | NOOPT_COREBOOT_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20 -O0 |