Fix libdpdk-dev headers path
[deb_dpdk.git] / debian / rules
index 640ed3a..42e58ba 100755 (executable)
@@ -1,29 +1,30 @@
 #!/usr/bin/make -f
 # See debhelper(7) (uncomment to enable)
 # output every command that modifies files on the build system.
-#export DH_VERBOSE = 1
+export DH_VERBOSE=1
+export DH_OPTIONS=-v
 
 VERSION := $(shell dpkg-parsechangelog | sed -nr '/^Version:/s/Version: (.*:)?(.*)-(.*)/\2/p')
 
 # see EXAMPLES in dpkg-buildflags(1) and read /usr/share/dpkg/*
-DPKG_EXPORT_BUILDFLAGS = 1
 include /usr/share/dpkg/default.mk
 
 DEB_HOST_GNU_CPU := $(shell dpkg-architecture -qDEB_HOST_GNU_CPU)
 
 # see FEATURE AREAS in dpkg-buildflags(1)
-export DEB_BUILD_MAINT_OPTIONS = hardening=+all
-
-# build with debug symbols, dh_strip will create -dgbsyms packages by that
-# also export -fPIC for the static build (already used by shared by default)
-export EXTRA_CFLAGS = -g -fPIC
+export DEB_BUILD_MAINT_OPTIONS = hardening=+all,-pie
 
 # see ENVIRONMENT in dpkg-buildflags(1)
 # package maintainers to append CFLAGS
-#export DEB_CFLAGS_MAINT_APPEND  = -Wall -pedantic
+export DEB_CFLAGS_MAINT_APPEND  = -fPIC
 # package maintainers to append LDFLAGS
 #export DEB_LDFLAGS_MAINT_APPEND = -Wl,--as-needed
 
+include /usr/share/dpkg/buildflags.mk
+export EXTRA_CFLAGS=$(CFLAGS)
+# need to be stripped as DPDK build system adds them and it would be -Wl,-Wl,opt
+export EXTRA_LDFLAGS=$(shell echo $(LDFLAGS) | sed 's/-Wl,//g')
+
 # People rebuilding this package can overwrite DPDK_CONFIG, RTE_MACHINE and
 # RTE_TARGET via environment variables if they like
 ifneq (,$(filter $(DEB_HOST_ARCH), arm64))
@@ -45,22 +46,26 @@ clean:
 
 build-config:
        dh_testdir
-       $(MAKE) O=$(DPDK_STATIC_DIR) T=$(DPDK_CONFIG) config
+       # report dpkg-buildflags status to build log
+       dpkg-buildflags --status
+       echo EXTRA_CFLAGS $$EXTRA_CFLAGS
+       echo EXTRA_LDFLAGS: $$EXTRA_LDFLAGS
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_STATIC_DIR) T=$(DPDK_CONFIG) config
        sed -ri -e 's,(RTE_MACHINE=).*,\1$(RTE_MACHINE),' \
-               -e 's,(RTE_NEXT_ABI=).*,\1n,' \
-                -e 's,(CONFIG_RTE_EAL_IGB_UIO=).*,\1n,' \
-                -e 's,(CONFIG_RTE_KNI_KMOD=).*,\1n,' \
-               -e 's,(LIBRTE_PMD_PCAP=).*,\1y,' \
-               -e 's,(LIBRTE_PMD_XENVIRT=).*,\1y,' \
-               $(DPDK_STATIC_DIR)/.config
+               -e 's,(RTE_NEXT_ABI=).*,\1n,' \
+               -e 's,(CONFIG_RTE_EAL_IGB_UIO=).*,\1n,' \
+               -e 's,(CONFIG_RTE_KNI_KMOD=).*,\1n,' \
+               -e 's,(LIBRTE_PMD_PCAP=).*,\1y,' \
+               -e 's,(LIBRTE_PMD_XENVIRT=).*,\1y,' \
+               $(DPDK_STATIC_DIR)/.config
 
 build-indep: build-config
        dh_testdir
-       $(MAKE) O=$(DPDK_STATIC_DIR) doc-api-html doc-guides-html
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_STATIC_DIR) doc-api-html doc-guides-html
 
 build-arch: build-config
        dh_testdir
-       $(MAKE) O=$(DPDK_STATIC_DIR) build
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_STATIC_DIR) build
        # Unfortunately the decision about having static or shared libraries is
        # made for the whole build, which then produces only .a or .so files
        # (but not both).
@@ -72,8 +77,8 @@ build-arch: build-config
        # used to get static libraries.
        cp -a $(DPDK_STATIC_DIR) $(DPDK_SHARED_DIR)
        sed -ri 's,(RTE_BUILD_SHARED_LIB=).*,\1y,' \
-               $(DPDK_SHARED_DIR)/.config
-       $(MAKE) O=$(DPDK_SHARED_DIR) build
+               $(DPDK_SHARED_DIR)/.config
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_SHARED_DIR) build
 
 build: build-arch build-indep
 
@@ -91,7 +96,7 @@ binary-indep:
        dh_lintian
        # Package: dpdk-doc
        # All files based on the install-doc rule (includes examples)
-       $(MAKE) O=$(DPDK_SHARED_DIR) prefix=/usr \
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_SHARED_DIR) prefix=/usr \
                DESTDIR=debian/dpdk-doc install-doc
        dh_link
        dh_compress
@@ -116,16 +121,17 @@ binary-arch:
        dh_installinit --no-start --no-restart-on-upgrade
        dh_systemd_start --no-start --no-restart-on-upgrade
        # Package: dpdk (runtime)
-       $(MAKE) O=$(DPDK_STATIC_DIR) prefix=/usr \
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_STATIC_DIR) prefix=/usr \
                DESTDIR=debian/dpdk install-runtime
-       $(MAKE) O=$(DPDK_SHARED_DIR) prefix=/usr \
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_SHARED_DIR) prefix=/usr \
                DESTDIR=debian/dpdk install-runtime
        cp debian/dpdk.interfaces debian/dpdk/etc/dpdk/interfaces
        rm debian/dpdk/usr/sbin/dpdk_nic_bind
+       mkdir -p debian/dpdk/sbin
        ln -s /usr/share/dpdk/tools/dpdk_nic_bind.py \
                debian/dpdk/sbin/dpdk_nic_bind
        # Package: dpdk-dev (build environment)
-       $(MAKE) O=$(DPDK_SHARED_DIR) prefix=/usr \
+       $(MAKE) V=$(DH_VERBOSE) O=$(DPDK_SHARED_DIR) prefix=/usr \
                DESTDIR=debian/dpdk-dev install-sdk
        cp $(DPDK_SHARED_DIR)/.config debian/dpdk-dev/usr/share/dpdk/config
        sed -e 's/SDK_TARGET/$(RTE_TARGET)/' debian/dpdk-sdk-env.sh.in > \
@@ -136,6 +142,7 @@ binary-arch:
        # linker script
        mv debian/dpdk/usr/lib/libdpdk.so debian/libdpdk-dev/$(LIBDIR)/
        # includes
+       mkdir -p debian/libdpdk-dev/usr/include
        mv debian/dpdk-dev/usr/include/dpdk debian/libdpdk-dev/usr/include/
        # all static libs are in the dev package
        mv debian/dpdk/usr/lib/lib*.a debian/libdpdk-dev/$(LIBDIR)/