xref: /linux/arch/arc/Makefile (revision d2912cb15bdda8ba4a5dd73396ad62641af2f520)
1*d2912cb1SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
2cfdbc2e1SVineet Gupta#
3cfdbc2e1SVineet Gupta# Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
4cfdbc2e1SVineet Gupta#
5cfdbc2e1SVineet Gupta
6b7cc40c3SKevin HilmanKBUILD_DEFCONFIG := nsim_hs_defconfig
7cfdbc2e1SVineet Gupta
874c11e30SAlexey Brodkincflags-y	+= -fno-common -pipe -fno-builtin -mmedium-calls -D__linux__
940b8ad8fSVineet Guptacflags-$(CONFIG_ISA_ARCOMPACT)	+= -mA7
1000a99339SVineet Guptacflags-$(CONFIG_ISA_ARCV2)	+= -mcpu=hs38
11cfdbc2e1SVineet Gupta
12080c3747SVineet Guptaifdef CONFIG_ARC_CURR_IN_REG
13080c3747SVineet Gupta# For a global register defintion, make sure it gets passed to every file
14080c3747SVineet Gupta# We had a customer reported bug where some code built in kernel was NOT using
15080c3747SVineet Gupta# any kernel headers, and missing the r25 global register
168235703eSVineet Gupta# Can't do unconditionally because of recursive include issues
17080c3747SVineet Gupta# due to <linux/thread_info.h>
18080c3747SVineet GuptaLINUXINCLUDE	+=  -include ${src}/arch/arc/include/asm/current.h
19080c3747SVineet Guptaendif
20080c3747SVineet Gupta
212b52e2a6SMasahiro Yamadacflags-y				+= -fsection-anchors
22cfdbc2e1SVineet Gupta
2376a08404SVineet Guptacflags-$(CONFIG_ARC_HAS_LLSC)		+= -mlock
2476a08404SVineet Guptacflags-$(CONFIG_ARC_HAS_SWAPE)		+= -mswape
2576a08404SVineet Gupta
26d05a76abSAlexey Brodkinifdef CONFIG_ISA_ARCV2
27d05a76abSAlexey Brodkin
2876551468SEugeniy Paltsevifdef CONFIG_ARC_USE_UNALIGNED_MEM_ACCESS
2976551468SEugeniy Paltsevcflags-y				+= -munaligned-access
3076551468SEugeniy Paltsevelse
3176551468SEugeniy Paltsevcflags-y				+= -mno-unaligned-access
3276551468SEugeniy Paltsevendif
3376551468SEugeniy Paltsev
341f6ccfffSVineet Guptaifndef CONFIG_ARC_HAS_LL64
35d05a76abSAlexey Brodkincflags-y				+= -mno-ll64
36d05a76abSAlexey Brodkinendif
37d05a76abSAlexey Brodkin
38d05a76abSAlexey Brodkinifndef CONFIG_ARC_HAS_DIV_REM
39d05a76abSAlexey Brodkincflags-y				+= -mno-div-rem
40d05a76abSAlexey Brodkinendif
41d05a76abSAlexey Brodkin
421f6ccfffSVineet Guptaendif
431f6ccfffSVineet Gupta
445a205a32SVineet Guptacfi := $(call as-instr,.cfi_startproc\n.cfi_endproc,-DARC_DW2_UNWIND_AS_CFI)
455a205a32SVineet Guptacflags-$(CONFIG_ARC_DW2_UNWIND)		+= -fasynchronous-unwind-tables $(cfi)
466716dbbdSVineet Gupta
47cfdbc2e1SVineet Guptaifndef CONFIG_CC_OPTIMIZE_FOR_SIZE
48cfdbc2e1SVineet Gupta# Generic build system uses -O2, we want -O3
4997709069SVineet Gupta# Note: No need to add to cflags-y as that happens anyways
50a76bcf55SArnd Bergmann#
51a76bcf55SArnd Bergmann# Disable the false maybe-uninitialized warings gcc spits out at -O3
52a76bcf55SArnd BergmannARCH_CFLAGS += -O3 $(call cc-disable-warning,maybe-uninitialized,)
53cfdbc2e1SVineet Guptaendif
54cfdbc2e1SVineet Gupta
55cfdbc2e1SVineet Gupta# small data is default for elf32 tool-chain. If not usable, disable it
56cfdbc2e1SVineet Gupta# This also allows repurposing GP as scratch reg to gcc reg allocator
57cfdbc2e1SVineet Guptadisable_small_data := y
58cfdbc2e1SVineet Guptacflags-$(disable_small_data)		+= -mno-sdata -fcall-used-gp
59cfdbc2e1SVineet Gupta
60cfdbc2e1SVineet Guptacflags-$(CONFIG_CPU_BIG_ENDIAN)		+= -mbig-endian
61cfdbc2e1SVineet Guptaldflags-$(CONFIG_CPU_BIG_ENDIAN)	+= -EB
62cfdbc2e1SVineet Gupta
6340660f1fSAlexey BrodkinLIBGCC	= $(shell $(CC) $(cflags-y) --print-libgcc-file-name)
64cfdbc2e1SVineet Gupta
65cfdbc2e1SVineet Gupta# Modules with short calls might break for calls into builtin-kernel
6607fd7d4bSVineet GuptaKBUILD_CFLAGS_MODULE	+= -mlong-calls -mno-millicode
67cfdbc2e1SVineet Gupta
68cfdbc2e1SVineet Gupta# Finally dump eveything into kernel build system
69cfdbc2e1SVineet GuptaKBUILD_CFLAGS	+= $(cflags-y)
70cfdbc2e1SVineet GuptaKBUILD_AFLAGS	+= $(KBUILD_CFLAGS)
71d503ac53SMasahiro YamadaKBUILD_LDFLAGS	+= $(ldflags-y)
72cfdbc2e1SVineet Gupta
73cfdbc2e1SVineet Guptahead-y		:= arch/arc/kernel/head.o
74cfdbc2e1SVineet Gupta
75cfdbc2e1SVineet Gupta# See arch/arc/Kbuild for content of core part of the kernel
76cfdbc2e1SVineet Guptacore-y		+= arch/arc/
77cfdbc2e1SVineet Gupta
78999159a5SVineet Gupta# w/o this dtb won't embed into kernel binary
79999159a5SVineet Guptacore-y		+= arch/arc/boot/dts/
80999159a5SVineet Gupta
8133460f86SVineet Guptacore-y				+= arch/arc/plat-sim/
82072eb693SChristian Ruppertcore-$(CONFIG_ARC_PLAT_TB10X)	+= arch/arc/plat-tb10x/
83556cc1c5SAlexey Brodkincore-$(CONFIG_ARC_PLAT_AXS10X)	+= arch/arc/plat-axs10x/
8496665789SNoam Camuscore-$(CONFIG_ARC_PLAT_EZNPS)	+= arch/arc/plat-eznps/
85a518d637SAlexey Brodkincore-$(CONFIG_ARC_SOC_HSDK)	+= arch/arc/plat-hsdk/
8696665789SNoam Camus
8796665789SNoam Camusifdef CONFIG_ARC_PLAT_EZNPS
8896665789SNoam CamusKBUILD_CPPFLAGS += -I$(srctree)/arch/arc/plat-eznps/include
8996665789SNoam Camusendif
90cfdbc2e1SVineet Gupta
91769bc1fdSVineet Guptadrivers-$(CONFIG_OPROFILE)	+= arch/arc/oprofile/
92769bc1fdSVineet Gupta
93cfdbc2e1SVineet Guptalibs-y		+= arch/arc/lib/ $(LIBGCC)
94cfdbc2e1SVineet Gupta
95fb0990bbSVineet Guptaboot		:= arch/arc/boot
96fb0990bbSVineet Gupta
972547476aSAndrea Gelmini#default target for make without any arguments.
985e40f0fdSMichal MarekKBUILD_IMAGE	:= $(boot)/bootpImage
99cfdbc2e1SVineet Gupta
1005e40f0fdSMichal Marekall:	bootpImage
101cfdbc2e1SVineet GuptabootpImage: vmlinux
102cfdbc2e1SVineet Gupta
103104058edSVineet Guptaboot_targets += uImage uImage.bin uImage.gz
104104058edSVineet Gupta
105104058edSVineet Gupta$(boot_targets): vmlinux
106cfdbc2e1SVineet Gupta	$(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
107cfdbc2e1SVineet Gupta
108cfdbc2e1SVineet Guptaarchclean:
109cfdbc2e1SVineet Gupta	$(Q)$(MAKE) $(clean)=$(boot)
110