mk: fix verbose pmdinfogen run
[dpdk.git] / mk / internal / rte.compile-pre.mk
index 87d2d93..9c25ff6 100644 (file)
@@ -84,28 +84,26 @@ C_TO_O = $(CC) -Wp,-MD,$(call obj2dep,$(@)).tmp $(CFLAGS) \
 C_TO_O_STR = $(subst ','\'',$(C_TO_O)) #'# fix syntax highlight
 C_TO_O_DISP = $(if $(V),"$(C_TO_O_STR)","  CC $(@)")
 endif
+PMDINFO_GEN = $(RTE_SDK_BIN)/app/pmdinfogen $@ $@.pmd.c
+PMDINFO_CC = $(CC) $(CFLAGS) -c -o $@.pmd.o $@.pmd.c
+PMDINFO_LD = $(CROSS)ld $(LDFLAGS) -r -o $@.o $@.pmd.o $@
+PMDINFO_TO_O = if grep -q 'PMD_REGISTER_DRIVER(.*)' $<; then \
+       echo "$(if $V,$(PMDINFO_GEN),  PMDINFO $@.pmd.c)" && \
+       $(PMDINFO_GEN) && \
+       echo "$(if $V,$(PMDINFO_CC),  CC $@.pmd.o)" && \
+       $(PMDINFO_CC) && \
+       echo "$(if $V,$(PMDINFO_LD),  LD $@)" && \
+       $(PMDINFO_LD) && \
+       mv -f $@.o $@; fi
 C_TO_O_CMD = 'cmd_$@ = $(C_TO_O_STR)'
 C_TO_O_DO = @set -e; \
        echo $(C_TO_O_DISP); \
        $(C_TO_O) && \
-       sh -c "grep -q \"PMD_REGISTER_DRIVER(.*)\" $<; \
-       if [ \$$? -eq 0 ]; then \
-               echo \"  PMDINFOGEN\" $@; \
-               OBJF=`readlink -f $@`; \
-               $(RTE_SDK_BIN)/app/pmdinfogen \$$OBJF \$$OBJF.pmd.c; \
-               if [ \$$? -eq 0 ]; \
-               then \
-                       echo \"  PMDINFOBUILD\" $@; \
-                       $(CC) $(CFLAGS) -c -o \$$OBJF.pmd.o \$$OBJF.pmd.c; \
-                       $(CROSS)ld $(LDFLAGS) -r -o \$$OBJF.o \$$OBJF.pmd.o \$$OBJF; \
-                       mv -f \$$OBJF.o \$$OBJF; \
-               fi; \
-       fi;" && \
+       $(PMDINFO_TO_O) && \
        echo $(C_TO_O_CMD) > $(call obj2cmd,$(@)) && \
        sed 's,'$@':,dep_'$@' =,' $(call obj2dep,$(@)).tmp > $(call obj2dep,$(@)) && \
        rm -f $(call obj2dep,$(@)).tmp
 
-
 # return an empty string if string are equal
 compare = $(strip $(subst $(1),,$(2)) $(subst $(2),,$(1)))