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