summaryrefslogtreecommitdiffstats
path: root/common/recipes-extended/dpdk/dpdk.inc
diff options
context:
space:
mode:
Diffstat (limited to 'common/recipes-extended/dpdk/dpdk.inc')
-rw-r--r--common/recipes-extended/dpdk/dpdk.inc152
1 files changed, 152 insertions, 0 deletions
diff --git a/common/recipes-extended/dpdk/dpdk.inc b/common/recipes-extended/dpdk/dpdk.inc
new file mode 100644
index 00000000..e90b13f7
--- /dev/null
+++ b/common/recipes-extended/dpdk/dpdk.inc
@@ -0,0 +1,152 @@
1DESCRIPTION = "Intel(r) Data Plane Development Kit"
2HOMEPAGE = "http://dpdk.org"
3LICENSE = "BSD & LGPLv2 & GPLv2"
4LIC_FILES_CHKSUM = "file://LICENSE.GPL;md5=751419260aa954499f7abaabaa882bbe"
5
6SRC_URI = "http://dpdk.org/browse/dpdk/snapshot/dpdk-${PV}.tar.gz;name=dpdk \
7 file://dpdk-16.04-add-RTE_KERNELDIR_OUT-to-split-kernel-bu.patch \
8 file://dpdk-16.07-add-sysroot-option-within-app-makefile.patch \
9 file://dpdk-16.04-point-to-the-right-include-and-lib-path.patch \
10 file://dpdk-16.04-Fix-for-misleading-indentation-error.patch \
11 file://dpdk-16.07-dpdk-fix-installation-warning-and-issue.patch \
12 file://dpdk-16.04-dpdk-fix-compilation-with-dynamic-libs.patch \
13 file://dpdk-16.07-dpdk-fix-for-parellel-make-issue.patch \
14 file://dpdk-16.07-net-ixgbe-move-PCI-device-IDs-from-EAL.patch \
15 file://dpdk-16.07-net-igb-move-PCI-device-IDs-from-EAL.patch \
16 file://dpdk-16.07-kni-fix-build-with-kernel-4.8.patch \
17 "
18
19COMPATIBLE_MACHINE = "crystalforest|intel-corei7-64"
20
21# dpdk example apps dpdk_qat and vhost have dependancy on fuse and qat.
22# fuse is in meta-filesystems and qat is not yet upstreamed.
23# So adding mechanism to explicitly disable the use of fuse and qat.
24# To enable, uncomment the below line or include in .bbappend.
25# PACKAGECONFIG ?= " dpdk_qat vhost libvirt"
26
27PACKAGECONFIG[dpdk_qat] = ",,virtual/qat"
28PACKAGECONFIG[vhost] = ",,fuse"
29PACKAGECONFIG[libvirt] = ",,libvirt"
30
31export CONFIG_EXAMPLE_DPDK_QAT = "${@bb.utils.contains('PACKAGECONFIG', 'dpdk_qat', 'y', 'n', d)}"
32export CONFIG_EXAMPLE_VM_POWER_MANAGER = "${@bb.utils.contains('PACKAGECONFIG', 'libvirt', 'y', 'n', d)}"
33export CONFIG_VHOST_ENABLED = "${@bb.utils.contains('PACKAGECONFIG', 'vhost', 'y', 'n', d)}"
34
35RDEPENDS_${PN} += "python-subprocess"
36DEPENDS = "virtual/kernel"
37do_configure[depends] += "virtual/kernel:do_shared_workdir"
38
39inherit module
40
41export MODULE_DIR="/lib/modules/${KERNEL_VERSION}/kernel/drivers/net"
42export RTE_SDK = "${S}"
43export RTE_TARGET="${@bb.utils.contains("TUNE_FEATURES", "corei7", "x86_64-ivshmem-linuxapp-gcc", "i686-native-linuxapp-gcc", d)}"
44
45export ICP_ROOT = "${PKG_CONFIG_SYSROOT_DIR}/usr/include"
46export ICP_LIB_ROOT= "${PKG_CONFIG_SYSROOT_DIR}/usr/lib"
47export RTE_KERNELDIR = "${STAGING_KERNEL_DIR}"
48export RTE_KERNELDIR_OUT = "${STAGING_KERNEL_BUILDDIR}"
49export INSTALL_PATH = "${prefix}/share"
50export RTE_OUTPUT = "${S}/${RTE_TARGET}"
51export ETHTOOL_LIB_PATH = "${S}/examples/ethtool/lib/${RTE_TARGET}/"
52export SYSROOTPATH = "--sysroot=${STAGING_DIR_HOST}"
53export DPDK_TARGET_MACH = "${@get_dpdk_target_mach(bb,d)}"
54export ICP_LAC_API_DIR = "${STAGING_DIR_TARGET}${includedir}/lac"
55
56# The list of intel Comms platforms and their target machine
57# process mapping. The supported target machine is listed under
58# dpdk/mk/machine
59def get_dpdk_target_mach(bb, d):
60 target_arch = d.getVar('MACHINE_ARCH', True)
61 multiarch_options = {
62 "mohonpeak64": "atm",
63 "mohonpeak32": "atm",
64 "crystalforest": "ivb",
65 "intel_corei7_64": "hsw",
66 }
67
68 if target_arch in multiarch_options :
69 return multiarch_options[target_arch]
70 return ""
71
72do_configure () {
73 #############################################################
74 ### default value for prefix is "usr", unsetting it, so it
75 ### will not be concatenated in ${RTE_TARGET}/Makefile
76 ### which will cause compilation failure
77 #############################################################
78 unset prefix
79
80 # Fix-up CONFIG_RTE_MACHINE based on target machine
81 sed -e "s#CONFIG_RTE_MACHINE=\"native\"#CONFIG_RTE_MACHINE=\"${DPDK_TARGET_MACH}\"#" -i ${S}/config/defconfig_x86_64-native-linuxapp-gcc
82 sed -e "s#CONFIG_RTE_MACHINE=\"native\"#CONFIG_RTE_MACHINE=\"${DPDK_TARGET_MACH}\"#" -i ${S}/config/defconfig_i686-native-linuxapp-gcc
83
84 # Fix-up vhost configs based on package config
85 sed -e "s#CONFIG_RTE_KNI_VHOST=n#CONFIG_RTE_KNI_VHOST=${CONFIG_VHOST_ENABLED}#" -i ${S}/config/common_linuxapp
86 sed -e "s#CONFIG_RTE_KNI_VHOST_VNET_HDR_EN=n#CONFIG_RTE_KNI_VHOST_VNET_HDR_EN=${CONFIG_VHOST_ENABLED}#" -i ${S}/config/common_linuxapp
87 sed -e "s#CONFIG_RTE_LIBRTE_VHOST=n#CONFIG_RTE_LIBRTE_VHOST=${CONFIG_VHOST_ENABLED}#" -i ${S}/config/common_linuxapp
88
89 make O=$RTE_TARGET T=$RTE_TARGET config
90}
91
92do_compile () {
93 unset LDFLAGS TARGET_LDFLAGS BUILD_LDFLAGS
94
95 cd ${S}/${RTE_TARGET}
96 oe_runmake EXTRA_LDFLAGS="-L${STAGING_LIBDIR} --hash-style=gnu" \
97 EXTRA_CFLAGS="--sysroot=${STAGING_DIR_HOST} -I${STAGING_INCDIR}" \
98 CROSS="${TARGET_PREFIX}" \
99 prefix="" LDFLAGS="" WERROR_FLAGS="-w" V=1
100
101 cd ${S}/examples/
102 oe_runmake EXTRA_LDFLAGS="-L${STAGING_LIBDIR} --hash-style=gnu" \
103 EXTRA_CFLAGS="--sysroot=${STAGING_DIR_HOST} -I${STAGING_INCDIR}" \
104 CROSS="${TARGET_PREFIX}" O="${S}/examples/$@/"
105}
106
107do_install () {
108 oe_runmake O=${RTE_OUTPUT} T= install-runtime DESTDIR=${D}
109 oe_runmake O=${RTE_OUTPUT} T= install-kmod DESTDIR=${D} kerneldir=${MODULE_DIR}
110 oe_runmake O=${RTE_OUTPUT} T= install-sdk DESTDIR=${D}
111
112 # Install examples
113 for dirname in ${S}/examples/*
114 do
115 install -m 0755 -d ${D}/${INSTALL_PATH}/examples/`basename ${dirname}`
116
117 for appname in `find ${dirname} -regex ".*${EXAMPLES_BUILD_DIR}\/app\/[-0-9a-zA-Z0-9/_]*$"`
118 do
119 install -m 755 ${appname} ${D}/${INSTALL_PATH}/examples/`basename ${dirname}`/
120 done
121 done
122}
123
124PACKAGES += "${PN}-examples"
125
126FILES_${PN}-dbg += " \
127 ${INSTALL_PATH}/.debug \
128 ${INSTALL_PATH}/examples/*/.debug \
129 "
130
131FILES_${PN}-doc += "\
132 ${INSTALL_PATH}/doc \
133 "
134
135FILES_${PN}-dev += " \
136 ${INSTALL_PATH}/${RTE_TARGET}/.config \
137 ${includedir} \
138 ${includedir}/${ARCHDIR} \
139 ${includedir}/exec-env \
140 ${INSTALL_PATH}/scripts/ \
141 ${INSTALL_PATH}/${RTE_TARGET}/include \
142 ${INSTALL_PATH}/${RTE_TARGET}/lib \
143 "
144
145FILES_${PN} += " ${INSTALL_PATH}/tools/ \
146 ${prefix}/sbin/ \
147 ${prefix}/bin/ \
148 ${libdir}/ \
149 "
150FILES_${PN}-examples += " \
151 ${INSTALL_PATH}/examples/* \
152 "