mirror of
git://git.yoctoproject.org/meta-intel.git
synced 2025-07-19 21:09:03 +02:00
meta-intel/common: Add include file for DPDK
Added include file dpdk.inc to share common functionality based on dpdk_1.6.0r2 Added a new variable EXAMPLE_BUILD_DIR. this points to apps build directory which is different in dpdk v1.6.0r2 and v1.7.0. Users of dpdk.inc have to define EXAMPLE_BUILD_DIR for the installation of example apps. Signed-off-by: Sreeju Selvaraj <sreeju.armughanx.selvaraj@intel.com> Acked-by: Ong Boon Leong <boon.leong.ong@intel.com> Signed-off-by: Tom Zanussi <tom.zanussi@linux.intel.com>
This commit is contained in:
parent
6702f5a00c
commit
1c825a0609
139
common/recipes-extended/dpdk/dpdk.inc
Normal file
139
common/recipes-extended/dpdk/dpdk.inc
Normal file
|
@ -0,0 +1,139 @@
|
|||
DESCRIPTION = "Intel(r) Data Plane Development Kit"
|
||||
HOMEPAGE = "http://dpdk.org"
|
||||
LICENSE = "BSD & LGPLv2 & GPLv2"
|
||||
LIC_FILES_CHKSUM = "file://LICENSE.GPL;md5=751419260aa954499f7abaabaa882bbe"
|
||||
|
||||
|
||||
RDEPENDS_${PN} += "python-subprocess"
|
||||
|
||||
inherit module
|
||||
|
||||
export MODULE_DIR="/lib/modules/${KERNEL_VERSION}/kernel/drivers/net"
|
||||
export RTE_SDK = "${S}"
|
||||
export RTE_TARGET="${TARGET_ARCH}-ivshmem-${TARGET_OS}app-gcc"
|
||||
export ICP_ROOT = "${PKG_CONFIG_SYSROOT_DIR}/usr/include"
|
||||
export ICP_LIB_ROOT= "${PKG_CONFIG_SYSROOT_DIR}/usr/lib"
|
||||
export RTE_KERNELDIR = "${STAGING_KERNEL_DIR}"
|
||||
export INSTALL_PATH = "${prefix}/dpdk"
|
||||
|
||||
|
||||
do_configure () {
|
||||
#############################################################
|
||||
### default value for prefix is "usr", unsetting it, so it
|
||||
### will not be concatenated in ${RTE_TARGET}/Makefile
|
||||
### which will cause compilation failure
|
||||
#############################################################
|
||||
unset prefix
|
||||
|
||||
make O=$RTE_TARGET T=$RTE_TARGET config
|
||||
|
||||
}
|
||||
|
||||
|
||||
do_compile () {
|
||||
unset LDFLAGS TARGET_LDFLAGS BUILD_LDFLAGS
|
||||
|
||||
cd ${S}/${RTE_TARGET}
|
||||
oe_runmake EXTRA_LDFLAGS=" --sysroot=${STAGING_DIR_HOST}" \
|
||||
EXTRA_CFLAGS=" --sysroot=${STAGING_DIR_HOST}" \
|
||||
CROSS="${TARGET_PREFIX}" \
|
||||
prefix="" LDFLAGS="" WERROR_FLAGS="-w" V=1
|
||||
|
||||
}
|
||||
|
||||
|
||||
do_install () {
|
||||
|
||||
install -m 0755 -d ${D}/${INSTALL_PATH} \
|
||||
${D}/${INSTALL_PATH}/doc \
|
||||
${D}/${INSTALL_PATH}/tools \
|
||||
${D}/${INSTALL_PATH}/${RTE_TARGET} \
|
||||
${D}/${INSTALL_PATH}/${RTE_TARGET}/app \
|
||||
${D}${includedir} \
|
||||
${D}${includedir}/arch \
|
||||
${D}${includedir}/exec-env \
|
||||
${D}${libdir} \
|
||||
${D}${MODULE_DIR}
|
||||
|
||||
install -m 0755 ${S}/${RTE_TARGET}/kmod/igb_uio.ko ${D}${MODULE_DIR}/
|
||||
install -m 0755 ${S}/${RTE_TARGET}/kmod/rte_kni.ko ${D}${MODULE_DIR}/
|
||||
|
||||
install -m 640 ${S}/${RTE_TARGET}/lib/*.a ${D}${libdir}
|
||||
|
||||
install -m 640 ${S}/${RTE_TARGET}/.config ${D}/${INSTALL_PATH}/${RTE_TARGET}/
|
||||
install -m 640 ${S}/${RTE_TARGET}/include/*.h ${D}${includedir}/
|
||||
install -m 640 ${S}/${RTE_TARGET}/include/arch/* ${D}${includedir}/arch/
|
||||
install -m 640 ${S}/${RTE_TARGET}/include/exec-env/* ${D}${includedir}/exec-env/
|
||||
install -m 0755 ${S}/tools/*.py ${D}/${INSTALL_PATH}/tools/
|
||||
|
||||
|
||||
#Install test applications
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/test ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/testpmd ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/dump_cfg ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/cmdline_test ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
|
||||
|
||||
# Install example applications
|
||||
# It is expected that user of this include file should define EXAMPLES_BUILD_DIR
|
||||
for app in ${S}/examples/*
|
||||
do
|
||||
case `basename ${app}` in
|
||||
"dpdk_qat" | "vhost" | "vhost_xen" | "Makefile" ) continue
|
||||
;;
|
||||
"l2fwd-ivshmem")
|
||||
install -m 0755 ${app}/guest/${EXAMPLES_BUILD_DIR}/app/guest ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/host/${EXAMPLES_BUILD_DIR}/app/host ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"multi_process")
|
||||
install -m 0755 ${app}/client_server_mp/mp_client/${EXAMPLES_BUILD_DIR}/app/mp_client ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/client_server_mp/mp_server/${EXAMPLES_BUILD_DIR}/app/mp_server ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/simple_mp/${EXAMPLES_BUILD_DIR}/app/simple_mp ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/symmetric_mp/${EXAMPLES_BUILD_DIR}/app/symmetric_mp ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"netmap_compat")
|
||||
install -m 0755 ${app}/bridge/${EXAMPLES_BUILD_DIR}/app/bridge ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"quota_watermark")
|
||||
install -m 0755 ${app}/qw/${EXAMPLES_BUILD_DIR}/app/qw ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/qwctl/${EXAMPLES_BUILD_DIR}/app/qwctl ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"vmdq")
|
||||
install -m 0755 ${app}/${EXAMPLES_BUILD_DIR}/app/`basename ${app}`_app ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"vmdq_dcb")
|
||||
install -m 0755 ${app}/${EXAMPLES_BUILD_DIR}/app/`basename ${app}`_app ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
esac
|
||||
|
||||
install -m 0755 ${app}/${EXAMPLES_BUILD_DIR}/app/`basename ${app}` ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
done
|
||||
}
|
||||
|
||||
PACKAGES += "${PN}-examples"
|
||||
|
||||
FILES_${PN}-dbg += " \
|
||||
${INSTALL_PATH}/.debug \
|
||||
${INSTALL_PATH}/${RTE_TARGET}/app/.debug \
|
||||
"
|
||||
|
||||
FILES_${PN}-doc += "\
|
||||
${INSTALL_PATH}/doc \
|
||||
"
|
||||
|
||||
FILES_${PN}-dev += " \
|
||||
${INSTALL_PATH}/${RTE_TARGET}/.config \
|
||||
${includedir} \
|
||||
${includedir}/arch \
|
||||
${includedir}/exec-env \
|
||||
"
|
||||
|
||||
FILES_${PN} += " ${INSTALL_PATH}/tools/ "
|
||||
|
||||
FILES_${PN}-examples += " ${INSTALL_PATH}/${RTE_TARGET}/app/ "
|
|
@ -1,7 +1,4 @@
|
|||
DESCRIPTION = "Intel(r) Data Plane Development Kit"
|
||||
HOMEPAGE = "http://dpdk.org"
|
||||
LICENSE = "BSD & LGPLv2 & GPLv2"
|
||||
LIC_FILES_CHKSUM = "file://LICENSE.GPL;md5=751419260aa954499f7abaabaa882bbe"
|
||||
include dpdk.inc
|
||||
|
||||
|
||||
SRC_URI = "http://dpdk.org/browse/dpdk/snapshot/dpdk-${PV}.tar.gz;name=dpdk \
|
||||
|
@ -14,41 +11,9 @@ SRC_URI = "http://dpdk.org/browse/dpdk/snapshot/dpdk-${PV}.tar.gz;name=dpdk \
|
|||
SRC_URI[dpdk.md5sum] = "f406d027320fc8e724bff20db5397cbb"
|
||||
SRC_URI[dpdk.sha256sum] = "e72fdebcf8a899fc58e60c9b6493b7457576eece60b08dea6aee96c9087df4b2"
|
||||
|
||||
RDEPENDS_${PN} += "python-subprocess"
|
||||
|
||||
inherit module
|
||||
|
||||
export MODULE_DIR="/lib/modules/${KERNEL_VERSION}/kernel/drivers/net"
|
||||
export RTE_SDK = "${S}"
|
||||
export RTE_TARGET="${TARGET_ARCH}-ivshmem-${TARGET_OS}app-gcc"
|
||||
export ICP_ROOT = "${PKG_CONFIG_SYSROOT_DIR}/usr/include"
|
||||
export ICP_LIB_ROOT= "${PKG_CONFIG_SYSROOT_DIR}/usr/lib"
|
||||
export RTE_KERNELDIR = "${STAGING_KERNEL_DIR}"
|
||||
export INSTALL_PATH = "${prefix}/dpdk"
|
||||
|
||||
|
||||
do_configure () {
|
||||
#############################################################
|
||||
### default value for prefix is "usr", unsetting it, so it
|
||||
### will not be concatenated in ${RTE_TARGET}/Makefile
|
||||
### which will cause compilation failure
|
||||
#############################################################
|
||||
unset prefix
|
||||
|
||||
make O=$RTE_TARGET T=$RTE_TARGET config
|
||||
|
||||
}
|
||||
|
||||
|
||||
do_compile () {
|
||||
unset LDFLAGS TARGET_LDFLAGS BUILD_LDFLAGS
|
||||
|
||||
cd ${S}/${RTE_TARGET}
|
||||
oe_runmake EXTRA_LDFLAGS=" --sysroot=${STAGING_DIR_HOST}" \
|
||||
EXTRA_CFLAGS=" --sysroot=${STAGING_DIR_HOST}" \
|
||||
CROSS="${TARGET_PREFIX}" \
|
||||
prefix="" LDFLAGS="" WERROR_FLAGS="-w" V=1
|
||||
export EXAMPLES_BUILD_DIR = "build"
|
||||
|
||||
do_compile_append () {
|
||||
|
||||
###################################################################
|
||||
### Compilation for examples
|
||||
|
@ -62,104 +27,19 @@ do_compile () {
|
|||
[ `basename ${app}` = "dpdk_qat" -o `basename ${app}` = "vhost" -o `basename ${app}` = "vhost_xen" ] && continue;
|
||||
|
||||
cd ${app}
|
||||
oe_runmake CROSS="${TARGET_PREFIX}"
|
||||
|
||||
###############################################################
|
||||
# netmap_compat is putting the binary in a directory path
|
||||
# which is different from rest of the example apps, so this
|
||||
# special case is handled here to avoid installation failure
|
||||
# with dpdk-1.6.0
|
||||
###############################################################
|
||||
if [ `basename ${app}` == "netmap_compat" ]; then
|
||||
oe_runmake CROSS="${TARGET_PREFIX}" O="${app}/bridge/${EXAMPLES_BUILD_DIR}/"
|
||||
else
|
||||
oe_runmake CROSS="${TARGET_PREFIX}"
|
||||
fi
|
||||
done
|
||||
|
||||
}
|
||||
|
||||
|
||||
do_install () {
|
||||
|
||||
install -m 0755 -d ${D}/${INSTALL_PATH} \
|
||||
${D}/${INSTALL_PATH}/doc \
|
||||
${D}/${INSTALL_PATH}/tools \
|
||||
${D}/${INSTALL_PATH}/${RTE_TARGET} \
|
||||
${D}/${INSTALL_PATH}/${RTE_TARGET}/app \
|
||||
${D}${includedir} \
|
||||
${D}${includedir}/arch \
|
||||
${D}${includedir}/exec-env \
|
||||
${D}${libdir} \
|
||||
${D}${MODULE_DIR}
|
||||
|
||||
install -m 0755 ${S}/${RTE_TARGET}/kmod/igb_uio.ko ${D}${MODULE_DIR}/
|
||||
install -m 0755 ${S}/${RTE_TARGET}/kmod/rte_kni.ko ${D}${MODULE_DIR}/
|
||||
|
||||
install -m 640 ${S}/${RTE_TARGET}/lib/*.a ${D}${libdir}
|
||||
|
||||
install -m 640 ${S}/${RTE_TARGET}/.config ${D}/${INSTALL_PATH}/${RTE_TARGET}/
|
||||
install -m 640 ${S}/${RTE_TARGET}/include/*.h ${D}${includedir}/
|
||||
install -m 640 ${S}/${RTE_TARGET}/include/arch/* ${D}${includedir}/arch/
|
||||
install -m 640 ${S}/${RTE_TARGET}/include/exec-env/* ${D}${includedir}/exec-env/
|
||||
install -m 0755 ${S}/tools/igb_uio_bind.py ${D}/${INSTALL_PATH}/tools/
|
||||
install -m 0755 ${S}/tools/cpu_layout.py ${D}/${INSTALL_PATH}/tools/
|
||||
|
||||
|
||||
#Install test applications
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/test ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/testpmd ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/dump_cfg ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${S}/${RTE_TARGET}/app/cmdline_test ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
|
||||
|
||||
#Install example applications
|
||||
for app in ${S}/examples/*
|
||||
do
|
||||
case `basename ${app}` in
|
||||
"dpdk_qat" | "vhost" | "vhost_xen" ) continue
|
||||
;;
|
||||
"l2fwd-ivshmem")
|
||||
install -m 0755 ${app}/guest/build/app/guest ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/host/build/app/host ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"multi_process")
|
||||
install -m 0755 ${app}/client_server_mp/mp_client/build/app/mp_client ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/client_server_mp/mp_server/build/app/mp_server ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/simple_mp/build/app/simple_mp ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/symmetric_mp/build/app/symmetric_mp ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"netmap_compat")
|
||||
install -m 0755 ${app}/build/app/bridge ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"quota_watermark")
|
||||
install -m 0755 ${app}/qw/build/app/qw ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
install -m 0755 ${app}/qwctl/build/app/qwctl ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"vmdq")
|
||||
install -m 0755 ${app}/build/app/`basename ${app}`_app ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
"vmdq_dcb")
|
||||
install -m 0755 ${app}/build/app/`basename ${app}`_app ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
continue
|
||||
;;
|
||||
esac
|
||||
|
||||
install -m 0755 ${app}/build/app/`basename ${app}` ${D}/${INSTALL_PATH}/${RTE_TARGET}/app
|
||||
done
|
||||
}
|
||||
|
||||
PACKAGES += "${PN}-examples"
|
||||
|
||||
FILES_${PN}-dbg += " \
|
||||
${INSTALL_PATH}/.debug \
|
||||
${INSTALL_PATH}/${RTE_TARGET}/app/.debug \
|
||||
"
|
||||
|
||||
FILES_${PN}-doc += "\
|
||||
${INSTALL_PATH}/doc \
|
||||
"
|
||||
|
||||
FILES_${PN}-dev += " \
|
||||
${INSTALL_PATH}/${RTE_TARGET}/.config \
|
||||
${includedir} \
|
||||
${includedir}/arch \
|
||||
${includedir}/exec-env \
|
||||
"
|
||||
|
||||
FILES_${PN} += " ${INSTALL_PATH}/tools/ "
|
||||
|
||||
FILES_${PN}-examples += " ${INSTALL_PATH}/${RTE_TARGET}/app/ "
|
||||
|
|
Loading…
Reference in New Issue
Block a user