1*3626738bSChristoph Hellwig# SPDX-License-Identifier: GPL-2.0 2*3626738bSChristoph Hellwig 3*3626738bSChristoph Hellwigccflags-y += -I $(src) 4*3626738bSChristoph Hellwig 5*3626738bSChristoph Hellwigobj-$(CONFIG_RAID6_PQ) += raid6_pq.o tests/ 6*3626738bSChristoph Hellwig 7*3626738bSChristoph Hellwigraid6_pq-y += algos.o tables.o 8*3626738bSChristoph Hellwig 9*3626738bSChristoph Hellwig# generic integer generation and recovery implementation 10*3626738bSChristoph Hellwigraid6_pq-y += int1.o int2.o int4.o int8.o 11*3626738bSChristoph Hellwigraid6_pq-y += recov.o 12*3626738bSChristoph Hellwig 13*3626738bSChristoph Hellwig# architecture-specific generation and recovery implementations: 14*3626738bSChristoph Hellwigraid6_pq-$(CONFIG_KERNEL_MODE_NEON) += arm/neon.o \ 15*3626738bSChristoph Hellwig arm/neon1.o \ 16*3626738bSChristoph Hellwig arm/neon2.o \ 17*3626738bSChristoph Hellwig arm/neon4.o \ 18*3626738bSChristoph Hellwig arm/neon8.o \ 19*3626738bSChristoph Hellwig arm/recov_neon.o \ 20*3626738bSChristoph Hellwig arm/recov_neon_inner.o 21*3626738bSChristoph Hellwigraid6_pq-$(CONFIG_LOONGARCH) += loongarch/loongarch_simd.o \ 22*3626738bSChristoph Hellwig loongarch/recov_loongarch_simd.o 23*3626738bSChristoph Hellwigraid6_pq-$(CONFIG_ALTIVEC) += powerpc/altivec1.o \ 24*3626738bSChristoph Hellwig powerpc/altivec2.o \ 25*3626738bSChristoph Hellwig powerpc/altivec4.o \ 26*3626738bSChristoph Hellwig powerpc/altivec8.o \ 27*3626738bSChristoph Hellwig powerpc/vpermxor1.o \ 28*3626738bSChristoph Hellwig powerpc/vpermxor2.o \ 29*3626738bSChristoph Hellwig powerpc/vpermxor4.o \ 30*3626738bSChristoph Hellwig powerpc/vpermxor8.o 31*3626738bSChristoph Hellwigraid6_pq-$(CONFIG_RISCV_ISA_V) += riscv/rvv.o \ 32*3626738bSChristoph Hellwig riscv/recov_rvv.o 33*3626738bSChristoph Hellwigraid6_pq-$(CONFIG_S390) += s390/s390vx8.o \ 34*3626738bSChristoph Hellwig s390/recov_s390xc.o 35*3626738bSChristoph Hellwigifeq ($(CONFIG_X86),y) 36*3626738bSChristoph Hellwigraid6_pq-$(CONFIG_X86_32) += x86/mmx.o \ 37*3626738bSChristoph Hellwig x86/sse1.o 38*3626738bSChristoph Hellwigendif 39*3626738bSChristoph Hellwigraid6_pq-$(CONFIG_X86) += x86/sse2.o \ 40*3626738bSChristoph Hellwig x86/avx2.o \ 41*3626738bSChristoph Hellwig x86/avx512.o \ 42*3626738bSChristoph Hellwig x86/recov_ssse3.o \ 43*3626738bSChristoph Hellwig x86/recov_avx2.o \ 44*3626738bSChristoph Hellwig x86/recov_avx512.o 45*3626738bSChristoph Hellwig 46*3626738bSChristoph Hellwighostprogs += mktables 47*3626738bSChristoph Hellwig 48*3626738bSChristoph HellwigCFLAGS_arm/neon1.o += $(CC_FLAGS_FPU) 49*3626738bSChristoph HellwigCFLAGS_arm/neon2.o += $(CC_FLAGS_FPU) 50*3626738bSChristoph HellwigCFLAGS_arm/neon4.o += $(CC_FLAGS_FPU) 51*3626738bSChristoph HellwigCFLAGS_arm/neon8.o += $(CC_FLAGS_FPU) 52*3626738bSChristoph HellwigCFLAGS_arm/recov_neon_inner.o += $(CC_FLAGS_FPU) 53*3626738bSChristoph HellwigCFLAGS_REMOVE_arm/neon1.o += $(CC_FLAGS_NO_FPU) 54*3626738bSChristoph HellwigCFLAGS_REMOVE_arm/neon2.o += $(CC_FLAGS_NO_FPU) 55*3626738bSChristoph HellwigCFLAGS_REMOVE_arm/neon4.o += $(CC_FLAGS_NO_FPU) 56*3626738bSChristoph HellwigCFLAGS_REMOVE_arm/neon8.o += $(CC_FLAGS_NO_FPU) 57*3626738bSChristoph HellwigCFLAGS_REMOVE_arm/recov_neon_inner.o += $(CC_FLAGS_NO_FPU) 58*3626738bSChristoph Hellwig 59*3626738bSChristoph Hellwigifeq ($(CONFIG_ALTIVEC),y) 60*3626738bSChristoph Hellwigaltivec_flags := -maltivec $(call cc-option,-mabi=altivec) 61*3626738bSChristoph Hellwig# Enable <altivec.h> 62*3626738bSChristoph Hellwigaltivec_flags += -isystem $(shell $(CC) -print-file-name=include) 63*3626738bSChristoph Hellwig 64*3626738bSChristoph HellwigCFLAGS_powerpc/altivec1.o += $(altivec_flags) 65*3626738bSChristoph HellwigCFLAGS_powerpc/altivec2.o += $(altivec_flags) 66*3626738bSChristoph HellwigCFLAGS_powerpc/altivec4.o += $(altivec_flags) 67*3626738bSChristoph HellwigCFLAGS_powerpc/altivec8.o += $(altivec_flags) 68*3626738bSChristoph HellwigCFLAGS_powerpc/vpermxor1.o += $(altivec_flags) 69*3626738bSChristoph HellwigCFLAGS_powerpc/vpermxor2.o += $(altivec_flags) 70*3626738bSChristoph HellwigCFLAGS_powerpc/vpermxor4.o += $(altivec_flags) 71*3626738bSChristoph HellwigCFLAGS_powerpc/vpermxor8.o += $(altivec_flags) 72*3626738bSChristoph Hellwig 73*3626738bSChristoph Hellwigifdef CONFIG_CC_IS_CLANG 74*3626738bSChristoph Hellwig# clang ppc port does not yet support -maltivec when -msoft-float is 75*3626738bSChristoph Hellwig# enabled. A future release of clang will resolve this 76*3626738bSChristoph Hellwig# https://llvm.org/pr31177 77*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/altivec1.o += -msoft-float 78*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/altivec2.o += -msoft-float 79*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/altivec4.o += -msoft-float 80*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/altivec8.o += -msoft-float 81*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/vpermxor1.o += -msoft-float 82*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/vpermxor2.o += -msoft-float 83*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/vpermxor4.o += -msoft-float 84*3626738bSChristoph HellwigCFLAGS_REMOVE_powerpc/vpermxor8.o += -msoft-float 85*3626738bSChristoph Hellwigendif # CONFIG_CC_IS_CLANG 86*3626738bSChristoph Hellwigendif # CONFIG_ALTIVEC 87*3626738bSChristoph Hellwig 88*3626738bSChristoph Hellwigquiet_cmd_mktable = TABLE $@ 89*3626738bSChristoph Hellwig cmd_mktable = $(obj)/mktables > $@ 90*3626738bSChristoph Hellwig 91*3626738bSChristoph Hellwigtargets += tables.c 92*3626738bSChristoph Hellwig$(obj)/tables.c: $(obj)/mktables FORCE 93*3626738bSChristoph Hellwig $(call if_changed,mktable) 94*3626738bSChristoph Hellwig 95*3626738bSChristoph Hellwigquiet_cmd_unroll = UNROLL $@ 96*3626738bSChristoph Hellwig cmd_unroll = $(AWK) -v N=$* -f $(src)/unroll.awk < $< > $@ 97*3626738bSChristoph Hellwig 98*3626738bSChristoph Hellwigtargets += int1.c int2.c int4.c int8.c 99*3626738bSChristoph Hellwig$(obj)/int%.c: $(src)/int.uc $(src)/unroll.awk FORCE 100*3626738bSChristoph Hellwig $(call if_changed,unroll) 101*3626738bSChristoph Hellwig 102*3626738bSChristoph Hellwigtargets += arm/neon1.c arm/neon2.c arm/neon4.c arm/neon8.c 103*3626738bSChristoph Hellwig$(obj)/arm/neon%.c: $(src)/arm/neon.uc $(src)/unroll.awk FORCE 104*3626738bSChristoph Hellwig $(call if_changed,unroll) 105*3626738bSChristoph Hellwig 106*3626738bSChristoph Hellwigtargets += powerpc/altivec1.c \ 107*3626738bSChristoph Hellwig powerpc/altivec2.c \ 108*3626738bSChristoph Hellwig powerpc/altivec4.c \ 109*3626738bSChristoph Hellwig powerpc/altivec8.c 110*3626738bSChristoph Hellwig$(obj)/powerpc/altivec%.c: $(src)/powerpc/altivec.uc $(src)/unroll.awk FORCE 111*3626738bSChristoph Hellwig $(call if_changed,unroll) 112*3626738bSChristoph Hellwig 113*3626738bSChristoph Hellwigtargets += powerpc/vpermxor1.c \ 114*3626738bSChristoph Hellwig powerpc/vpermxor2.c \ 115*3626738bSChristoph Hellwig powerpc/vpermxor4.c \ 116*3626738bSChristoph Hellwig powerpc/vpermxor8.c 117*3626738bSChristoph Hellwig$(obj)/powerpc/vpermxor%.c: $(src)/powerpc/vpermxor.uc $(src)/unroll.awk FORCE 118*3626738bSChristoph Hellwig $(call if_changed,unroll) 119*3626738bSChristoph Hellwig 120*3626738bSChristoph Hellwigtargets += s390/s390vx8.c 121*3626738bSChristoph Hellwig$(obj)/s390/s390vx%.c: $(src)/s390/s390vx.uc $(src)/unroll.awk FORCE 122*3626738bSChristoph Hellwig $(call if_changed,unroll) 123