xref: /openbmc/linux/lib/raid6/Makefile (revision 13c520b2)
1f5e70d0fSDavid Woodhouseobj-$(CONFIG_RAID6_PQ)	+= raid6_pq.o
2f5e70d0fSDavid Woodhouse
34f8c55c5SYuanhan Liuraid6_pq-y	+= algos.o recov.o tables.o int1.o int2.o int4.o \
44f8c55c5SYuanhan Liu		   int8.o int16.o int32.o
54f8c55c5SYuanhan Liu
613c520b2SGayatri Kammelaraid6_pq-$(CONFIG_X86) += recov_ssse3.o recov_avx2.o mmx.o sse1.o sse2.o avx2.o avx512.o recov_avx512.o
74f8c55c5SYuanhan Liuraid6_pq-$(CONFIG_ALTIVEC) += altivec1.o altivec2.o altivec4.o altivec8.o
87d11965dSArd Biesheuvelraid6_pq-$(CONFIG_KERNEL_MODE_NEON) += neon.o neon1.o neon2.o neon4.o neon8.o
9ae77cbc1SKen Steeleraid6_pq-$(CONFIG_TILEGX) += tilegx8.o
104f8c55c5SYuanhan Liu
11f5e70d0fSDavid Woodhousehostprogs-y	+= mktables
12f5e70d0fSDavid Woodhouse
13f5e70d0fSDavid Woodhousequiet_cmd_unroll = UNROLL  $@
142144381dSDavid Woodhouse      cmd_unroll = $(AWK) -f$(srctree)/$(src)/unroll.awk -vN=$(UNROLL) \
15f5e70d0fSDavid Woodhouse                   < $< > $@ || ( rm -f $@ && exit 1 )
16f5e70d0fSDavid Woodhouse
17f5e70d0fSDavid Woodhouseifeq ($(CONFIG_ALTIVEC),y)
181fb3f5a7SAnton Blanchardaltivec_flags := -maltivec $(call cc-option,-mabi=altivec)
19f5e70d0fSDavid Woodhouseendif
20f5e70d0fSDavid Woodhouse
217d11965dSArd Biesheuvel# The GCC option -ffreestanding is required in order to compile code containing
227d11965dSArd Biesheuvel# ARM/NEON intrinsics in a non C99-compliant environment (such as the kernel)
237d11965dSArd Biesheuvelifeq ($(CONFIG_KERNEL_MODE_NEON),y)
247d11965dSArd BiesheuvelNEON_FLAGS := -ffreestanding
257d11965dSArd Biesheuvelifeq ($(ARCH),arm)
267d11965dSArd BiesheuvelNEON_FLAGS += -mfloat-abi=softfp -mfpu=neon
277d11965dSArd Biesheuvelendif
287d11965dSArd Biesheuvelifeq ($(ARCH),arm64)
297d11965dSArd BiesheuvelCFLAGS_REMOVE_neon1.o += -mgeneral-regs-only
307d11965dSArd BiesheuvelCFLAGS_REMOVE_neon2.o += -mgeneral-regs-only
317d11965dSArd BiesheuvelCFLAGS_REMOVE_neon4.o += -mgeneral-regs-only
327d11965dSArd BiesheuvelCFLAGS_REMOVE_neon8.o += -mgeneral-regs-only
337d11965dSArd Biesheuvelendif
347d11965dSArd Biesheuvelendif
357d11965dSArd Biesheuvel
36cc4589ebSDavid Woodhousetargets += int1.c
37cc4589ebSDavid Woodhouse$(obj)/int1.c:   UNROLL := 1
38cc4589ebSDavid Woodhouse$(obj)/int1.c:   $(src)/int.uc $(src)/unroll.awk FORCE
39f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
40f5e70d0fSDavid Woodhouse
41cc4589ebSDavid Woodhousetargets += int2.c
42cc4589ebSDavid Woodhouse$(obj)/int2.c:   UNROLL := 2
43cc4589ebSDavid Woodhouse$(obj)/int2.c:   $(src)/int.uc $(src)/unroll.awk FORCE
44f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
45f5e70d0fSDavid Woodhouse
46cc4589ebSDavid Woodhousetargets += int4.c
47cc4589ebSDavid Woodhouse$(obj)/int4.c:   UNROLL := 4
48cc4589ebSDavid Woodhouse$(obj)/int4.c:   $(src)/int.uc $(src)/unroll.awk FORCE
49f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
50f5e70d0fSDavid Woodhouse
51cc4589ebSDavid Woodhousetargets += int8.c
52cc4589ebSDavid Woodhouse$(obj)/int8.c:   UNROLL := 8
53cc4589ebSDavid Woodhouse$(obj)/int8.c:   $(src)/int.uc $(src)/unroll.awk FORCE
54f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
55f5e70d0fSDavid Woodhouse
56cc4589ebSDavid Woodhousetargets += int16.c
57cc4589ebSDavid Woodhouse$(obj)/int16.c:  UNROLL := 16
58cc4589ebSDavid Woodhouse$(obj)/int16.c:  $(src)/int.uc $(src)/unroll.awk FORCE
59f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
60f5e70d0fSDavid Woodhouse
61cc4589ebSDavid Woodhousetargets += int32.c
62cc4589ebSDavid Woodhouse$(obj)/int32.c:  UNROLL := 32
63cc4589ebSDavid Woodhouse$(obj)/int32.c:  $(src)/int.uc $(src)/unroll.awk FORCE
64f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
65f5e70d0fSDavid Woodhouse
66cc4589ebSDavid WoodhouseCFLAGS_altivec1.o += $(altivec_flags)
67cc4589ebSDavid Woodhousetargets += altivec1.c
68cc4589ebSDavid Woodhouse$(obj)/altivec1.c:   UNROLL := 1
69cc4589ebSDavid Woodhouse$(obj)/altivec1.c:   $(src)/altivec.uc $(src)/unroll.awk FORCE
70f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
71f5e70d0fSDavid Woodhouse
72cc4589ebSDavid WoodhouseCFLAGS_altivec2.o += $(altivec_flags)
73cc4589ebSDavid Woodhousetargets += altivec2.c
74cc4589ebSDavid Woodhouse$(obj)/altivec2.c:   UNROLL := 2
75cc4589ebSDavid Woodhouse$(obj)/altivec2.c:   $(src)/altivec.uc $(src)/unroll.awk FORCE
76f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
77f5e70d0fSDavid Woodhouse
78cc4589ebSDavid WoodhouseCFLAGS_altivec4.o += $(altivec_flags)
79cc4589ebSDavid Woodhousetargets += altivec4.c
80cc4589ebSDavid Woodhouse$(obj)/altivec4.c:   UNROLL := 4
81cc4589ebSDavid Woodhouse$(obj)/altivec4.c:   $(src)/altivec.uc $(src)/unroll.awk FORCE
82f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
83f5e70d0fSDavid Woodhouse
84cc4589ebSDavid WoodhouseCFLAGS_altivec8.o += $(altivec_flags)
85cc4589ebSDavid Woodhousetargets += altivec8.c
86cc4589ebSDavid Woodhouse$(obj)/altivec8.c:   UNROLL := 8
87cc4589ebSDavid Woodhouse$(obj)/altivec8.c:   $(src)/altivec.uc $(src)/unroll.awk FORCE
88f5e70d0fSDavid Woodhouse	$(call if_changed,unroll)
89f5e70d0fSDavid Woodhouse
907d11965dSArd BiesheuvelCFLAGS_neon1.o += $(NEON_FLAGS)
917d11965dSArd Biesheuveltargets += neon1.c
927d11965dSArd Biesheuvel$(obj)/neon1.c:   UNROLL := 1
937d11965dSArd Biesheuvel$(obj)/neon1.c:   $(src)/neon.uc $(src)/unroll.awk FORCE
947d11965dSArd Biesheuvel	$(call if_changed,unroll)
957d11965dSArd Biesheuvel
967d11965dSArd BiesheuvelCFLAGS_neon2.o += $(NEON_FLAGS)
977d11965dSArd Biesheuveltargets += neon2.c
987d11965dSArd Biesheuvel$(obj)/neon2.c:   UNROLL := 2
997d11965dSArd Biesheuvel$(obj)/neon2.c:   $(src)/neon.uc $(src)/unroll.awk FORCE
1007d11965dSArd Biesheuvel	$(call if_changed,unroll)
1017d11965dSArd Biesheuvel
1027d11965dSArd BiesheuvelCFLAGS_neon4.o += $(NEON_FLAGS)
1037d11965dSArd Biesheuveltargets += neon4.c
1047d11965dSArd Biesheuvel$(obj)/neon4.c:   UNROLL := 4
1057d11965dSArd Biesheuvel$(obj)/neon4.c:   $(src)/neon.uc $(src)/unroll.awk FORCE
1067d11965dSArd Biesheuvel	$(call if_changed,unroll)
1077d11965dSArd Biesheuvel
1087d11965dSArd BiesheuvelCFLAGS_neon8.o += $(NEON_FLAGS)
1097d11965dSArd Biesheuveltargets += neon8.c
1107d11965dSArd Biesheuvel$(obj)/neon8.c:   UNROLL := 8
1117d11965dSArd Biesheuvel$(obj)/neon8.c:   $(src)/neon.uc $(src)/unroll.awk FORCE
1127d11965dSArd Biesheuvel	$(call if_changed,unroll)
1137d11965dSArd Biesheuvel
114ae77cbc1SKen Steeletargets += tilegx8.c
115ae77cbc1SKen Steele$(obj)/tilegx8.c:   UNROLL := 8
116ae77cbc1SKen Steele$(obj)/tilegx8.c:   $(src)/tilegx.uc $(src)/unroll.awk FORCE
117ae77cbc1SKen Steele	$(call if_changed,unroll)
118ae77cbc1SKen Steele
119f5e70d0fSDavid Woodhousequiet_cmd_mktable = TABLE   $@
120f5e70d0fSDavid Woodhouse      cmd_mktable = $(obj)/mktables > $@ || ( rm -f $@ && exit 1 )
121f5e70d0fSDavid Woodhouse
122cc4589ebSDavid Woodhousetargets += tables.c
123cc4589ebSDavid Woodhouse$(obj)/tables.c: $(obj)/mktables FORCE
124f5e70d0fSDavid Woodhouse	$(call if_changed,mktable)
125