diff options
author | Sreeju Selvaraj <sreeju.armughanx.selvaraj@intel.com> | 2014-09-04 22:06:56 +0800 |
---|---|---|
committer | Tom Zanussi <tom.zanussi@linux.intel.com> | 2014-10-01 22:54:52 -0500 |
commit | 1c825a06095178c0c51f28d5867549feac8a47f4 (patch) | |
tree | 1283b80ad5b06bae1e8527948b4bf9a654510157 /common/recipes-extended/dpdk/dpdk.inc | |
parent | 6702f5a00c414c68f6f6ceae46552bce571cf93f (diff) | |
download | meta-intel-1c825a06095178c0c51f28d5867549feac8a47f4.tar.gz |
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>
Diffstat (limited to 'common/recipes-extended/dpdk/dpdk.inc')
-rw-r--r-- | common/recipes-extended/dpdk/dpdk.inc | 139 |
1 files changed, 139 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..ef369df3 --- /dev/null +++ b/common/recipes-extended/dpdk/dpdk.inc | |||
@@ -0,0 +1,139 @@ | |||
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 | |||
7 | RDEPENDS_${PN} += "python-subprocess" | ||
8 | |||
9 | inherit module | ||
10 | |||
11 | export MODULE_DIR="/lib/modules/${KERNEL_VERSION}/kernel/drivers/net" | ||
12 | export RTE_SDK = "${S}" | ||
13 | export RTE_TARGET="${TARGET_ARCH}-ivshmem-${TARGET_OS}app-gcc" | ||
14 | export ICP_ROOT = "${PKG_CONFIG_SYSROOT_DIR}/usr/include" | ||
15 | export ICP_LIB_ROOT= "${PKG_CONFIG_SYSROOT_DIR}/usr/lib" | ||
16 | export RTE_KERNELDIR = "${STAGING_KERNEL_DIR}" | ||
17 | export INSTALL_PATH = "${prefix}/dpdk" | ||
18 | |||
19 | |||
20 | do_configure () { | ||
21 | ############################################################# | ||
22 | ### default value for prefix is "usr", unsetting it, so it | ||
23 | ### will not be concatenated in ${RTE_TARGET}/Makefile | ||
24 | ### which will cause compilation failure | ||
25 | ############################################################# | ||
26 | unset prefix | ||
27 | |||
28 | make O=$RTE_TARGET T=$RTE_TARGET config | ||
29 | |||
30 | } | ||
31 | |||
32 | |||
33 | do_compile () { | ||
34 | unset LDFLAGS TARGET_LDFLAGS BUILD_LDFLAGS | ||
35 | |||
36 | cd ${S}/${RTE_TARGET} | ||
37 | oe_runmake EXTRA_LDFLAGS=" --sysroot=${STAGING_DIR_HOST}" \ | ||
38 | EXTRA_CFLAGS=" --sysroot=${STAGING_DIR_HOST}" \ | ||
39 | CROSS="${TARGET_PREFIX}" \ | ||
40 | prefix="" LDFLAGS="" WERROR_FLAGS="-w" V=1 | ||
41 | |||
42 | } | ||
43 | |||
44 | |||
45 | do_install () { | ||
46 | |||
47 | install -m 0755 -d ${D}/${INSTALL_PATH} \ | ||
48 | ${D}/${INSTALL_PATH}/doc \ | ||
49 | ${D}/${INSTALL_PATH}/tools \ | ||
50 | ${D}/${INSTALL_PATH}/${RTE_TARGET} \ | ||
51 | ${D}/${INSTALL_PATH}/${RTE_TARGET}/app \ | ||
52 | ${D}${includedir} \ | ||
53 | ${D}${includedir}/arch \ | ||
54 | ${D}${includedir}/exec-env \ | ||
55 | ${D}${libdir} \ | ||
56 | ${D}${MODULE_DIR} | ||
57 | |||
58 | install -m 0755 ${S}/${RTE_TARGET}/kmod/igb_uio.ko ${D}${MODULE_DIR}/ | ||
59 | install -m 0755 ${S}/${RTE_TARGET}/kmod/rte_kni.ko ${D}${MODULE_DIR}/ | ||
60 | |||
61 | install -m 640 ${S}/${RTE_TARGET}/lib/*.a ${D}${libdir} | ||
62 | |||
63 | install -m 640 ${S}/${RTE_TARGET}/.config ${D}/${INSTALL_PATH}/${RTE_TARGET}/ | ||
64 | install -m 640 ${S}/${RTE_TARGET}/include/*.h ${D}${includedir}/ | ||
65 | install -m 640 ${S}/${RTE_TARGET}/include/arch/* ${D}${includedir}/arch/ | ||
66 | install -m 640 ${S}/${RTE_TARGET}/include/exec-env/* ${D}${includedir}/exec-env/ | ||
67 | install -m 0755 ${S}/tools/*.py ${D}/${INSTALL_PATH}/tools/ | ||
68 | |||
69 | |||
70 | #Install test applications | ||
71 | install -m 0755 ${S}/${RTE_TARGET}/app/test ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
72 | install -m 0755 ${S}/${RTE_TARGET}/app/testpmd ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
73 | install -m 0755 ${S}/${RTE_TARGET}/app/dump_cfg ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
74 | install -m 0755 ${S}/${RTE_TARGET}/app/cmdline_test ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
75 | |||
76 | |||
77 | # Install example applications | ||
78 | # It is expected that user of this include file should define EXAMPLES_BUILD_DIR | ||
79 | for app in ${S}/examples/* | ||
80 | do | ||
81 | case `basename ${app}` in | ||
82 | "dpdk_qat" | "vhost" | "vhost_xen" | "Makefile" ) continue | ||
83 | ;; | ||
84 | "l2fwd-ivshmem") | ||
85 | install -m 0755 ${app}/guest/${EXAMPLES_BUILD_DIR}/app/guest ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
86 | install -m 0755 ${app}/host/${EXAMPLES_BUILD_DIR}/app/host ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
87 | continue | ||
88 | ;; | ||
89 | "multi_process") | ||
90 | install -m 0755 ${app}/client_server_mp/mp_client/${EXAMPLES_BUILD_DIR}/app/mp_client ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
91 | install -m 0755 ${app}/client_server_mp/mp_server/${EXAMPLES_BUILD_DIR}/app/mp_server ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
92 | install -m 0755 ${app}/simple_mp/${EXAMPLES_BUILD_DIR}/app/simple_mp ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
93 | install -m 0755 ${app}/symmetric_mp/${EXAMPLES_BUILD_DIR}/app/symmetric_mp ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
94 | continue | ||
95 | ;; | ||
96 | "netmap_compat") | ||
97 | install -m 0755 ${app}/bridge/${EXAMPLES_BUILD_DIR}/app/bridge ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
98 | continue | ||
99 | ;; | ||
100 | "quota_watermark") | ||
101 | install -m 0755 ${app}/qw/${EXAMPLES_BUILD_DIR}/app/qw ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
102 | install -m 0755 ${app}/qwctl/${EXAMPLES_BUILD_DIR}/app/qwctl ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
103 | continue | ||
104 | ;; | ||
105 | "vmdq") | ||
106 | install -m 0755 ${app}/${EXAMPLES_BUILD_DIR}/app/`basename ${app}`_app ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
107 | continue | ||
108 | ;; | ||
109 | "vmdq_dcb") | ||
110 | install -m 0755 ${app}/${EXAMPLES_BUILD_DIR}/app/`basename ${app}`_app ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
111 | continue | ||
112 | ;; | ||
113 | esac | ||
114 | |||
115 | install -m 0755 ${app}/${EXAMPLES_BUILD_DIR}/app/`basename ${app}` ${D}/${INSTALL_PATH}/${RTE_TARGET}/app | ||
116 | done | ||
117 | } | ||
118 | |||
119 | PACKAGES += "${PN}-examples" | ||
120 | |||
121 | FILES_${PN}-dbg += " \ | ||
122 | ${INSTALL_PATH}/.debug \ | ||
123 | ${INSTALL_PATH}/${RTE_TARGET}/app/.debug \ | ||
124 | " | ||
125 | |||
126 | FILES_${PN}-doc += "\ | ||
127 | ${INSTALL_PATH}/doc \ | ||
128 | " | ||
129 | |||
130 | FILES_${PN}-dev += " \ | ||
131 | ${INSTALL_PATH}/${RTE_TARGET}/.config \ | ||
132 | ${includedir} \ | ||
133 | ${includedir}/arch \ | ||
134 | ${includedir}/exec-env \ | ||
135 | " | ||
136 | |||
137 | FILES_${PN} += " ${INSTALL_PATH}/tools/ " | ||
138 | |||
139 | FILES_${PN}-examples += " ${INSTALL_PATH}/${RTE_TARGET}/app/ " | ||