1 # SPDX-License-Identifier: GPL-2.0 << 2 obj-$(CONFIG_RAID6_PQ) += raid6_pq.o 1 obj-$(CONFIG_RAID6_PQ) += raid6_pq.o 3 2 4 raid6_pq-y += algos.o recov.o tables.o in 3 raid6_pq-y += algos.o recov.o tables.o int1.o int2.o int4.o \ 5 int8.o !! 4 int8.o int16.o int32.o 6 5 7 raid6_pq-$(CONFIG_X86) += recov_ssse3.o recov_ 6 raid6_pq-$(CONFIG_X86) += recov_ssse3.o recov_avx2.o mmx.o sse1.o sse2.o avx2.o avx512.o recov_avx512.o 8 raid6_pq-$(CONFIG_ALTIVEC) += altivec1.o altiv !! 7 raid6_pq-$(CONFIG_ALTIVEC) += altivec1.o altivec2.o altivec4.o altivec8.o 9 vpermxor1.o vper !! 8 raid6_pq-$(CONFIG_KERNEL_MODE_NEON) += neon.o neon1.o neon2.o neon4.o neon8.o 10 raid6_pq-$(CONFIG_KERNEL_MODE_NEON) += neon.o !! 9 raid6_pq-$(CONFIG_TILEGX) += tilegx8.o 11 raid6_pq-$(CONFIG_S390) += s390vx8.o recov_s39 10 raid6_pq-$(CONFIG_S390) += s390vx8.o recov_s390xc.o 12 raid6_pq-$(CONFIG_LOONGARCH) += loongarch_simd << 13 11 14 hostprogs += mktables !! 12 hostprogs-y += mktables >> 13 >> 14 quiet_cmd_unroll = UNROLL $@ >> 15 cmd_unroll = $(AWK) -f$(srctree)/$(src)/unroll.awk -vN=$(UNROLL) \ >> 16 < $< > $@ || ( rm -f $@ && exit 1 ) 15 17 16 ifeq ($(CONFIG_ALTIVEC),y) 18 ifeq ($(CONFIG_ALTIVEC),y) 17 altivec_flags := -maltivec $(call cc-option,-m 19 altivec_flags := -maltivec $(call cc-option,-mabi=altivec) 18 # Enable <altivec.h> !! 20 endif 19 altivec_flags += -isystem $(shell $(CC) -print << 20 21 21 ifdef CONFIG_CC_IS_CLANG !! 22 # The GCC option -ffreestanding is required in order to compile code containing 22 # clang ppc port does not yet support -maltive !! 23 # ARM/NEON intrinsics in a non C99-compliant environment (such as the kernel) 23 # enabled. A future release of clang will reso !! 24 ifeq ($(CONFIG_KERNEL_MODE_NEON),y) 24 # https://llvm.org/pr31177 !! 25 NEON_FLAGS := -ffreestanding 25 CFLAGS_REMOVE_altivec1.o += -msoft-float !! 26 ifeq ($(ARCH),arm) 26 CFLAGS_REMOVE_altivec2.o += -msoft-float !! 27 NEON_FLAGS += -mfloat-abi=softfp -mfpu=neon 27 CFLAGS_REMOVE_altivec4.o += -msoft-float !! 28 endif 28 CFLAGS_REMOVE_altivec8.o += -msoft-float !! 29 ifeq ($(ARCH),arm64) 29 CFLAGS_REMOVE_vpermxor1.o += -msoft-float !! 30 CFLAGS_REMOVE_neon1.o += -mgeneral-regs-only 30 CFLAGS_REMOVE_vpermxor2.o += -msoft-float !! 31 CFLAGS_REMOVE_neon2.o += -mgeneral-regs-only 31 CFLAGS_REMOVE_vpermxor4.o += -msoft-float !! 32 CFLAGS_REMOVE_neon4.o += -mgeneral-regs-only 32 CFLAGS_REMOVE_vpermxor8.o += -msoft-float !! 33 CFLAGS_REMOVE_neon8.o += -mgeneral-regs-only 33 endif 34 endif 34 endif 35 endif 35 36 36 quiet_cmd_unroll = UNROLL $@ !! 37 targets += int1.c 37 cmd_unroll = $(AWK) -v N=$* -f $(src)/un !! 38 $(obj)/int1.c: UNROLL := 1 >> 39 $(obj)/int1.c: $(src)/int.uc $(src)/unroll.awk FORCE >> 40 $(call if_changed,unroll) >> 41 >> 42 targets += int2.c >> 43 $(obj)/int2.c: UNROLL := 2 >> 44 $(obj)/int2.c: $(src)/int.uc $(src)/unroll.awk FORCE >> 45 $(call if_changed,unroll) >> 46 >> 47 targets += int4.c >> 48 $(obj)/int4.c: UNROLL := 4 >> 49 $(obj)/int4.c: $(src)/int.uc $(src)/unroll.awk FORCE >> 50 $(call if_changed,unroll) >> 51 >> 52 targets += int8.c >> 53 $(obj)/int8.c: UNROLL := 8 >> 54 $(obj)/int8.c: $(src)/int.uc $(src)/unroll.awk FORCE >> 55 $(call if_changed,unroll) >> 56 >> 57 targets += int16.c >> 58 $(obj)/int16.c: UNROLL := 16 >> 59 $(obj)/int16.c: $(src)/int.uc $(src)/unroll.awk FORCE >> 60 $(call if_changed,unroll) 38 61 39 targets += int1.c int2.c int4.c int8.c !! 62 targets += int32.c 40 $(obj)/int%.c: $(src)/int.uc $(src)/unroll.awk !! 63 $(obj)/int32.c: UNROLL := 32 >> 64 $(obj)/int32.c: $(src)/int.uc $(src)/unroll.awk FORCE 41 $(call if_changed,unroll) 65 $(call if_changed,unroll) 42 66 43 CFLAGS_altivec1.o += $(altivec_flags) 67 CFLAGS_altivec1.o += $(altivec_flags) >> 68 targets += altivec1.c >> 69 $(obj)/altivec1.c: UNROLL := 1 >> 70 $(obj)/altivec1.c: $(src)/altivec.uc $(src)/unroll.awk FORCE >> 71 $(call if_changed,unroll) >> 72 44 CFLAGS_altivec2.o += $(altivec_flags) 73 CFLAGS_altivec2.o += $(altivec_flags) >> 74 targets += altivec2.c >> 75 $(obj)/altivec2.c: UNROLL := 2 >> 76 $(obj)/altivec2.c: $(src)/altivec.uc $(src)/unroll.awk FORCE >> 77 $(call if_changed,unroll) >> 78 45 CFLAGS_altivec4.o += $(altivec_flags) 79 CFLAGS_altivec4.o += $(altivec_flags) >> 80 targets += altivec4.c >> 81 $(obj)/altivec4.c: UNROLL := 4 >> 82 $(obj)/altivec4.c: $(src)/altivec.uc $(src)/unroll.awk FORCE >> 83 $(call if_changed,unroll) >> 84 46 CFLAGS_altivec8.o += $(altivec_flags) 85 CFLAGS_altivec8.o += $(altivec_flags) 47 targets += altivec1.c altivec2.c altivec4.c al !! 86 targets += altivec8.c 48 $(obj)/altivec%.c: $(src)/altivec.uc $(src)/un !! 87 $(obj)/altivec8.c: UNROLL := 8 >> 88 $(obj)/altivec8.c: $(src)/altivec.uc $(src)/unroll.awk FORCE >> 89 $(call if_changed,unroll) >> 90 >> 91 CFLAGS_neon1.o += $(NEON_FLAGS) >> 92 targets += neon1.c >> 93 $(obj)/neon1.c: UNROLL := 1 >> 94 $(obj)/neon1.c: $(src)/neon.uc $(src)/unroll.awk FORCE >> 95 $(call if_changed,unroll) >> 96 >> 97 CFLAGS_neon2.o += $(NEON_FLAGS) >> 98 targets += neon2.c >> 99 $(obj)/neon2.c: UNROLL := 2 >> 100 $(obj)/neon2.c: $(src)/neon.uc $(src)/unroll.awk FORCE >> 101 $(call if_changed,unroll) >> 102 >> 103 CFLAGS_neon4.o += $(NEON_FLAGS) >> 104 targets += neon4.c >> 105 $(obj)/neon4.c: UNROLL := 4 >> 106 $(obj)/neon4.c: $(src)/neon.uc $(src)/unroll.awk FORCE >> 107 $(call if_changed,unroll) >> 108 >> 109 CFLAGS_neon8.o += $(NEON_FLAGS) >> 110 targets += neon8.c >> 111 $(obj)/neon8.c: UNROLL := 8 >> 112 $(obj)/neon8.c: $(src)/neon.uc $(src)/unroll.awk FORCE 49 $(call if_changed,unroll) 113 $(call if_changed,unroll) 50 114 51 CFLAGS_vpermxor1.o += $(altivec_flags) !! 115 targets += tilegx8.c 52 CFLAGS_vpermxor2.o += $(altivec_flags) !! 116 $(obj)/tilegx8.c: UNROLL := 8 53 CFLAGS_vpermxor4.o += $(altivec_flags) !! 117 $(obj)/tilegx8.c: $(src)/tilegx.uc $(src)/unroll.awk FORCE 54 CFLAGS_vpermxor8.o += $(altivec_flags) << 55 targets += vpermxor1.c vpermxor2.c vpermxor4.c << 56 $(obj)/vpermxor%.c: $(src)/vpermxor.uc $(src)/ << 57 $(call if_changed,unroll) << 58 << 59 CFLAGS_neon1.o += $(CC_FLAGS_FPU) << 60 CFLAGS_neon2.o += $(CC_FLAGS_FPU) << 61 CFLAGS_neon4.o += $(CC_FLAGS_FPU) << 62 CFLAGS_neon8.o += $(CC_FLAGS_FPU) << 63 CFLAGS_recov_neon_inner.o += $(CC_FLAGS_FPU) << 64 CFLAGS_REMOVE_neon1.o += $(CC_FLAGS_NO_FPU) << 65 CFLAGS_REMOVE_neon2.o += $(CC_FLAGS_NO_FPU) << 66 CFLAGS_REMOVE_neon4.o += $(CC_FLAGS_NO_FPU) << 67 CFLAGS_REMOVE_neon8.o += $(CC_FLAGS_NO_FPU) << 68 CFLAGS_REMOVE_recov_neon_inner.o += $(CC_FLAGS << 69 targets += neon1.c neon2.c neon4.c neon8.c << 70 $(obj)/neon%.c: $(src)/neon.uc $(src)/unroll.a << 71 $(call if_changed,unroll) 118 $(call if_changed,unroll) 72 119 73 targets += s390vx8.c 120 targets += s390vx8.c 74 $(obj)/s390vx%.c: $(src)/s390vx.uc $(src)/unro !! 121 $(obj)/s390vx8.c: UNROLL := 8 >> 122 $(obj)/s390vx8.c: $(src)/s390vx.uc $(src)/unroll.awk FORCE 75 $(call if_changed,unroll) 123 $(call if_changed,unroll) 76 124 77 quiet_cmd_mktable = TABLE $@ 125 quiet_cmd_mktable = TABLE $@ 78 cmd_mktable = $(obj)/mktables > $@ !! 126 cmd_mktable = $(obj)/mktables > $@ || ( rm -f $@ && exit 1 ) 79 127 80 targets += tables.c 128 targets += tables.c 81 $(obj)/tables.c: $(obj)/mktables FORCE 129 $(obj)/tables.c: $(obj)/mktables FORCE 82 $(call if_changed,mktable) 130 $(call if_changed,mktable)
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.