|
@@ -3,25 +3,26 @@
|
|
|
# netsnmp
|
|
|
#
|
|
|
#############################################################
|
|
|
-NETSNMP_VERSION:=5.1.2
|
|
|
-NETSNMP_PATCH_VERSION:=6.2
|
|
|
-NETSNMP_URL:=http://$(BR2_SOURCEFORGE_MIRROR).dl.sourceforge.net/sourceforge/net-snmp/
|
|
|
+NETSNMP_VERSION:=5.4.1
|
|
|
+NETSNMP_SITE:=http://$(BR2_SOURCEFORGE_MIRROR).dl.sourceforge.net/sourceforge/net-snmp/
|
|
|
NETSNMP_DIR:=$(BUILD_DIR)/net-snmp-$(NETSNMP_VERSION)
|
|
|
NETSNMP_SOURCE:=net-snmp-$(NETSNMP_VERSION).tar.gz
|
|
|
-NETSNMP_PATCH1:=net-snmp_$(NETSNMP_VERSION)-$(NETSNMP_PATCH_VERSION).diff.gz
|
|
|
-NETSNMP_PATCH1_URL:=$(BR2_DEBIAN_MIRROR)/debian/pool/main/n/net-snmp/
|
|
|
|
|
|
-$(DL_DIR)/$(NETSNMP_SOURCE):
|
|
|
- $(WGET) -P $(DL_DIR) $(NETSNMP_URL)/$(NETSNMP_SOURCE)
|
|
|
+NETSNMP_WO_TRANSPORT:=
|
|
|
+ifneq ($(BR2_INET_IPX),y)
|
|
|
+NETSNMP_WO_TRANSPORT+= IPX
|
|
|
+endif
|
|
|
+ifneq ($(BR2_INET_IPV6),y)
|
|
|
+NETSNMP_WO_TRANSPORT+= UDPIPv6 TCPIPv6
|
|
|
+endif
|
|
|
|
|
|
-$(DL_DIR)/$(NETSNMP_PATCH1):
|
|
|
- $(WGET) -P $(DL_DIR) $(NETSNMP_PATCH1_URL)/$(NETSNMP_PATCH1)
|
|
|
+$(DL_DIR)/$(NETSNMP_SOURCE):
|
|
|
+ $(WGET) -P $(DL_DIR) $(NETSNMP_SITE)/$(NETSNMP_SOURCE)
|
|
|
|
|
|
-$(NETSNMP_DIR)/.unpacked: $(DL_DIR)/$(NETSNMP_SOURCE) $(DL_DIR)/$(NETSNMP_PATCH1)
|
|
|
+$(NETSNMP_DIR)/.unpacked: $(DL_DIR)/$(NETSNMP_SOURCE)
|
|
|
$(ZCAT) $(DL_DIR)/$(NETSNMP_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
|
|
|
- $(ZCAT) $(DL_DIR)/$(NETSNMP_PATCH1) | patch -p1 -d $(NETSNMP_DIR)
|
|
|
- toolchain/patch-kernel.sh $(NETSNMP_DIR) package/netsnmp/ \*.patch
|
|
|
- touch $(NETSNMP_DIR)/.unpacked
|
|
|
+ toolchain/patch-kernel.sh $(NETSNMP_DIR) package/netsnmp/ \*$(NETSNMP_VERSION)\*.patch
|
|
|
+ touch $@
|
|
|
|
|
|
ifeq ($(BR2_ENDIAN),"BIG")
|
|
|
NETSNMP_ENDIAN=big
|
|
@@ -29,21 +30,47 @@ else
|
|
|
NETSNMP_ENDIAN=little
|
|
|
endif
|
|
|
|
|
|
-# We set CAN_USE_SYSCTL to no and use /proc since the
|
|
|
-# sysctl code in this thing is apparently intended for
|
|
|
-# freebsd or some such thing...
|
|
|
+ifeq ($(BR2_HAVE_PERL),y)
|
|
|
+NETSNMP_CONFIGURE_PERL_ENV:=\
|
|
|
+ PERLCC="$(TARGET_CC)"
|
|
|
+NETSNMP_CONFIGURE_PERL:=\
|
|
|
+ --disable-embedded-perl \
|
|
|
+ --disable-perl-cc-checks \
|
|
|
+ --enable-as-needed
|
|
|
+else
|
|
|
+NETSNMP_CONFIGURE_PERL_ENV:=
|
|
|
+NETSNMP_CONFIGURE_PERL:=\
|
|
|
+ --disable-embedded-perl \
|
|
|
+ --disable-perl-cc-checks \
|
|
|
+ --without-perl-modules
|
|
|
+endif
|
|
|
+
|
|
|
+ifeq ($(BR2_PACKAGE_OPENSSL),y)
|
|
|
+NETSNMP_CONFIGURE_OPENSSL:=--with-openssl=$(STAGING_DIR)/usr/include/openssl
|
|
|
+else
|
|
|
+NETSNMP_CONFIGURE_OPENSSL:=--without-openssl
|
|
|
+endif
|
|
|
+
|
|
|
+ifneq ($(findstring y,$(BR2_HAVE_MANPAGES)$(BR2_HAVE_INFOPAGES)),y)
|
|
|
+NETSNMP_DOCS:=--disable-manuals
|
|
|
+endif
|
|
|
+
|
|
|
$(NETSNMP_DIR)/.configured: $(NETSNMP_DIR)/.unpacked
|
|
|
(cd $(NETSNMP_DIR); rm -f config.cache; \
|
|
|
autoconf && \
|
|
|
- ac_cv_CAN_USE_SYSCTL=no \
|
|
|
+ ac_cv_NETSNMP_CAN_USE_SYSCTL=yes \
|
|
|
+ $(NETSNMP_CONFIGURE_PERL_ENV) \
|
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
|
$(TARGET_CONFIGURE_ARGS) \
|
|
|
./configure \
|
|
|
- --with-cc=$(TARGET_CROSS)gcc \
|
|
|
- --with-ar=$(TARGET_CROSS)ar \
|
|
|
--target=$(GNU_TARGET_NAME) \
|
|
|
--host=$(GNU_TARGET_NAME) \
|
|
|
--build=$(GNU_HOST_NAME) \
|
|
|
+ --with-cc=$(TARGET_CROSS)gcc \
|
|
|
+ --with-linkcc=$(TARGET_CROSS)gcc \
|
|
|
+ --with-ar=$(TARGET_CROSS)ar \
|
|
|
+ --with-cflags="$(TARGET_CFLAGS)" \
|
|
|
+ --with-ldflags="$(TARGET_LDFLAGS)" \
|
|
|
--with-endianness=$(NETSNMP_ENDIAN) \
|
|
|
--with-persistent-directory=/var/lib/snmp \
|
|
|
--enable-ucd-snmp-compatibility \
|
|
@@ -51,54 +78,61 @@ $(NETSNMP_DIR)/.configured: $(NETSNMP_DIR)/.unpacked
|
|
|
--disable-static \
|
|
|
--with-logfile=none \
|
|
|
--without-rpm \
|
|
|
- --with-openssl \
|
|
|
+ $(NETSNMP_CONFIGURE_OPENSSL) \
|
|
|
+ $(NETSNMP_DOCS) \
|
|
|
+ $(NETSNMP_CONFIGURE_PERL) \
|
|
|
--without-dmalloc \
|
|
|
--without-efence \
|
|
|
--without-rsaref \
|
|
|
--with-sys-contact="root" \
|
|
|
--with-sys-location="Unknown" \
|
|
|
--with-mib-modules="host smux ucd-snmp/dlmod" \
|
|
|
+ --with-out-transports="$(NETSNMP_WO_TRANSPORT)" \
|
|
|
--with-defaults \
|
|
|
+ --disable-debugging \
|
|
|
--prefix=/usr \
|
|
|
--sysconfdir=/etc \
|
|
|
- --mandir=/usr/man \
|
|
|
- --infodir=/usr/info \
|
|
|
+ --enable-mini-agent \
|
|
|
+ --without-kmem-usage \
|
|
|
+ $(DISABLE_IPV6) \
|
|
|
)
|
|
|
- touch $(NETSNMP_DIR)/.configured
|
|
|
+ touch $@
|
|
|
|
|
|
$(NETSNMP_DIR)/agent/snmpd: $(NETSNMP_DIR)/.configured
|
|
|
$(MAKE1) -C $(NETSNMP_DIR)
|
|
|
+ touch -c $@
|
|
|
|
|
|
$(TARGET_DIR)/usr/sbin/snmpd: $(NETSNMP_DIR)/agent/snmpd
|
|
|
$(MAKE) PREFIX=$(TARGET_DIR)/usr \
|
|
|
prefix=$(TARGET_DIR)/usr \
|
|
|
exec_prefix=$(TARGET_DIR)/usr \
|
|
|
persistentdir=$(TARGET_DIR)/var/lib/snmp \
|
|
|
- infodir=$(TARGET_DIR)/usr/info \
|
|
|
- mandir=$(TARGET_DIR)/usr/man \
|
|
|
includedir=$(STAGING_DIR)/usr/include/net-snmp \
|
|
|
ucdincludedir=$(STAGING_DIR)/usr/include/ucd-snmp \
|
|
|
-C $(NETSNMP_DIR) install
|
|
|
- rm -rf $(TARGET_DIR)/share/locale $(TARGET_DIR)/usr/info \
|
|
|
- $(TARGET_DIR)/usr/man $(TARGET_DIR)/usr/share/doc
|
|
|
+ rm -rf $(TARGET_DIR)/usr/share/doc
|
|
|
+ifneq ($(BR2_HAVE_MANPAGES),y)
|
|
|
+ rm -rf $(TARGET_DIR)/usr/share/man
|
|
|
+endif
|
|
|
+ifneq ($(BR2_HAVE_INFOPAGES),y)
|
|
|
+ rm -rf $(TARGET_DIR)/usr/share/info
|
|
|
+endif
|
|
|
# Copy the .conf files.
|
|
|
- mkdir -p $(TARGET_DIR)/etc/snmp
|
|
|
- cp $(NETSNMP_DIR)/EXAMPLE.conf $(TARGET_DIR)/etc/snmp/snmpd.conf
|
|
|
- cp $(NETSNMP_DIR)/EXAMPLE-trap.conf $(TARGET_DIR)/etc/snmp/snmptrapd.conf
|
|
|
+ $(INSTALL) -D -m 0644 $(NETSNMP_DIR)/EXAMPLE.conf $(TARGET_DIR)/etc/snmp/snmpd.conf
|
|
|
-mv $(TARGET_DIR)/usr/share/snmp/mib2c*.conf $(TARGET_DIR)/etc/snmp
|
|
|
- mkdir -p $(TARGET_DIR)/etc/default
|
|
|
- cp $(NETSNMP_DIR)/debian/snmpd.default $(TARGET_DIR)/etc/default/snmpd
|
|
|
# Remove the unsupported snmpcheck program
|
|
|
- rm $(TARGET_DIR)/usr/bin/snmpcheck
|
|
|
+ rm -f $(TARGET_DIR)/usr/bin/snmpcheck
|
|
|
# Install the "broken" headers
|
|
|
- cp $(NETSNMP_DIR)/agent/mibgroup/struct.h $(STAGING_DIR)/usr/include/net-snmp/agent
|
|
|
- cp $(NETSNMP_DIR)/agent/mibgroup/util_funcs.h $(STAGING_DIR)/usr/include/net-snmp
|
|
|
- cp $(NETSNMP_DIR)/agent/mibgroup/mibincl.h $(STAGING_DIR)/usr/include/net-snmp/library
|
|
|
- cp $(NETSNMP_DIR)/agent/mibgroup/header_complex.h $(STAGING_DIR)/usr/include/net-snmp/agent
|
|
|
+ $(INSTALL) -D -m 0644 $(NETSNMP_DIR)/agent/mibgroup/struct.h $(STAGING_DIR)/usr/include/net-snmp/agent/struct.h
|
|
|
+ $(INSTALL) -D -m 0644 $(NETSNMP_DIR)/agent/mibgroup/util_funcs.h $(STAGING_DIR)/usr/include/net-snmp/util_funcs.h
|
|
|
+ $(INSTALL) -D -m 0644 $(NETSNMP_DIR)/agent/mibgroup/mibincl.h $(STAGING_DIR)/usr/include/net-snmp/library/mibincl.h
|
|
|
+ $(INSTALL) -D -m 0644 $(NETSNMP_DIR)/agent/mibgroup/header_complex.h $(STAGING_DIR)/usr/include/net-snmp/agent/header_complex.h
|
|
|
+ $(INSTALL) -D -m 0755 package/netsnmp/S59snmpd $(TARGET_DIR)/etc/init.d/S59snmpd
|
|
|
|
|
|
netsnmp: openssl $(TARGET_DIR)/usr/sbin/snmpd
|
|
|
|
|
|
netsnmp-headers: $(TARGET_DIR)/usr/include/net-snmp/net-snmp-config.h
|
|
|
+ $(INSTALL) -d $(TARGET_DIR)/usr/include/net-snmp
|
|
|
cp -a $(STAGING_DIR)/usr/include/net-snmp $(TARGET_DIR)/usr/include/net-snmp
|
|
|
cp -a $(STAGING_DIR)/usr/include/ucd-snmp $(TARGET_DIR)/usr/include/net-snmp
|
|
|
|
|
@@ -119,6 +153,6 @@ netsnmp-dirclean:
|
|
|
# Toplevel Makefile options
|
|
|
#
|
|
|
#############################################################
|
|
|
-ifeq ($(strip $(BR2_PACKAGE_NETSNMP)),y)
|
|
|
+ifeq ($(BR2_PACKAGE_NETSNMP),y)
|
|
|
TARGETS+=netsnmp
|
|
|
endif
|