xref: /openbmc/linux/arch/x86/lib/Makefile (revision f5d2313b)
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
940d04110SMarco Elver# KCSAN uses udelay for introducing watchpoint delay; avoid recursion.
1040d04110SMarco ElverKCSAN_SANITIZE_delay.o := n
11f5d2313bSMarco Elverifdef CONFIG_KCSAN
12f5d2313bSMarco Elver# In case KCSAN+lockdep+ftrace are enabled, disable ftrace for delay.o to avoid
13f5d2313bSMarco Elver# lockdep -> [other libs] -> KCSAN -> udelay -> ftrace -> lockdep recursion.
14f5d2313bSMarco ElverCFLAGS_REMOVE_delay.o = $(CC_FLAGS_FTRACE)
15f5d2313bSMarco Elverendif
1640d04110SMarco Elver
17b51ce374SGary Hook# Early boot use of cmdline; don't instrument it
18b51ce374SGary Hookifdef CONFIG_AMD_MEM_ENCRYPT
19b51ce374SGary HookKCOV_INSTRUMENT_cmdline.o := n
20b51ce374SGary HookKASAN_SANITIZE_cmdline.o  := n
2140d04110SMarco ElverKCSAN_SANITIZE_cmdline.o  := n
22b51ce374SGary Hook
23b51ce374SGary Hookifdef CONFIG_FUNCTION_TRACER
24b51ce374SGary HookCFLAGS_REMOVE_cmdline.o = -pg
25b51ce374SGary Hookendif
26b51ce374SGary Hook
27b51ce374SGary HookCFLAGS_cmdline.o := $(call cc-option, -fno-stack-protector)
28b51ce374SGary Hookendif
29b51ce374SGary Hook
30eb13296cSMasami Hiramatsuinat_tables_script = $(srctree)/arch/x86/tools/gen-insn-attr-x86.awk
31eb13296cSMasami Hiramatsuinat_tables_maps = $(srctree)/arch/x86/lib/x86-opcode-map.txt
32eb13296cSMasami Hiramatsuquiet_cmd_inat_tables = GEN     $@
33172caf19SMasahiro Yamada      cmd_inat_tables = $(AWK) -f $(inat_tables_script) $(inat_tables_maps) > $@
34eb13296cSMasami Hiramatsu
35eb13296cSMasami Hiramatsu$(obj)/inat-tables.c: $(inat_tables_script) $(inat_tables_maps)
36eb13296cSMasami Hiramatsu	$(call cmd,inat_tables)
37eb13296cSMasami Hiramatsu
38eb13296cSMasami Hiramatsu$(obj)/inat.o: $(obj)/inat-tables.c
39eb13296cSMasami Hiramatsu
40eb13296cSMasami Hiramatsuclean-files := inat-tables.c
41eb13296cSMasami Hiramatsu
42a7b480e7SBorislav Petkovobj-$(CONFIG_SMP) += msr-smp.o cache-smp.o
43583d0e90SSam Ravnborg
4499f925ceSBorislav Petkovlib-y := delay.o misc.o cmdline.o cpu.o
451ac2e6caSRobert Richterlib-y += usercopy_$(BITS).o usercopy.o getuser.o putuser.o
46583d0e90SSam Ravnborglib-y += memcpy_$(BITS).o
4732542ee2SRicardo Nerilib-$(CONFIG_INSTRUCTION_DECODER) += insn.o inat.o insn-eval.o
48d899a7d1SThomas Garnierlib-$(CONFIG_RANDOMIZE_BASE) += kaslr.o
49540adea3SMasami Hiramatsulib-$(CONFIG_FUNCTION_ERROR_INJECTION)	+= error-inject.o
5076b04384SDavid Woodhouselib-$(CONFIG_RETPOLINE) += retpoline.o
51583d0e90SSam Ravnborg
52f5967101SBorislav Petkovobj-y += msr.o msr-reg.o msr-reg-export.o hweight.o
53170d13caSLinus Torvaldsobj-y += iomem.o
5444f0257fSThomas Gleixner
5544f0257fSThomas Gleixnerifeq ($(CONFIG_X86_32),y)
561fde902dSIngo Molnar        obj-y += atomic64_32.o
57a7e926abSLuca Barbieri        lib-y += atomic64_cx8_32.o
58583d0e90SSam Ravnborg        lib-y += checksum_32.o
59583d0e90SSam Ravnborg        lib-y += strstr_32.o
604625cd63SJan Beulich        lib-y += string_32.o
6104edbdefSEric Dumazetifneq ($(CONFIG_X86_CMPXCHG64),y)
62a7e926abSLuca Barbieri        lib-y += cmpxchg8b_emu.o atomic64_386_32.o
6304edbdefSEric Dumazetendif
64583d0e90SSam Ravnborg        lib-$(CONFIG_X86_USE_3DNOW) += mmx_32.o
6544f0257fSThomas Gleixnerelse
666175ddf0SBrian Gerst        obj-y += iomap_copy_64.o
67583d0e90SSam Ravnborg        lib-y += csum-partial_64.o csum-copy_64.o csum-wrappers_64.o
68212be3b2SOleg Nesterov        lib-y += clear_page_64.o copy_page_64.o
69583d0e90SSam Ravnborg        lib-y += memmove_64.o memset_64.o
70b41e6ec2SBorislav Petkov        lib-y += copy_user_64.o
71b9ec40afSChristoph Lameter	lib-y += cmpxchg16b_emu.o
7244f0257fSThomas Gleixnerendif
73