Re: [PATCH 2/2] lib/raid6: refactor unroll rules with pattern rules
From: Masahiro Yamada
Date: Thu Jun 20 2019 - 12:01:49 EST
On Mon, Jun 17, 2019 at 2:49 AM Masahiro Yamada
<yamada.masahiro@xxxxxxxxxxxxx> wrote:
>
> This Makefile repeats very similar rules.
>
> Let's use pattern rules. $(UNROLL) can be replaced with $*.
>
> No intended change in behavior.
>
> Signed-off-by: Masahiro Yamada <yamada.masahiro@xxxxxxxxxxxxx>
> ---
Applied to linux-kbuild.
>
> lib/raid6/Makefile | 97 ++++++----------------------------------------
> 1 file changed, 11 insertions(+), 86 deletions(-)
>
> diff --git a/lib/raid6/Makefile b/lib/raid6/Makefile
> index 74004037033f..42695bc8d451 100644
> --- a/lib/raid6/Makefile
> +++ b/lib/raid6/Makefile
> @@ -12,9 +12,6 @@ raid6_pq-$(CONFIG_S390) += s390vx8.o recov_s390xc.o
>
> hostprogs-y += mktables
>
> -quiet_cmd_unroll = UNROLL $@
> - cmd_unroll = $(AWK) -f$(srctree)/$(src)/unroll.awk -vN=$(UNROLL) < $< > $@
> -
> ifeq ($(CONFIG_ALTIVEC),y)
> altivec_flags := -maltivec $(call cc-option,-mabi=altivec)
>
> @@ -50,111 +47,39 @@ CFLAGS_REMOVE_neon8.o += -mgeneral-regs-only
> endif
> endif
>
> -targets += int1.c
> -$(obj)/int1.c: UNROLL := 1
> -$(obj)/int1.c: $(src)/int.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> -targets += int2.c
> -$(obj)/int2.c: UNROLL := 2
> -$(obj)/int2.c: $(src)/int.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> -targets += int4.c
> -$(obj)/int4.c: UNROLL := 4
> -$(obj)/int4.c: $(src)/int.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> -targets += int8.c
> -$(obj)/int8.c: UNROLL := 8
> -$(obj)/int8.c: $(src)/int.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> -targets += int16.c
> -$(obj)/int16.c: UNROLL := 16
> -$(obj)/int16.c: $(src)/int.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> +quiet_cmd_unroll = UNROLL $@
> + cmd_unroll = $(AWK) -f$(srctree)/$(src)/unroll.awk -vN=$* < $< > $@
>
> -targets += int32.c
> -$(obj)/int32.c: UNROLL := 32
> -$(obj)/int32.c: $(src)/int.uc $(src)/unroll.awk FORCE
> +targets += int1.c int2.c int4.c int8.c int16.c int32.c
> +$(obj)/int%.c: $(src)/int.uc $(src)/unroll.awk FORCE
> $(call if_changed,unroll)
>
> CFLAGS_altivec1.o += $(altivec_flags)
> -targets += altivec1.c
> -$(obj)/altivec1.c: UNROLL := 1
> -$(obj)/altivec1.c: $(src)/altivec.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_altivec2.o += $(altivec_flags)
> -targets += altivec2.c
> -$(obj)/altivec2.c: UNROLL := 2
> -$(obj)/altivec2.c: $(src)/altivec.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_altivec4.o += $(altivec_flags)
> -targets += altivec4.c
> -$(obj)/altivec4.c: UNROLL := 4
> -$(obj)/altivec4.c: $(src)/altivec.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_altivec8.o += $(altivec_flags)
> -targets += altivec8.c
> -$(obj)/altivec8.c: UNROLL := 8
> -$(obj)/altivec8.c: $(src)/altivec.uc $(src)/unroll.awk FORCE
> +targets += altivec1.c altivec2.c altivec4.c altivec8.c
> +$(obj)/altivec%.c: $(src)/altivec.uc $(src)/unroll.awk FORCE
> $(call if_changed,unroll)
>
> CFLAGS_vpermxor1.o += $(altivec_flags)
> -targets += vpermxor1.c
> -$(obj)/vpermxor1.c: UNROLL := 1
> -$(obj)/vpermxor1.c: $(src)/vpermxor.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_vpermxor2.o += $(altivec_flags)
> -targets += vpermxor2.c
> -$(obj)/vpermxor2.c: UNROLL := 2
> -$(obj)/vpermxor2.c: $(src)/vpermxor.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_vpermxor4.o += $(altivec_flags)
> -targets += vpermxor4.c
> -$(obj)/vpermxor4.c: UNROLL := 4
> -$(obj)/vpermxor4.c: $(src)/vpermxor.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_vpermxor8.o += $(altivec_flags)
> -targets += vpermxor8.c
> -$(obj)/vpermxor8.c: UNROLL := 8
> -$(obj)/vpermxor8.c: $(src)/vpermxor.uc $(src)/unroll.awk FORCE
> +targets += vpermxor1.o vpermxor2.o vpermxor4.o vpermxor8.o
> +$(obj)/vpermxor%.c: $(src)/vpermxor.uc $(src)/unroll.awk FORCE
> $(call if_changed,unroll)
>
> CFLAGS_neon1.o += $(NEON_FLAGS)
> -targets += neon1.c
> -$(obj)/neon1.c: UNROLL := 1
> -$(obj)/neon1.c: $(src)/neon.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_neon2.o += $(NEON_FLAGS)
> -targets += neon2.c
> -$(obj)/neon2.c: UNROLL := 2
> -$(obj)/neon2.c: $(src)/neon.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_neon4.o += $(NEON_FLAGS)
> -targets += neon4.c
> -$(obj)/neon4.c: UNROLL := 4
> -$(obj)/neon4.c: $(src)/neon.uc $(src)/unroll.awk FORCE
> - $(call if_changed,unroll)
> -
> CFLAGS_neon8.o += $(NEON_FLAGS)
> -targets += neon8.c
> -$(obj)/neon8.c: UNROLL := 8
> -$(obj)/neon8.c: $(src)/neon.uc $(src)/unroll.awk FORCE
> +targets += neon1.c neon2.c neon4.c neon8.c
> +$(obj)/neon%.c: $(src)/neon.uc $(src)/unroll.awk FORCE
> $(call if_changed,unroll)
>
> targets += s390vx8.c
> -$(obj)/s390vx8.c: UNROLL := 8
> -$(obj)/s390vx8.c: $(src)/s390vx.uc $(src)/unroll.awk FORCE
> +$(obj)/s390vx%.c: $(src)/s390vx.uc $(src)/unroll.awk FORCE
> $(call if_changed,unroll)
>
> quiet_cmd_mktable = TABLE $@
> --
> 2.17.1
>
--
Best Regards
Masahiro Yamada