summaryrefslogtreecommitdiffstats
path: root/meta-networking/recipes-protocols/net-snmp/net-snmp_5.8.bb
diff options
context:
space:
mode:
Diffstat (limited to 'meta-networking/recipes-protocols/net-snmp/net-snmp_5.8.bb')
-rw-r--r--meta-networking/recipes-protocols/net-snmp/net-snmp_5.8.bb238
1 files changed, 238 insertions, 0 deletions
diff --git a/meta-networking/recipes-protocols/net-snmp/net-snmp_5.8.bb b/meta-networking/recipes-protocols/net-snmp/net-snmp_5.8.bb
new file mode 100644
index 0000000000..413f033f87
--- /dev/null
+++ b/meta-networking/recipes-protocols/net-snmp/net-snmp_5.8.bb
@@ -0,0 +1,238 @@
1SUMMARY = "Various tools relating to the Simple Network Management Protocol"
2HOMEPAGE = "http://www.net-snmp.org/"
3SECTION = "net"
4LICENSE = "BSD"
5
6LIC_FILES_CHKSUM = "file://README;beginline=3;endline=8;md5=7f7f00ba639ac8e8deb5a622ea24634e"
7
8DEPENDS = "openssl libnl pciutils"
9
10SRC_URI = "${SOURCEFORGE_MIRROR}/net-snmp/net-snmp-${PV}.zip \
11 file://init \
12 file://snmpd.conf \
13 file://snmptrapd.conf \
14 file://snmpd.service \
15 file://snmptrapd.service \
16 file://net-snmp-add-knob-whether-nlist.h-are-checked.patch \
17 file://fix-libtool-finish.patch \
18 file://net-snmp-testing-add-the-output-format-for-ptest.patch \
19 file://run-ptest \
20 file://0001-config_os_headers-Error-Fix.patch \
21 file://0001-snmplib-keytools.c-Don-t-check-for-return-from-EVP_M.patch \
22 file://0001-get_pid_from_inode-Include-limit.h.patch \
23 file://0002-configure-fix-a-cc-check-issue.patch \
24 file://0004-configure-fix-incorrect-variable.patch \
25 file://net-snmp-5.7.2-fix-engineBoots-value-on-SIGHUP.patch \
26 file://net-snmp-fix-for-disable-des.patch \
27 "
28SRC_URI[md5sum] = "6aae5948df7efde626613d6a4b3cd9d4"
29SRC_URI[sha256sum] = "c6291385b8ed84f05890fe4197005daf7e7ee7b082c2e390fa114a9477a56042"
30
31UPSTREAM_CHECK_URI = "https://sourceforge.net/projects/net-snmp/files/net-snmp/"
32UPSTREAM_CHECK_REGEX = "/net-snmp/(?P<pver>\d+(\.\d+)+)/"
33
34inherit autotools-brokensep update-rc.d siteinfo systemd pkgconfig perlnative
35
36EXTRA_OEMAKE = "INSTALL_PREFIX=${D} OTHERLDFLAGS='${LDFLAGS}' HOST_CPPFLAGS='${BUILD_CPPFLAGS}'"
37
38PARALLEL_MAKE = ""
39CCACHE = ""
40
41TARGET_CC_ARCH += "${LDFLAGS}"
42
43PACKAGECONFIG ??= ""
44PACKAGECONFIG[elfutils] = "--with-elf, --without-elf, elfutils"
45PACKAGECONFIG[libnl] = "--with-nl, --without-nl, libnl"
46
47PACKAGECONFIG ??= "${@bb.utils.filter('DISTRO_FEATURES', 'ipv6', d)}"
48PACKAGECONFIG[ipv6] = "--enable-ipv6,--disable-ipv6,,"
49
50PACKAGECONFIG[perl] = "--enable-embedded-perl --with-perl-modules=yes, --disable-embedded-perl --with-perl-modules=no,\
51 perl, perl perl-lib"
52
53EXTRA_OECONF = "--enable-shared \
54 --disable-manuals \
55 --with-defaults \
56 --with-install-prefix=${D} \
57 --with-persistent-directory=${localstatedir}/lib/net-snmp \
58 ${@oe.utils.conditional('SITEINFO_ENDIANNESS', 'le', '--with-endianness=little', '--with-endianness=big', d)} \
59"
60
61# net-snmp needs to have mib-modules=smux enabled to enable quagga to support snmp
62EXTRA_OECONF += "--with-mib-modules=smux"
63
64CACHED_CONFIGUREVARS = " \
65 ac_cv_header_valgrind_valgrind_h=no \
66 ac_cv_header_valgrind_memcheck_h=no \
67 ac_cv_ETC_MNTTAB=/etc/mtab \
68 lt_cv_shlibpath_overrides_runpath=yes \
69"
70export PERLPROG="${bindir}/env perl"
71PERLPROG_append = "${@bb.utils.contains('PACKAGECONFIG', 'perl', ' -I${WORKDIR}', '', d)}"
72
73HAS_PERL = "${@bb.utils.contains('PACKAGECONFIG', 'perl', '1', '0', d)}"
74
75do_configure_prepend() {
76 sed -i -e "s|I/usr/include|I${STAGING_INCDIR}|g" \
77 "${S}"/configure \
78 "${S}"/configure.d/config_os_libs2
79
80 if [ "${HAS_PERL}" = "1" ]; then
81 # this may need to be changed when package perl has any change.
82 cp -f ${STAGING_DIR_TARGET}/usr/lib*/perl/*/Config.pm ${WORKDIR}/
83 cp -f ${STAGING_DIR_TARGET}/usr/lib*/perl/*/Config_heavy.pl ${WORKDIR}/
84 sed -e "s@libpth => '/usr/lib.*@libpth => '${STAGING_DIR_TARGET}/${libdir} ${STAGING_DIR_TARGET}/${base_libdir}',@g" \
85 -e "s@privlibexp => '/usr@privlibexp => '${STAGING_DIR_TARGET}/usr@g" \
86 -e "s@scriptdir => '/usr@scriptdir => '${STAGING_DIR_TARGET}/usr@g" \
87 -e "s@sitearchexp => '/usr@sitearchexp => '${STAGING_DIR_TARGET}/usr@g" \
88 -e "s@sitelibexp => '/usr@sitearchexp => '${STAGING_DIR_TARGET}/usr@g" \
89 -e "s@vendorarchexp => '/usr@vendorarchexp => '${STAGING_DIR_TARGET}/usr@g" \
90 -e "s@vendorlibexp => '/usr@vendorlibexp => '${STAGING_DIR_TARGET}/usr@g" \
91 -i ${WORKDIR}/Config.pm
92 fi
93
94}
95
96do_configure_append() {
97 if [ "${HAS_PERL}" = "1" ]; then
98 sed -e "s@^NSC_INCLUDEDIR=.*@NSC_INCLUDEDIR=${STAGING_DIR_TARGET}\$\{includedir\}@g" \
99 -e "s@^NSC_LIBDIR=-L.*@NSC_LIBDIR=-L${STAGING_DIR_TARGET}\$\{libdir\}@g" \
100 -i ${B}/net-snmp-config
101 fi
102}
103
104do_install_append() {
105 install -d ${D}${sysconfdir}/snmp
106 install -d ${D}${sysconfdir}/init.d
107 install -m 755 ${WORKDIR}/init ${D}${sysconfdir}/init.d/snmpd
108 install -m 644 ${WORKDIR}/snmpd.conf ${D}${sysconfdir}/snmp/
109 install -m 644 ${WORKDIR}/snmptrapd.conf ${D}${sysconfdir}/snmp/
110 install -d ${D}${systemd_unitdir}/system
111 install -m 0644 ${WORKDIR}/snmpd.service ${D}${systemd_unitdir}/system
112 install -m 0644 ${WORKDIR}/snmptrapd.service ${D}${systemd_unitdir}/system
113 sed -e "s@^NSC_SRCDIR=.*@NSC_SRCDIR=.@g" \
114 -i ${D}${bindir}/net-snmp-create-v3-user
115 sed -e "s@^NSC_SRCDIR=.*@NSC_SRCDIR=.@g" \
116 -e "s@\([^ ]*-fdebug-prefix-map=[^ ]*\)\1*@@g" \
117 -e "s@\([^ ]*--sysroot=[^ ]*\)\1*@@g" \
118 -e "s@\([^ ]*--with-libtool-sysroot=[^ ]*\)\1*@@g" \
119 -e "s@\([^ ]*--with-install-prefix=[^ ]*\)\1*@@g" \
120 -i ${D}${bindir}/net-snmp-config
121
122 if [ "${HAS_PERL}" = "1" ]; then
123 sed -e "s@^NSC_INCLUDEDIR=.*@NSC_INCLUDEDIR=\$\{includedir\}@g" \
124 -e "s@^NSC_LIBDIR=-L.*@NSC_LIBDIR=-L\$\{libdir\}@g" \
125 -i ${D}${bindir}/net-snmp-config
126 fi
127}
128
129do_install_ptest() {
130 install -d ${D}${PTEST_PATH}
131 for i in ${S}/dist ${S}/include ${B}/include ${S}/mibs ${S}/configure \
132 ${B}/net-snmp-config ${S}/testing; do
133 if [ -e "$i" ]; then
134 cp -R --no-dereference --preserve=mode,links -v "$i" ${D}${PTEST_PATH}
135 fi
136 done
137 echo `autoconf -V|awk '/autoconf/{print $NF}'` > ${D}${PTEST_PATH}/dist/autoconf-version
138
139 rmdlist="${D}${PTEST_PATH}/dist/net-snmp-solaris-build"
140 for i in $rmdlist; do
141 if [ -d "$i" ]; then
142 rm -rf "$i"
143 fi
144 done
145}
146
147SYSROOT_PREPROCESS_FUNCS += "net_snmp_sysroot_preprocess"
148SNMP_DBGDIR = "/usr/src/debug/${PN}/${EXTENDPE}${PV}-${PR}"
149
150net_snmp_sysroot_preprocess () {
151 if [ -e ${D}${bindir}/net-snmp-config ]; then
152 install -d ${SYSROOT_DESTDIR}${bindir_crossscripts}/
153 install -m 755 ${D}${bindir}/net-snmp-config ${SYSROOT_DESTDIR}${bindir_crossscripts}/
154 sed -e "s@-I/usr/include@-I${STAGING_INCDIR}@g" \
155 -e "s@^prefix=.*@prefix=${STAGING_DIR_HOST}${prefix}@g" \
156 -e "s@^exec_prefix=.*@exec_prefix=${STAGING_EXECPREFIXDIR}@g" \
157 -e "s@^includedir=.*@includedir=${STAGING_INCDIR}@g" \
158 -e "s@^libdir=.*@libdir=${STAGING_LIBDIR}@g" \
159 -e "s@^NSC_SRCDIR=.*@NSC_SRCDIR=${S}@g" \
160 -e "s@-fdebug-prefix-map=${SNMP_DBGDIR}@-fdebug-prefix-map=${WORKDIR}=${SNMP_DBGDIR}@g" \
161 -e "s@-fdebug-prefix-map= -fdebug-prefix-map=@-fdebug-prefix-map=${STAGING_DIR_NATIVE}= \
162 -fdebug-prefix-map=${STAGING_DIR_HOST}=@g" \
163 -e "s@--sysroot=@--sysroot=${STAGING_DIR_HOST}@g" \
164 -e "s@--with-libtool-sysroot=@--with-libtool-sysroot=${STAGING_DIR_HOST}@g" \
165 -e "s@--with-install-prefix=@--with-install-prefix=${D}@g" \
166 -i ${SYSROOT_DESTDIR}${bindir_crossscripts}/net-snmp-config
167 fi
168}
169
170PACKAGES += "${PN}-libs ${PN}-mibs ${PN}-server ${PN}-client ${PN}-server-snmpd ${PN}-server-snmptrapd"
171
172# perl module
173PACKAGES += "${@bb.utils.contains('PACKAGECONFIG', 'perl', '${PN}-perl-modules', '', d)}"
174
175ALLOW_EMPTY_${PN} = "1"
176ALLOW_EMPTY_${PN}-server = "1"
177
178FILES_${PN}-perl-modules = "${libdir}/perl/*"
179
180FILES_${PN}-libs = "${libdir}/lib*${SOLIBS}"
181FILES_${PN}-mibs = "${datadir}/snmp/mibs"
182FILES_${PN}-server-snmpd = "${sbindir}/snmpd \
183 ${sysconfdir}/snmp/snmpd.conf \
184 ${sysconfdir}/init.d \
185 ${systemd_unitdir}/system/snmpd.service \
186"
187
188FILES_${PN}-server-snmptrapd = "${sbindir}/snmptrapd \
189 ${sysconfdir}/snmp/snmptrapd.conf \
190 ${systemd_unitdir}/system/snmptrapd.service \
191"
192
193FILES_${PN} = ""
194FILES_${PN}-client = "${bindir}/* ${datadir}/snmp/"
195FILES_${PN}-dbg += "${libdir}/.debug/ ${sbindir}/.debug/ ${bindir}/.debug/"
196FILES_${PN}-dev += "${bindir}/mib2c ${bindir}/mib2c-update"
197
198CONFFILES_${PN}-server-snmpd = "${sysconfdir}/snmp/snmpd.conf"
199CONFFILES_${PN}-server-snmptrapd = "${sysconfdir}/snmp/snmptrapd.conf"
200
201INITSCRIPT_PACKAGES = "${PN}-server-snmpd"
202INITSCRIPT_NAME_${PN}-server-snmpd = "snmpd"
203INITSCRIPT_PARAMS_${PN}-server-snmpd = "start 90 2 3 4 5 . stop 60 0 1 6 ."
204
205EXTRA_OECONF += "${@bb.utils.contains('DISTRO_FEATURES', 'systemd', '--with-systemd', '--without-systemd', d)}"
206
207SYSTEMD_PACKAGES = "${PN}-server-snmpd \
208 ${PN}-server-snmptrapd"
209
210SYSTEMD_SERVICE_${PN}-server-snmpd = "snmpd.service"
211SYSTEMD_SERVICE_${PN}-server-snmptrapd = "snmptrapd.service"
212
213RDEPENDS_${PN} += "${@bb.utils.contains('PACKAGECONFIG', 'perl', 'net-snmp-perl-modules', '', d)}"
214RDEPENDS_${PN} += "net-snmp-client"
215RDEPENDS_${PN}-server-snmpd += "net-snmp-mibs"
216RDEPENDS_${PN}-server-snmptrapd += "net-snmp-server-snmpd"
217RDEPENDS_${PN}-server += "net-snmp-server-snmpd net-snmp-server-snmptrapd"
218RDEPENDS_${PN}-client += "net-snmp-mibs net-snmp-libs"
219RDEPENDS_${PN}-libs += "libpci"
220RDEPENDS_${PN}-ptest += "perl \
221 perl-module-test \
222 perl-module-file-basename \
223 perl-module-getopt-long \
224 perl-module-file-temp \
225 perl-module-data-dumper \
226"
227RDEPENDS_${PN}-dev = "net-snmp-client (= ${EXTENDPKGV}) net-snmp-server (= ${EXTENDPKGV})"
228RRECOMMENDS_${PN}-dbg = "net-snmp-client (= ${EXTENDPKGV}) net-snmp-server (= ${EXTENDPKGV})"
229
230RPROVIDES_${PN}-server-snmpd += "${PN}-server-snmpd-systemd"
231RREPLACES_${PN}-server-snmpd += "${PN}-server-snmpd-systemd"
232RCONFLICTS_${PN}-server-snmpd += "${PN}-server-snmpd-systemd"
233
234RPROVIDES_${PN}-server-snmptrapd += "${PN}-server-snmptrapd-systemd"
235RREPLACES_${PN}-server-snmptrapd += "${PN}-server-snmptrapd-systemd"
236RCONFLICTS_${PN}-server-snmptrapd += "${PN}-server-snmptrapd-systemd"
237
238LEAD_SONAME = "libnetsnmp.so"