xref: /openbmc/u-boot/arch/mips/config.mk (revision 872cfa20cd694fdbfa76abddd3cd00b05ad5355b)
1# SPDX-License-Identifier: GPL-2.0+
2#
3# (C) Copyright 2003
4# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5
6ifdef CONFIG_SYS_BIG_ENDIAN
732bit-emul		:= elf32btsmip
864bit-emul		:= elf64btsmip
932bit-bfd		:= elf32-tradbigmips
1064bit-bfd		:= elf64-tradbigmips
11PLATFORM_CPPFLAGS	+= -EB
12PLATFORM_LDFLAGS	+= -EB
13endif
14
15ifdef CONFIG_SYS_LITTLE_ENDIAN
1632bit-emul		:= elf32ltsmip
1764bit-emul		:= elf64ltsmip
1832bit-bfd		:= elf32-tradlittlemips
1964bit-bfd		:= elf64-tradlittlemips
20PLATFORM_CPPFLAGS	+= -EL
21PLATFORM_LDFLAGS	+= -EL
22endif
23
24ifdef CONFIG_32BIT
25PLATFORM_CPPFLAGS	+= -mabi=32
26PLATFORM_LDFLAGS	+= -m $(32bit-emul)
27OBJCOPYFLAGS		+= -O $(32bit-bfd)
28CONFIG_STANDALONE_LOAD_ADDR	?= 0x80200000
29endif
30
31ifdef CONFIG_64BIT
32PLATFORM_CPPFLAGS	+= -mabi=64
33PLATFORM_LDFLAGS	+= -m$(64bit-emul)
34OBJCOPYFLAGS		+= -O $(64bit-bfd)
35CONFIG_STANDALONE_LOAD_ADDR	?= 0xffffffff80200000
36endif
37
38PLATFORM_CPPFLAGS += -D__MIPS__
39PLATFORM_ELFENTRY = "__start"
40PLATFORM_ELFFLAGS += -B mips $(OBJCOPYFLAGS)
41
42#
43# From Linux arch/mips/Makefile
44#
45# GCC uses -G 0 -mabicalls -fpic as default.  We don't want PIC in the kernel
46# code since it only slows down the whole thing.  At some point we might make
47# use of global pointer optimizations but their use of $28 conflicts with
48# the current pointer optimization.
49#
50# The DECStation requires an ECOFF kernel for remote booting, other MIPS
51# machines may also.  Since BFD is incredibly buggy with respect to
52# crossformat linking we rely on the elf2ecoff tool for format conversion.
53#
54# cflags-y			+= -G 0 -mno-abicalls -fno-pic -pipe
55# cflags-y			+= -msoft-float
56# LDFLAGS_vmlinux		+= -G 0 -static -n -nostdlib
57# MODFLAGS			+= -mlong-calls
58#
59ifndef CONFIG_SPL_BUILD
60OBJCOPYFLAGS			+= -j .data.reloc -j .dtb.init.rodata
61LDFLAGS_FINAL			+= --emit-relocs
62endif
63
64PLATFORM_CPPFLAGS		+= -G 0 -mno-abicalls -fno-pic
65PLATFORM_CPPFLAGS		+= -msoft-float
66PLATFORM_LDFLAGS		+= -G 0 -static -n -nostdlib
67PLATFORM_RELFLAGS		+= -ffunction-sections -fdata-sections
68LDFLAGS_FINAL			+= --gc-sections
69OBJCOPYFLAGS			+= -j .text -j .rodata -j .data -j .u_boot_list
70
71LDFLAGS_STANDALONE		+= --gc-sections
72