xref: /openbmc/linux/arch/x86/lib/Makefile (revision 40d04110f87940b6a03bf0aa19cd29e84f465f20)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
2583d0e90SSam Ravnborg#
3583d0e90SSam Ravnborg# Makefile for x86 specific library files.
4583d0e90SSam Ravnborg#
5583d0e90SSam Ravnborg
65c9a8750SDmitry Vyukov# Produces uninteresting flaky coverage.
75c9a8750SDmitry VyukovKCOV_INSTRUMENT_delay.o	:= n
85c9a8750SDmitry Vyukov
9*40d04110SMarco Elver# KCSAN uses udelay for introducing watchpoint delay; avoid recursion.
10*40d04110SMarco ElverKCSAN_SANITIZE_delay.o := n
11*40d04110SMarco Elver
12b51ce374SGary Hook# Early boot use of cmdline; don't instrument it
13b51ce374SGary Hookifdef CONFIG_AMD_MEM_ENCRYPT
14b51ce374SGary HookKCOV_INSTRUMENT_cmdline.o := n
15b51ce374SGary HookKASAN_SANITIZE_cmdline.o  := n
16*40d04110SMarco ElverKCSAN_SANITIZE_cmdline.o  := n
17b51ce374SGary Hook
18b51ce374SGary Hookifdef CONFIG_FUNCTION_TRACER
19b51ce374SGary HookCFLAGS_REMOVE_cmdline.o = -pg
20b51ce374SGary Hookendif
21b51ce374SGary Hook
22b51ce374SGary HookCFLAGS_cmdline.o := $(call cc-option, -fno-stack-protector)
23b51ce374SGary Hookendif
24b51ce374SGary Hook
25eb13296cSMasami Hiramatsuinat_tables_script = $(srctree)/arch/x86/tools/gen-insn-attr-x86.awk
26eb13296cSMasami Hiramatsuinat_tables_maps = $(srctree)/arch/x86/lib/x86-opcode-map.txt
27eb13296cSMasami Hiramatsuquiet_cmd_inat_tables = GEN     $@
28172caf19SMasahiro Yamada      cmd_inat_tables = $(AWK) -f $(inat_tables_script) $(inat_tables_maps) > $@
29eb13296cSMasami Hiramatsu
30eb13296cSMasami Hiramatsu$(obj)/inat-tables.c: $(inat_tables_script) $(inat_tables_maps)
31eb13296cSMasami Hiramatsu	$(call cmd,inat_tables)
32eb13296cSMasami Hiramatsu
33eb13296cSMasami Hiramatsu$(obj)/inat.o: $(obj)/inat-tables.c
34eb13296cSMasami Hiramatsu
35eb13296cSMasami Hiramatsuclean-files := inat-tables.c
36eb13296cSMasami Hiramatsu
37a7b480e7SBorislav Petkovobj-$(CONFIG_SMP) += msr-smp.o cache-smp.o
38583d0e90SSam Ravnborg
3999f925ceSBorislav Petkovlib-y := delay.o misc.o cmdline.o cpu.o
401ac2e6caSRobert Richterlib-y += usercopy_$(BITS).o usercopy.o getuser.o putuser.o
41583d0e90SSam Ravnborglib-y += memcpy_$(BITS).o
4232542ee2SRicardo Nerilib-$(CONFIG_INSTRUCTION_DECODER) += insn.o inat.o insn-eval.o
43d899a7d1SThomas Garnierlib-$(CONFIG_RANDOMIZE_BASE) += kaslr.o
44540adea3SMasami Hiramatsulib-$(CONFIG_FUNCTION_ERROR_INJECTION)	+= error-inject.o
4576b04384SDavid Woodhouselib-$(CONFIG_RETPOLINE) += retpoline.o
46583d0e90SSam Ravnborg
47f5967101SBorislav Petkovobj-y += msr.o msr-reg.o msr-reg-export.o hweight.o
48170d13caSLinus Torvaldsobj-y += iomem.o
4944f0257fSThomas Gleixner
5044f0257fSThomas Gleixnerifeq ($(CONFIG_X86_32),y)
511fde902dSIngo Molnar        obj-y += atomic64_32.o
52a7e926abSLuca Barbieri        lib-y += atomic64_cx8_32.o
53583d0e90SSam Ravnborg        lib-y += checksum_32.o
54583d0e90SSam Ravnborg        lib-y += strstr_32.o
554625cd63SJan Beulich        lib-y += string_32.o
5604edbdefSEric Dumazetifneq ($(CONFIG_X86_CMPXCHG64),y)
57a7e926abSLuca Barbieri        lib-y += cmpxchg8b_emu.o atomic64_386_32.o
5804edbdefSEric Dumazetendif
59583d0e90SSam Ravnborg        lib-$(CONFIG_X86_USE_3DNOW) += mmx_32.o
6044f0257fSThomas Gleixnerelse
616175ddf0SBrian Gerst        obj-y += iomap_copy_64.o
62583d0e90SSam Ravnborg        lib-y += csum-partial_64.o csum-copy_64.o csum-wrappers_64.o
63212be3b2SOleg Nesterov        lib-y += clear_page_64.o copy_page_64.o
64583d0e90SSam Ravnborg        lib-y += memmove_64.o memset_64.o
65b41e6ec2SBorislav Petkov        lib-y += copy_user_64.o
66b9ec40afSChristoph Lameter	lib-y += cmpxchg16b_emu.o
6744f0257fSThomas Gleixnerendif
68