2005-04-17 02:20:36 +04:00
#
# This file is subject to the terms and conditions of the GNU General Public
# License. See the file "COPYING" in the main directory of this archive
# for more details.
#
# Copyright (C) 1994, 95, 96, 2003 by Ralf Baechle
# DECStation modifications by Paul M. Antoine, 1996
# Copyright (C) 2002, 2003, 2004 Maciej W. Rozycki
#
# This file is included by the global makefile so that you can add your own
# architecture-specific flags and dependencies. Remember to do have actions
# for "archclean" cleaning up for this architecture.
#
2016-03-31 12:05:33 +03:00
archscripts : scripts_basic
2018-08-29 21:01:30 +03:00
$( Q) $( MAKE) $( build) = arch/mips/tools elf-entry
2019-10-02 00:53:44 +03:00
i f e q ( $( CONFIG_CPU_LOONGSON 3_WORKAROUNDS ) , y )
$( Q) $( MAKE) $( build) = arch/mips/tools loongson3-llsc-check
e n d i f
2016-03-31 12:05:33 +03:00
$( Q) $( MAKE) $( build) = arch/mips/boot/tools relocs
2016-12-14 18:09:43 +03:00
KBUILD_DEFCONFIG := 32r2el_defconfig
2019-06-13 11:52:50 +03:00
KBUILD_DTBS := dtbs
2008-02-26 22:54:54 +03:00
2005-04-17 02:20:36 +04:00
#
# Select the object file format to substitute into the linker script.
#
i f d e f C O N F I G _ C P U _ L I T T L E _ E N D I A N
2007-10-22 22:10:57 +04:00
32bit-tool-archpref = mipsel
64bit-tool-archpref = mips64el
2005-04-17 02:20:36 +04:00
32bit-bfd = elf32-tradlittlemips
64bit-bfd = elf64-tradlittlemips
32bit-emul = elf32ltsmip
64bit-emul = elf64ltsmip
e l s e
2007-10-22 22:10:57 +04:00
32bit-tool-archpref = mips
64bit-tool-archpref = mips64
2005-04-17 02:20:36 +04:00
32bit-bfd = elf32-tradbigmips
64bit-bfd = elf64-tradbigmips
32bit-emul = elf32btsmip
64bit-emul = elf64btsmip
e n d i f
2005-09-04 02:56:16 +04:00
i f d e f C O N F I G _ 3 2 B I T
2007-10-22 22:10:57 +04:00
tool-archpref = $( 32bit-tool-archpref)
2005-04-17 02:20:36 +04:00
UTS_MACHINE := mips
e n d i f
2005-09-04 02:56:16 +04:00
i f d e f C O N F I G _ 6 4 B I T
2007-10-22 22:10:57 +04:00
tool-archpref = $( 64bit-tool-archpref)
2005-04-17 02:20:36 +04:00
UTS_MACHINE := mips64
e n d i f
2007-10-22 22:10:57 +04:00
i f n e q ( $( SUBARCH ) , $( ARCH ) )
ifeq ( $( CROSS_COMPILE) ,)
2007-11-12 20:30:52 +03:00
CROSS_COMPILE := $( call cc-cross-prefix, $( tool-archpref) -linux- $( tool-archpref) -linux-gnu- $( tool-archpref) -unknown-linux-gnu-)
2007-10-22 22:10:57 +04:00
endif
2005-04-17 02:20:36 +04:00
e n d i f
MIPS: Tracing: Make function graph tracer work with -mmcount-ra-address
That thread "MIPS: Add option to pass return address location to
_mcount" from "David Daney <ddaney@caviumnetworks.com>" have added a new
option -mmcount-ra-address to gcc(4.5) for MIPS to transfer the location
of the return address to _mcount.
Benefit from this new feature, function graph tracer on MIPS will be
easier and safer to hijack the return address of the kernel function,
which will save some overhead and make the whole thing more reliable.
In this patch, at first, try to enable the option -mmcount-ra-address in
arch/mips/Makefile with cc-option, if gcc support it, it will be
enabled, otherwise, no side effect.
and then, we need to support this new option of gcc 4.5 and also support
the old gcc versions.
with _mcount in the old gcc versions, it's not easy to get the location
of return address(tracing: add function graph tracer support for MIPS),
so, we do it in a C function: ftrace_get_parent_addr(ftrace.c), but
with -mmcount-ra-address, only several instructions need to get what
we want, so, I put into asm(mcount.S). and also, as the $12(t0) is
used by -mmcount-ra-address for transferring the localtion of return
address to _mcount, we need to save it into the stack and restore it
when enabled dynamic function tracer, 'Cause we have called
"ftrace_call" before "ftrace_graph_caller", which may destroy
$12(t0).
(Thanks to David for providing that -mcount-ra-address and giving the
idea of KBUILD_MCOUNT_RA_ADDRESS, both of them have made the whole
thing more beautiful!)
Signed-off-by: Wu Zhangjin <wuzhangjin@gmail.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Nicholas Mc Guire <der.herr@hofr.at>
Cc: zhangfx@lemote.com
Cc: Wu Zhangjin <wuzhangjin@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: linux-kernel@vger.kernel.org
Cc: linux-mips@linux-mips.org
Patchwork: http://patchwork.linux-mips.org/patch/681/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
2009-11-20 15:34:38 +03:00
i f d e f C O N F I G _ F U N C T I O N _ G R A P H _ T R A C E R
ifndef KBUILD_MCOUNT_RA_ADDRESS
ifeq ( $( call cc-option-yn,-mmcount-ra-address) , y)
cflags-y += -mmcount-ra-address -DKBUILD_MCOUNT_RA_ADDRESS
endif
endif
e n d i f
2009-04-28 21:28:33 +04:00
cflags-y += $( call cc-option, -mno-check-zero-division)
2009-04-28 21:38:35 +04:00
2006-02-23 02:06:55 +03:00
i f d e f C O N F I G _ 3 2 B I T
2005-04-17 02:20:36 +04:00
ld-emul = $( 32bit-emul)
vmlinux-32 = vmlinux
vmlinux-64 = vmlinux.64
2006-03-08 14:35:00 +03:00
cflags-y += -mabi= 32
2006-02-23 02:06:55 +03:00
e n d i f
2005-04-17 02:20:36 +04:00
2006-02-23 02:06:55 +03:00
i f d e f C O N F I G _ 6 4 B I T
ld-emul = $( 64bit-emul)
vmlinux-32 = vmlinux.32
vmlinux-64 = vmlinux
2006-03-08 14:35:00 +03:00
cflags-y += -mabi= 64
2005-04-17 02:20:36 +04:00
e n d i f
2007-07-28 16:27:21 +04:00
all-$(CONFIG_BOOT_ELF32) := $( vmlinux-32)
all-$(CONFIG_BOOT_ELF64) := $( vmlinux-64)
2009-10-14 14:12:16 +04:00
all-$(CONFIG_SYS_SUPPORTS_ZBOOT) += vmlinuz
2006-03-08 14:35:00 +03:00
2005-04-17 02:20:36 +04:00
#
# GCC uses -G 0 -mabicalls -fpic as default. We don't want PIC in the kernel
# code since it only slows down the whole thing. At some point we might make
# use of global pointer optimizations but their use of $28 conflicts with
# the current pointer optimization.
#
# The DECStation requires an ECOFF kernel for remote booting, other MIPS
# machines may also. Since BFD is incredibly buggy with respect to
# crossformat linking we rely on the elf2ecoff tool for format conversion.
#
cflags-y += -G 0 -mno-abicalls -fno-pic -pipe
2006-03-08 20:14:49 +03:00
cflags-y += -msoft-float
2005-02-21 14:22:15 +03:00
LDFLAGS_vmlinux += -G 0 -static -n -nostdlib
kbuild: allow assignment to {A,C,LD}FLAGS_MODULE on the command line
It is now possible to assign options to AS, CC and LD
on the command line - which is only used when building modules.
{A,C,LD}FLAGS_MODULE was all used both in the top-level Makefile
in the arch makefiles, thus users had no way to specify
additional options to AS, CC, LD when building modules
without overriding the original value.
Introduce a new set of variables KBUILD_{A,C,LD}FLAGS_MODULE
that is used by arch specific files and free up
{A,C,LD}FLAGS_MODULE so they can be assigned on
the command line.
All arch Makefiles that used the old variables has been updated.
Note: Previously we had a MODFLAGS variable for both
AS and CC. But in favour of consistency this was dropped.
So in some cases arch Makefile has one assignmnet replaced by
two assignmnets.
Note2: MODFLAGS was not documented and is dropped
without any notice. I do not expect much/any breakage
from this.
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Cc: Denys Vlasenko <vda.linux@googlemail.com>
Cc: Haavard Skinnemoen <hskinnemoen@atmel.com>
Cc: Mike Frysinger <vapier@gentoo.org>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Chen Liqin <liqin.chen@sunplusct.com>
Acked-by: Mike Frysinger <vapier@gentoo.org> [blackfin]
Acked-by: Haavard Skinnemoen <haavard.skinnemoen@atmel.com> [avr32]
Signed-off-by: Michal Marek <mmarek@suse.cz>
2010-07-28 19:33:09 +04:00
KBUILD_AFLAGS_MODULE += -mlong-calls
KBUILD_CFLAGS_MODULE += -mlong-calls
2005-04-17 02:20:36 +04:00
2016-03-31 12:05:35 +03:00
i f e q ( $( CONFIG_RELOCATABLE ) , y )
LDFLAGS_vmlinux += --emit-relocs
e n d i f
2014-11-07 16:13:54 +03:00
#
# pass -msoft-float to GAS if it supports it. However on newer binutils
# (specifically newer than 2.24.51.20140728) we then also need to explicitly
# set ".set hardfloat" in all files which manipulate floating point registers.
#
i f n e q ( $( call as -option ,-Wa $ ( comma ) -msoft -float ,) , )
cflags-y += -DGAS_HAS_SET_HARDFLOAT -Wa,-msoft-float
e n d i f
2006-06-07 16:25:37 +04:00
cflags-y += -ffreestanding
2005-07-07 13:19:31 +04:00
#
# We explicitly add the endianness specifier if needed, this allows
# to compile kernels with a toolchain for the other endianness. We
# carefully avoid to add it redundantly because gcc 3.3/3.4 complains
# when fed the toolchain default!
#
2011-03-31 05:57:33 +04:00
# Certain gcc versions up to gcc 4.1.1 (probably 4.2-subversion as of
2007-05-09 10:57:56 +04:00
# 2006-10-10 don't properly change the predefined symbols if -EB / -EL
2006-10-10 18:44:10 +04:00
# are used, so we kludge that here. A bug has been filed at
# http://gcc.gnu.org/bugzilla/show_bug.cgi?id=29413.
#
2018-08-08 02:06:41 +03:00
# clang doesn't suffer from these issues and our checks against -dumpmachine
# don't work so well when cross compiling, since without providing --target
# clang's output will be based upon the build machine. So for clang we simply
# unconditionally specify -EB or -EL as appropriate.
#
2018-10-30 16:26:33 +03:00
i f d e f C O N F I G _ C C _ I S _ C L A N G
2018-08-08 02:06:41 +03:00
cflags-$(CONFIG_CPU_BIG_ENDIAN) += -EB
cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -EL
e l s e
2006-10-10 18:44:10 +04:00
undef-all += -UMIPSEB -U_MIPSEB -U__MIPSEB -U__MIPSEB__
undef-all += -UMIPSEL -U_MIPSEL -U__MIPSEL -U__MIPSEL__
predef-be += -DMIPSEB -D_MIPSEB -D__MIPSEB -D__MIPSEB__
predef-le += -DMIPSEL -D_MIPSEL -D__MIPSEL -D__MIPSEL__
cflags-$(CONFIG_CPU_BIG_ENDIAN) += $( shell $( CC) -dumpmachine | grep -q 'mips.*el-.*' && echo -EB $( undef-all) $( predef-be) )
cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += $( shell $( CC) -dumpmachine | grep -q 'mips.*el-.*' || echo -EL $( undef-all) $( predef-le) )
2018-08-08 02:06:41 +03:00
e n d i f
2005-07-07 13:19:31 +04:00
2006-03-18 19:59:31 +03:00
cflags-$(CONFIG_SB1XXX_CORELIS) += $( call cc-option,-mno-sched-prolog) \
-fno-omit-frame-pointer
2017-01-29 06:24:16 +03:00
# Some distribution-specific toolchains might pass the -fstack-check
# option during the build, which adds a simple stack-probe at the beginning
# of every function. This stack probe is to ensure that there is enough
# stack space, else a SEGV is generated. This is not desirable for MIPS
# as kernel stacks are small, placed in unmapped virtual memory, and do not
# grow when overflowed. Especially on SGI IP27 platforms, this check will
# lead to a NULL pointer dereference in _raw_spin_lock_irq.
#
# In disassembly, this stack probe appears at the top of a function as:
# sd zero,<offset>(sp)
# Where <offset> is a negative value.
#
cflags-y += -fno-stack-check
2005-04-17 02:20:36 +04:00
#
# CPU-dependent compiler/assembler options for optimization.
#
2006-03-08 14:35:00 +03:00
cflags-$(CONFIG_CPU_R3000) += -march= r3000
cflags-$(CONFIG_CPU_TX39XX) += -march= r3900
cflags-$(CONFIG_CPU_VR41XX) += -march= r4100 -Wa,--trap
cflags-$(CONFIG_CPU_R4X00) += -march= r4600 -Wa,--trap
cflags-$(CONFIG_CPU_TX49XX) += -march= r4600 -Wa,--trap
2018-06-19 03:37:59 +03:00
cflags-$(CONFIG_CPU_MIPS32_R1) += -march= mips32 -Wa,--trap
cflags-$(CONFIG_CPU_MIPS32_R2) += -march= mips32r2 -Wa,--trap
MIPS: build: Fix "-modd-spreg" switch usage when compiling for mips32r6
Add "-modd-spreg" when compiling the kernel for mips32r6 target.
This makes sure the kernel builds properly even with toolchains that
use "-mno-odd-spreg" by default. This is the case with Android gcc.
Prior to this patch, kernel builds using gcc for Android failed with
following error messages, if target architecture is set to mips32r6:
arch/mips/kernel/r4k_switch.S: Assembler messages:
.../r4k_switch.S:210: Error: float register should be even, was 1
.../r4k_switch.S:212: Error: float register should be even, was 3
.../r4k_switch.S:214: Error: float register should be even, was 5
.../r4k_switch.S:216: Error: float register should be even, was 7
.../r4k_switch.S:218: Error: float register should be even, was 9
.../r4k_switch.S:220: Error: float register should be even, was 11
.../r4k_switch.S:222: Error: float register should be even, was 13
.../r4k_switch.S:224: Error: float register should be even, was 15
.../r4k_switch.S:226: Error: float register should be even, was 17
.../r4k_switch.S:228: Error: float register should be even, was 19
.../r4k_switch.S:230: Error: float register should be even, was 21
.../r4k_switch.S:232: Error: float register should be even, was 23
.../r4k_switch.S:234: Error: float register should be even, was 25
.../r4k_switch.S:236: Error: float register should be even, was 27
.../r4k_switch.S:238: Error: float register should be even, was 29
.../r4k_switch.S:240: Error: float register should be even, was 31
make[2]: *** [arch/mips/kernel/r4k_switch.o] Error 1
Signed-off-by: Miodrag Dinic <miodrag.dinic@imgtec.com>
Signed-off-by: Goran Ferenc <goran.ferenc@imgtec.com>
Signed-off-by: Aleksandar Markovic <aleksandar.markovic@imgtec.com>
Cc: James.Hogan@imgtec.com
Cc: Paul.Burton@imgtec.com
Cc: Raghu.Gandham@imgtec.com
Cc: Leonid.Yegoshin@imgtec.com
Cc: Douglas.Leung@imgtec.com
Cc: Petar.Jovanovic@imgtec.com
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/16509/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
2017-06-19 18:50:09 +03:00
cflags-$(CONFIG_CPU_MIPS32_R6) += -march= mips32r6 -Wa,--trap -modd-spreg
2018-06-19 03:37:59 +03:00
cflags-$(CONFIG_CPU_MIPS64_R1) += -march= mips64 -Wa,--trap
cflags-$(CONFIG_CPU_MIPS64_R2) += -march= mips64r2 -Wa,--trap
2014-10-27 13:34:11 +03:00
cflags-$(CONFIG_CPU_MIPS64_R6) += -march= mips64r6 -Wa,--trap
2006-03-08 14:35:00 +03:00
cflags-$(CONFIG_CPU_R5000) += -march= r5000 -Wa,--trap
2008-10-23 20:27:57 +04:00
cflags-$(CONFIG_CPU_R5500) += $( call cc-option,-march= r5500,-march= r5000) \
-Wa,--trap
2006-04-01 23:43:58 +04:00
cflags-$(CONFIG_CPU_NEVADA) += $( call cc-option,-march= rm5200,-march= r5000) \
2005-04-17 02:20:36 +04:00
-Wa,--trap
2006-03-08 14:35:00 +03:00
cflags-$(CONFIG_CPU_RM7000) += $( call cc-option,-march= rm7000,-march= r5000) \
2005-04-17 02:20:36 +04:00
-Wa,--trap
2014-06-29 03:59:35 +04:00
cflags-$(CONFIG_CPU_SB1) += $( call cc-option,-march= sb1,-march= r5000) \
2005-04-17 02:20:36 +04:00
-Wa,--trap
2014-06-29 03:59:35 +04:00
cflags-$(CONFIG_CPU_SB1) += $( call cc-option,-mno-mdmx)
cflags-$(CONFIG_CPU_SB1) += $( call cc-option,-mno-mips3d)
2006-03-08 14:35:00 +03:00
cflags-$(CONFIG_CPU_R10000) += $( call cc-option,-march= r10000,-march= r8000) \
2005-04-17 02:20:36 +04:00
-Wa,--trap
2008-12-12 02:33:28 +03:00
cflags-$(CONFIG_CPU_CAVIUM_OCTEON) += $( call cc-option,-march= octeon) -Wa,--trap
i f e q ( , $( findstring march =octeon , $ ( cflags -$ ( CONFIG_CPU_CAVIUM_OCTEON ) ) ) )
cflags-$(CONFIG_CPU_CAVIUM_OCTEON) += -Wa,-march= octeon
e n d i f
2010-10-08 03:03:53 +04:00
cflags-$(CONFIG_CAVIUM_CN63XXP1) += -Wa,-mfix-cn63xxp1
2011-11-16 05:25:40 +04:00
cflags-$(CONFIG_CPU_BMIPS) += -march= mips32 -Wa,-mips32 -Wa,--trap
2005-04-17 02:20:36 +04:00
2007-10-23 15:43:11 +04:00
cflags-$(CONFIG_CPU_R4000_WORKAROUNDS) += $( call cc-option,-mfix-r4000,)
cflags-$(CONFIG_CPU_R4400_WORKAROUNDS) += $( call cc-option,-mfix-r4400,)
cflags-$(CONFIG_CPU_DADDI_WORKAROUNDS) += $( call cc-option,-mno-daddi,)
2015-02-02 18:41:01 +03:00
# For smartmips configurations, there are hundreds of warnings due to ISA overrides
# in assembly and header files. smartmips is only supported for MIPS32r1 onwards
# and there is no support for 64-bit. Various '.set mips2' or '.set mips3' or
# similar directives in the kernel will spam the build logs with the following warnings:
# Warning: the `smartmips' extension requires MIPS32 revision 1 or greater
# or
# Warning: the 64-bit MIPS architecture does not support the `smartmips' extension
# Pass -Wa,--no-warn to disable all assembler warnings until the kernel code has
# been fixed properly.
2015-04-02 16:42:52 +03:00
mips-cflags := $( cflags-y)
i f e q ( $( CONFIG_CPU_HAS_SMARTMIPS ) , y )
smartmips-ase := $( call cc-option-yn,$( mips-cflags) -msmartmips)
cflags-$(smartmips-ase) += -msmartmips -Wa,--no-warn
e n d i f
i f e q ( $( CONFIG_CPU_MICROMIPS ) , y )
micromips-ase := $( call cc-option-yn,$( mips-cflags) -mmicromips)
cflags-$(micromips-ase) += -mmicromips
e n d i f
2015-02-02 18:41:01 +03:00
i f e q ( $( CONFIG_CPU_HAS_MSA ) , y )
2015-04-02 16:42:52 +03:00
toolchain-msa := $( call cc-option-yn,$( mips-cflags) -mhard-float -mfp64 -Wa$( comma) -mmsa)
2015-02-02 18:41:01 +03:00
cflags-$(toolchain-msa) += -DTOOLCHAIN_SUPPORTS_MSA
e n d i f
2016-05-16 14:50:04 +03:00
toolchain-virt := $( call cc-option-yn,$( mips-cflags) -mvirt)
cflags-$(toolchain-virt) += -DTOOLCHAIN_SUPPORTS_VIRT
2017-11-22 14:30:30 +03:00
# For -mmicromips, use -Wa,-fatal-warnings to catch unsupported -mxpa which
# only warns
xpa-cflags-y := $( mips-cflags)
xpa-cflags-$(micromips-ase) += -mmicromips -Wa$( comma) -fatal-warnings
toolchain-xpa := $( call cc-option-yn,$( xpa-cflags-y) -mxpa)
cflags-$(toolchain-xpa) += -DTOOLCHAIN_SUPPORTS_XPA
2018-02-10 01:11:06 +03:00
toolchain-crc := $( call cc-option-yn,$( mips-cflags) -Wa$( comma) -mcrc)
cflags-$(toolchain-crc) += -DTOOLCHAIN_SUPPORTS_CRC
2018-10-15 21:26:12 +03:00
toolchain-dsp := $( call cc-option-yn,$( mips-cflags) -Wa$( comma) -mdsp)
cflags-$(toolchain-dsp) += -DTOOLCHAIN_SUPPORTS_DSP
2019-02-02 04:43:27 +03:00
toolchain-ginv := $( call cc-option-yn,$( mips-cflags) -Wa$( comma) -mginv)
cflags-$(toolchain-ginv) += -DTOOLCHAIN_SUPPORTS_GINV
2015-02-02 18:41:01 +03:00
2005-04-17 02:20:36 +04:00
#
# Firmware support
#
2012-11-15 23:48:50 +04:00
libs-$(CONFIG_FW_ARC) += arch/mips/fw/arc/
libs-$(CONFIG_FW_CFE) += arch/mips/fw/cfe/
libs-$(CONFIG_FW_SNIPROM) += arch/mips/fw/sni/
2008-01-05 01:31:07 +03:00
libs-y += arch/mips/fw/lib/
2005-04-17 02:20:36 +04:00
2010-02-26 15:57:12 +03:00
#
# Kernel compression
#
2018-01-16 06:29:54 +03:00
i f d e f C O N F I G _ S Y S _ S U P P O R T S _ Z B O O T
2010-02-26 15:57:12 +03:00
COMPRESSION_FNAME = vmlinuz
e l s e
COMPRESSION_FNAME = vmlinux
e n d i f
2005-04-17 02:20:36 +04:00
#
# Board-dependent options and extra files
#
2015-03-27 14:43:36 +03:00
i n c l u d e a r c h / m i p s / K b u i l d . p l a t f o r m s
2009-06-24 13:12:57 +04:00
2012-10-25 18:23:31 +04:00
i f d e f C O N F I G _ P H Y S I C A L _ S T A R T
2013-01-22 15:59:30 +04:00
load-y = $( CONFIG_PHYSICAL_START)
2012-10-25 18:23:31 +04:00
e n d i f
2017-08-08 02:16:47 +03:00
2018-08-29 21:01:30 +03:00
entry-y = $( shell $( objtree) /arch/mips/tools/elf-entry vmlinux)
2008-09-16 21:48:51 +04:00
cflags-y += -I$( srctree) /arch/mips/include/asm/mach-generic
2005-04-17 02:20:36 +04:00
drivers-$(CONFIG_PCI) += arch/mips/pci/
2007-02-15 14:06:48 +03:00
#
# Automatically detect the build format. By default we choose
# the elf format according to the load address.
# We can always force a build with a 64-bits symbol format by
2007-02-15 16:21:36 +03:00
# passing 'KBUILD_SYM32=no' option to the make's command line.
2007-02-15 14:06:48 +03:00
#
i f d e f C O N F I G _ 6 4 B I T
2007-02-15 16:21:36 +03:00
ifndef KBUILD_SYM32
2007-02-15 14:06:48 +03:00
ifeq ( $( shell expr $( load-y) \< 0xffffffff80000000) , 0)
2007-02-15 16:21:36 +03:00
KBUILD_SYM32 = y
2007-02-15 14:06:48 +03:00
endif
endif
2007-10-23 15:43:11 +04:00
ifeq ( $( KBUILD_SYM32) $( call cc-option-yn,-msym32) , yy)
cflags-y += -msym32 -DKBUILD_64BIT_SYM32
else
ifeq ( $( CONFIG_CPU_DADDI_WORKAROUNDS) , y)
$( error CONFIG_CPU_DADDI_WORKAROUNDS unsupported without -msym32)
2007-09-27 18:26:40 +04:00
endif
2007-02-15 14:06:48 +03:00
endif
e n d i f
2007-10-15 23:59:31 +04:00
KBUILD_AFLAGS += $( cflags-y)
2009-09-20 14:28:22 +04:00
KBUILD_CFLAGS += $( cflags-y)
2012-05-10 16:22:10 +04:00
KBUILD_CPPFLAGS += -DVMLINUX_LOAD_ADDRESS= $( load-y)
KBUILD_CPPFLAGS += -DDATAOFFSET= $( if $( dataoffset-y) ,$( dataoffset-y) ,0)
2005-04-17 02:20:36 +04:00
2013-08-30 19:42:41 +04:00
bootvars-y = VMLINUX_LOAD_ADDRESS = $( load-y) \
2016-10-05 20:18:19 +03:00
VMLINUX_ENTRY_ADDRESS = $( entry-y) \
2017-08-08 01:37:21 +03:00
PLATFORM = " $( platform-y) " \
ITS_INPUTS = " $( its-y) "
2016-10-05 20:18:20 +03:00
i f d e f C O N F I G _ 3 2 B I T
bootvars-y += ADDR_BITS = 32
e n d i f
i f d e f C O N F I G _ 6 4 B I T
bootvars-y += ADDR_BITS = 64
e n d i f
2013-08-30 19:42:41 +04:00
2017-08-10 21:27:39 +03:00
# This is required to get dwarf unwinding tables into .debug_frame
# instead of .eh_frame so we don't discard them.
KBUILD_CFLAGS += -fno-asynchronous-unwind-tables
2018-08-24 02:20:39 +03:00
KBUILD_LDFLAGS += -m $( ld-emul)
2005-04-17 02:20:36 +04:00
2006-03-08 14:35:00 +03:00
i f d e f C O N F I G _ M I P S
2012-10-02 18:42:36 +04:00
CHECKFLAGS += $( shell $( CC) $( KBUILD_CFLAGS) -dM -E -x c /dev/null | \
2007-01-23 21:30:14 +03:00
egrep -vw '__GNUC_(|MINOR_|PATCHLEVEL_)_' | \
2015-05-11 23:37:05 +03:00
sed -e "s/^\#define /-D'/" -e "s/ /'='/" -e " s/ $$ /'/ " -e 's/\$$/&&/g' )
2006-03-08 14:35:00 +03:00
e n d i f
2005-04-17 02:20:36 +04:00
OBJCOPYFLAGS += --remove-section= .reginfo
2012-05-03 13:02:55 +04:00
head-y := arch/mips/kernel/head.o
2005-04-17 02:20:36 +04:00
libs-y += arch/mips/lib/
2018-11-08 02:14:10 +03:00
libs-$(CONFIG_MIPS_FP_SUPPORT) += arch/mips/math-emu/
2005-04-17 02:20:36 +04:00
2010-05-30 15:27:22 +04:00
# See arch/mips/Kbuild for content of core part of the kernel
core-y += arch/mips/
2005-04-17 02:20:36 +04:00
2019-11-08 15:22:17 +03:00
drivers-y += arch/mips/crypto/
2005-04-17 02:20:36 +04:00
drivers-$(CONFIG_OPROFILE) += arch/mips/oprofile/
2009-06-04 16:27:10 +04:00
# suspend and hibernation support
drivers-$(CONFIG_PM) += arch/mips/power/
2013-08-30 19:42:40 +04:00
# boot image targets (arch/mips/boot/)
boot-y := vmlinux.bin
boot-y += vmlinux.ecoff
boot-y += vmlinux.srec
2013-08-30 19:42:42 +04:00
i f e q ( $( shell expr $ ( load -y ) \< 0xffffffff 80000000 2> /dev /null ) , 0 )
boot-y += uImage
2015-02-16 18:13:11 +03:00
boot-y += uImage.bin
boot-y += uImage.bz2
2013-08-30 19:42:42 +04:00
boot-y += uImage.gz
2015-02-16 18:13:11 +03:00
boot-y += uImage.lzma
boot-y += uImage.lzo
2013-08-30 19:42:42 +04:00
e n d i f
2016-10-05 20:18:19 +03:00
boot-y += vmlinux.itb
boot-y += vmlinux.gz.itb
boot-y += vmlinux.bz2.itb
boot-y += vmlinux.lzma.itb
boot-y += vmlinux.lzo.itb
2013-08-30 19:42:40 +04:00
# compressed boot image targets (arch/mips/boot/compressed/)
bootz-y := vmlinuz
bootz-y += vmlinuz.bin
bootz-y += vmlinuz.ecoff
bootz-y += vmlinuz.srec
2016-10-31 17:19:55 +03:00
i f e q ( $( shell expr $ ( zload -y ) \< 0xffffffff 80000000 2> /dev /null ) , 0 )
bootz-y += uzImage.bin
e n d i f
2013-08-30 19:42:40 +04:00
2007-08-22 00:34:16 +04:00
i f d e f C O N F I G _ L A S A T
rom.bin rom.sw : vmlinux
2013-08-30 19:42:41 +04:00
$( Q) $( MAKE) $( build) = arch/mips/lasat/image \
$( bootvars-y) $@
2007-08-22 00:34:16 +04:00
e n d i f
2005-04-17 02:20:36 +04:00
#
# Some machines like the Indy need 32-bit ELF binaries for booting purposes.
# Other need ECOFF, so we build a 32-bit ELF binary for them which we then
# convert to ECOFF using elf2ecoff.
#
2010-11-09 19:26:34 +03:00
quiet_cmd_32 = OBJCOPY $@
cmd_32 = $( OBJCOPY) -O $( 32bit-bfd) $( OBJCOPYFLAGS) $< $@
2005-04-17 02:20:36 +04:00
vmlinux.32 : vmlinux
2010-11-09 19:26:34 +03:00
$( call cmd,32)
2005-04-17 02:20:36 +04:00
#
# The 64-bit ELF tools are pretty broken so at this time we generate 64-bit
# ELF files from 32-bit files by conversion.
#
2010-11-09 19:26:34 +03:00
quiet_cmd_64 = OBJCOPY $@
cmd_64 = $( OBJCOPY) -O $( 64bit-bfd) $( OBJCOPYFLAGS) $< $@
2005-04-17 02:20:36 +04:00
vmlinux.64 : vmlinux
2010-11-09 19:26:34 +03:00
$( call cmd,64)
2005-04-17 02:20:36 +04:00
2019-06-13 11:52:50 +03:00
all : $( all -y ) $( KBUILD_DTBS )
2005-04-17 02:20:36 +04:00
2010-05-30 18:28:03 +04:00
# boot
2013-08-30 19:42:40 +04:00
$(boot-y) : $( vmlinux -32) FORCE
2013-08-30 19:42:41 +04:00
$( Q) $( MAKE) $( build) = arch/mips/boot VMLINUX = $( vmlinux-32) \
$( bootvars-y) arch/mips/boot/$@
2005-04-17 02:20:36 +04:00
2013-09-11 14:34:48 +04:00
i f d e f C O N F I G _ S Y S _ S U P P O R T S _ Z B O O T
2010-05-30 18:28:03 +04:00
# boot/compressed
2013-08-30 19:42:40 +04:00
$(bootz-y) : $( vmlinux -32) FORCE
2010-05-30 18:28:03 +04:00
$( Q) $( MAKE) $( build) = arch/mips/boot/compressed \
2013-08-30 19:42:41 +04:00
$( bootvars-y) 32bit-bfd= $( 32bit-bfd) $@
2013-09-11 14:34:48 +04:00
e l s e
vmlinuz : FORCE
@echo ' CONFIG_SYS_SUPPORTS_ZBOOT is not enabled'
/bin/false
e n d i f
2010-05-30 18:28:03 +04:00
2010-05-30 18:28:31 +04:00
CLEAN_FILES += vmlinux.32 vmlinux.64
2005-04-17 02:20:36 +04:00
2014-08-22 00:04:20 +04:00
# device-trees
2018-01-11 00:19:37 +03:00
core-y += arch/mips/boot/dts/
2014-08-22 00:04:21 +04:00
2007-05-29 19:38:07 +04:00
archprepare :
i f d e f C O N F I G _ M I P S 3 2 _ N 3 2
2017-01-17 18:18:37 +03:00
@$( kecho) ' Checking missing-syscalls for N32'
2011-11-08 22:20:10 +04:00
$( Q) $( MAKE) $( build) = . missing-syscalls missing_syscalls_flags = "-mabi=n32"
2007-05-29 19:38:07 +04:00
e n d i f
i f d e f C O N F I G _ M I P S 3 2 _ O 3 2
2017-01-17 18:18:37 +03:00
@$( kecho) ' Checking missing-syscalls for O32'
2011-11-08 22:20:10 +04:00
$( Q) $( MAKE) $( build) = . missing-syscalls missing_syscalls_flags = "-mabi=32"
2007-05-29 19:38:07 +04:00
e n d i f
2009-03-30 16:49:40 +04:00
install :
$( Q) install -D -m 755 vmlinux $( INSTALL_PATH) /vmlinux-$( KERNELRELEASE)
2011-06-21 20:58:55 +04:00
i f d e f C O N F I G _ S Y S _ S U P P O R T S _ Z B O O T
2009-10-14 14:12:16 +04:00
$( Q) install -D -m 755 vmlinuz $( INSTALL_PATH) /vmlinuz-$( KERNELRELEASE)
2011-06-21 20:58:55 +04:00
e n d i f
2009-03-30 16:49:40 +04:00
$( Q) install -D -m 644 .config $( INSTALL_PATH) /config-$( KERNELRELEASE)
$( Q) install -D -m 644 System.map $( INSTALL_PATH) /System.map-$( KERNELRELEASE)
2005-04-17 02:20:36 +04:00
archclean :
2010-05-30 18:28:31 +04:00
$( Q) $( MAKE) $( clean) = arch/mips/boot
$( Q) $( MAKE) $( clean) = arch/mips/boot/compressed
2016-03-31 12:05:33 +03:00
$( Q) $( MAKE) $( clean) = arch/mips/boot/tools
2010-05-30 18:28:31 +04:00
$( Q) $( MAKE) $( clean) = arch/mips/lasat
2005-04-17 02:20:36 +04:00
2018-12-13 12:07:39 +03:00
archheaders :
$( Q) $( MAKE) $( build) = arch/mips/kernel/syscalls all
2007-07-28 16:38:49 +04:00
d e f i n e a r c h h e l p
2009-03-30 16:49:40 +04:00
echo ' install - install kernel into $(INSTALL_PATH)'
2007-07-28 16:38:49 +04:00
echo ' vmlinux.ecoff - ECOFF boot image'
echo ' vmlinux.bin - Raw binary boot image'
echo ' vmlinux.srec - SREC boot image'
2014-10-08 05:33:04 +04:00
echo ' vmlinux.32 - 64-bit boot image wrapped in 32bits (IP22/IP32)'
2009-10-14 14:12:16 +04:00
echo ' vmlinuz - Compressed boot(zboot) image'
echo ' vmlinuz.ecoff - ECOFF zboot image'
echo ' vmlinuz.bin - Raw binary zboot image'
echo ' vmlinuz.srec - SREC zboot image'
2013-08-30 19:42:42 +04:00
echo ' uImage - U-Boot image'
2015-02-16 18:13:11 +03:00
echo ' uImage.bin - U-Boot image (uncompressed)'
echo ' uImage.bz2 - U-Boot image (bz2)'
2013-08-30 19:42:42 +04:00
echo ' uImage.gz - U-Boot image (gzip)'
2015-02-16 18:13:11 +03:00
echo ' uImage.lzma - U-Boot image (lzma)'
echo ' uImage.lzo - U-Boot image (lzo)'
2016-10-31 17:19:55 +03:00
echo ' uzImage.bin - U-Boot image (self-extracting)'
2007-07-28 16:38:49 +04:00
echo
2011-03-31 05:57:33 +04:00
echo ' These will be default as appropriate for a configured platform.'
2016-10-05 20:18:20 +03:00
echo
echo ' If you are targeting a system supported by generic kernels you may'
echo ' configure the kernel for a given architecture target like so:'
echo
echo ' {micro32,32,64}{r1,r2,r6}{el,}_defconfig <BOARDS="list of boards">'
echo
2018-02-09 19:11:58 +03:00
echo ' Where BOARDS is some subset of the following:'
for board in $( sort $( BOARDS) ) ; do echo " $$ {board} " ; done
echo
echo ' Specifically the following generic default configurations are'
echo ' supported:'
echo
$( foreach cfg,$( generic_defconfigs) ,
printf " %-24s - Build generic kernel for $( call describe_generic_defconfig,$( cfg) ) \n " $( cfg) ; )
echo
echo ' The following legacy default configurations have been converted to'
echo ' generic and can still be used:'
echo
$( foreach cfg,$( sort $( legacy_defconfigs) ) ,
printf " %-24s - Build $( $( cfg) -y) \n " $( cfg) ; )
echo
2016-10-05 20:18:20 +03:00
echo ' Otherwise, the following default configurations are available:'
2007-07-28 16:38:49 +04:00
e n d e f
2016-10-05 20:18:20 +03:00
generic_config_dir = $( srctree) /arch/$( ARCH) /configs/generic
generic_defconfigs :=
#
# If the user generates a generic kernel configuration without specifying a
# list of boards to include the config fragments for, default to including all
# available board config fragments.
#
i f e q ( $( BOARDS ) , )
BOARDS = $( patsubst board-%.config,%,$( notdir $( wildcard $( generic_config_dir) /board-*.config) ) )
e n d i f
#
# Generic kernel configurations which merge generic_defconfig with the
# appropriate config fragments from arch/mips/configs/generic/, resulting in
# the ability to easily configure the kernel for a given architecture,
# endianness & set of boards without duplicating the needed configuration in
# hundreds of defconfig files.
#
d e f i n e g e n _ g e n e r i c _ d e f c o n f i g s
$( foreach bits ,$ ( 1) ,$ ( foreach rev ,$ ( 2) ,$ ( foreach endian ,$ ( 3) ,
target := $( bits) $( rev) $( filter el,$( endian) ) _defconfig
generic_defconfigs += $$ ( target)
$$ (target) : $( generic_config_dir ) /$( bits ) $( rev ) .config
$$ (target) : $( generic_config_dir ) /$( endian ) .config
) ) )
e n d e f
$( eval $ ( call gen_generic_defconfigs ,32 64,r 1 r 2 r 6,eb el ) )
$( eval $ ( call gen_generic_defconfigs ,micro 32,r 2,eb el ) )
2018-02-09 19:11:58 +03:00
d e f i n e d e s c r i b e _ g e n e r i c _ d e f c o n f i g
$( subst 32r ,MIPS 32 r ,$ ( subst 64r ,MIPS 64 r ,$ ( subst el , little endian ,$ ( patsubst %_defconfig ,%,$ ( 1) ) ) ) )
e n d e f
2016-10-05 20:18:20 +03:00
.PHONY : $( generic_defconfigs )
$(generic_defconfigs) :
$( Q) $( CONFIG_SHELL) $( srctree) /scripts/kconfig/merge_config.sh \
2017-08-08 02:01:12 +03:00
-m -O $( objtree) $( srctree) /arch/$( ARCH) /configs/generic_defconfig $^ | \
grep -Ev '^#'
$( Q) cp $( KCONFIG_CONFIG) $( objtree) /.config.$@
$( Q) $( MAKE) -f $( srctree) /Makefile olddefconfig \
KCONFIG_CONFIG = $( objtree) /.config.$@ >/dev/null
$( Q) $( CONFIG_SHELL) $( srctree) /arch/$( ARCH) /tools/generic-board-config.sh \
$( srctree) $( objtree) $( objtree) /.config.$@ $( KCONFIG_CONFIG) \
" $( origin BOARDS) " $( BOARDS)
2017-03-13 17:57:14 +03:00
$( Q) $( MAKE) -f $( srctree) /Makefile olddefconfig
2016-10-05 20:18:20 +03:00
#
# Prevent generic merge_config rules attempting to merge single fragments
#
$(generic_config_dir)/%.config : ;
2016-10-05 20:18:21 +03:00
2017-08-08 02:01:15 +03:00
#
# Prevent direct use of generic_defconfig, which is intended to be used as the
# basis of the various ISA-specific targets generated above.
#
.PHONY : generic_defconfig
generic_defconfig :
$( Q) echo "generic_defconfig is not intended for direct use, but should instead be"
$( Q) echo "used via an ISA-specific target from the following list:"
$( Q) echo
$( Q) for cfg in $( generic_defconfigs) ; do echo " $$ {cfg} " ; done
$( Q) echo
$( Q) false
2016-10-05 20:18:21 +03:00
#
# Legacy defconfig compatibility - these targets used to be real defconfigs but
# now that the boards have been converted to use the generic kernel they are
# wrappers around the generic rules above.
#
2018-03-20 16:08:00 +03:00
legacy_defconfigs += ocelot_defconfig
ocelot_defconfig-y := 32r2el_defconfig BOARDS = ocelot
2018-02-09 19:11:56 +03:00
legacy_defconfigs += sead3_defconfig
sead3_defconfig-y := 32r2el_defconfig BOARDS = sead-3
2016-10-05 20:18:21 +03:00
2018-02-09 19:11:56 +03:00
legacy_defconfigs += sead3micro_defconfig
sead3micro_defconfig-y := micro32r2el_defconfig BOARDS = sead-3
2017-03-31 12:00:42 +03:00
2018-02-09 19:11:56 +03:00
legacy_defconfigs += xilfpga_defconfig
xilfpga_defconfig-y := 32r2el_defconfig BOARDS = xilfpga
.PHONY : $( legacy_defconfigs )
$(legacy_defconfigs) :
$( Q) $( MAKE) -f $( srctree) /Makefile $( $@ -y)