1 # SPDX-License-Identifier: GPL-2.0 << 2 # 1 # 3 # Makefile for ppc-specific library files.. !! 2 # Makefile for alpha-specific library files.. 4 # 3 # 5 4 6 CFLAGS_code-patching.o += -fno-stack-protector !! 5 asflags-y := $(KBUILD_CFLAGS) 7 CFLAGS_feature-fixups.o += -fno-stack-protecto !! 6 ccflags-y := -Werror 8 7 9 CFLAGS_REMOVE_code-patching.o = $(CC_FLAGS_FTR !! 8 # Many of these routines have implementations tuned for ev6. 10 CFLAGS_REMOVE_feature-fixups.o = $(CC_FLAGS_FT !! 9 # Choose them iff we're targeting ev6 specifically. 11 !! 10 ev6-$(CONFIG_ALPHA_EV6) := ev6- 12 KASAN_SANITIZE_code-patching.o := n !! 11 13 KASAN_SANITIZE_feature-fixups.o := n !! 12 # Several make use of the cttz instruction introduced in ev67. 14 # restart_table.o contains functions called in !! 13 ev67-$(CONFIG_ALPHA_EV67) := ev67- 15 # which can be in real mode. Disable KASAN. !! 14 16 KASAN_SANITIZE_restart_table.o := n !! 15 lib-y = __divqu.o __remqu.o __divlu.o __remlu.o \ 17 KCSAN_SANITIZE_code-patching.o := n !! 16 udelay.o \ 18 KCSAN_SANITIZE_feature-fixups.o := n !! 17 $(ev6-y)memset.o \ 19 !! 18 $(ev6-y)memcpy.o \ 20 ifdef CONFIG_KASAN !! 19 memmove.o \ 21 CFLAGS_code-patching.o += -DDISABLE_BRANCH_PRO !! 20 checksum.o \ 22 CFLAGS_feature-fixups.o += -DDISABLE_BRANCH_PR !! 21 csum_partial_copy.o \ 23 endif !! 22 $(ev67-y)strlen.o \ 24 !! 23 $(ev67-y)strcat.o \ 25 CFLAGS_code-patching.o += $(DISABLE_LATENT_ENT !! 24 strcpy.o \ 26 CFLAGS_feature-fixups.o += $(DISABLE_LATENT_EN !! 25 $(ev67-y)strncat.o \ 27 !! 26 strncpy.o \ 28 obj-y += code-patching.o feature-fixups.o pmem !! 27 $(ev6-y)stxcpy.o \ 29 !! 28 $(ev6-y)stxncpy.o \ 30 obj-$(CONFIG_CODE_PATCHING_SELFTEST) += test-c !! 29 $(ev67-y)strchr.o \ 31 !! 30 $(ev67-y)strrchr.o \ 32 ifndef CONFIG_KASAN !! 31 $(ev6-y)memchr.o \ 33 obj-y += string.o memcmp_$(BITS).o !! 32 $(ev6-y)copy_user.o \ 34 obj-$(CONFIG_PPC32) += strlen_32.o !! 33 $(ev6-y)clear_user.o \ 35 endif !! 34 $(ev6-y)csum_ipv6_magic.o \ 36 !! 35 $(ev6-y)clear_page.o \ 37 obj-$(CONFIG_PPC32) += div64.o copy_32.o c !! 36 $(ev6-y)copy_page.o \ 38 !! 37 fpreg.o \ 39 obj-$(CONFIG_FUNCTION_ERROR_INJECTION) += err !! 38 callback_srm.o srm_puts.o srm_printk.o \ 40 !! 39 fls.o 41 # See corresponding test in arch/powerpc/Makef !! 40 42 # 64-bit linker creates .sfpr on demand for fi !! 41 lib-$(CONFIG_SMP) += dec_and_lock.o 43 # so it is only needed for modules, and only f !! 42 44 # do not support --save-restore-funcs !! 43 # The division routines are built from single source, with different defines. 45 ifndef CONFIG_LD_IS_BFD !! 44 AFLAGS___divqu.o = -DDIV 46 always-$(CONFIG_PPC64) += crtsavres.o !! 45 AFLAGS___remqu.o = -DREM 47 endif !! 46 AFLAGS___divlu.o = -DDIV -DINTSIZE 48 !! 47 AFLAGS___remlu.o = -DREM -DINTSIZE 49 obj-$(CONFIG_PPC_BOOK3S_64) += copyuser_power7 !! 48 50 memcpy_power7.o !! 49 $(obj)/__divqu.o: $(obj)/$(ev6-y)divide.S 51 !! 50 $(cmd_as_o_S) 52 obj64-y += copypage_64.o copyuser_64.o mem_64. !! 51 $(obj)/__remqu.o: $(obj)/$(ev6-y)divide.S 53 memcpy_64.o copy_mc_64.o !! 52 $(cmd_as_o_S) 54 !! 53 $(obj)/__divlu.o: $(obj)/$(ev6-y)divide.S 55 ifdef CONFIG_PPC_QUEUED_SPINLOCKS !! 54 $(cmd_as_o_S) 56 obj-$(CONFIG_SMP) += qspinlock.o !! 55 $(obj)/__remlu.o: $(obj)/$(ev6-y)divide.S 57 else !! 56 $(cmd_as_o_S) 58 obj64-$(CONFIG_SMP) += locks.o << 59 endif << 60 << 61 obj64-$(CONFIG_ALTIVEC) += vmx-helper.o << 62 obj64-$(CONFIG_KPROBES_SANITY_TEST) += tes << 63 tes << 64 << 65 obj-y += checksum_$(BITS).o << 66 string_$(BITS).o << 67 << 68 obj-y += sstep.o << 69 obj-$(CONFIG_PPC_FPU) += ldstfp.o << 70 obj64-y += quad.o << 71 << 72 obj-$(CONFIG_PPC_LIB_RHEAP) += rheap.o << 73 << 74 obj-$(CONFIG_FTR_FIXUP_SELFTEST) += feature-fi << 75 << 76 obj-$(CONFIG_ALTIVEC) += xor_vmx.o xor_vmx_g << 77 CFLAGS_xor_vmx.o += -mhard-float -maltivec $(c << 78 # Enable <altivec.h> << 79 CFLAGS_xor_vmx.o += -isystem $(shell $(CC) -pr << 80 << 81 obj-$(CONFIG_PPC64) += $(obj64-y) <<
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.