N: Alexander Mukhin <alexander.i.mukhin@gmail.com>
F: package/hostapd/
+N: Alexander Sverdlin <alexander.sverdlin@gmail.com>
+F: package/mini-snmpd/
+
N: Alexander Varnin <fenixk19@mail.ru>
F: package/liblog4c-localtime/
source "package/macchanger/Config.in"
source "package/memcached/Config.in"
source "package/mii-diag/Config.in"
+ source "package/mini-snmpd/Config.in"
source "package/minidlna/Config.in"
source "package/minissdpd/Config.in"
source "package/mjpg-streamer/Config.in"
--- /dev/null
+From 949ae648bf7c654b8fae607a0988bfa672607156 Mon Sep 17 00:00:00 2001
+From: Patrick Rauscher <prauscher@prauscher.de>
+Date: Fri, 18 Aug 2017 17:31:23 +0200
+Subject: [PATCH] Prepend zero-byte before unsigned integers
+
+fixes #8
+
+Signed-off-by: Alexander Sverdlin <alexander.sverdlin@gmail.com>
+---
+ mib.c | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+diff --git a/mib.c b/mib.c
+index 7d2e513..a9ffbe2 100644
+--- a/mib.c
++++ b/mib.c
+@@ -207,6 +207,11 @@ static int encode_unsigned(data_t *data, int type, unsigned int ticks_value)
+ else
+ length = 1;
+
++ /* check if the integer could be interpreted negative during a signed decode and prepend a zero-byte if necessary */
++ if ((ticks_value >> (8 * (length - 1))) & 0x80) {
++ length++;
++ }
++
+ *buffer++ = type;
+ *buffer++ = length;
+ while (length--)
+--
+2.13.2
+
--- /dev/null
+From 556c8a406c9e08dd9444222e072f7eb9c82a81e8 Mon Sep 17 00:00:00 2001
+From: Patrick Rauscher <prauscher@prauscher.de>
+Date: Fri, 18 Aug 2017 17:44:32 +0200
+Subject: [PATCH] mib.c: allow unsigned integers to have an extra byte
+
+The extra byte can be needed when encoding huge unsigned numbers (i.e. 0x80000000 or higher). In this case, during encoding we need an extra byte to make sure clients decoding as signed int do not get negative numbers. For further details, see commit 949ae648
+
+Signed-off-by: Alexander Sverdlin <alexander.sverdlin@gmail.com>
+---
+ mib.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/mib.c b/mib.c
+index a9ffbe2..83cc20d 100644
+--- a/mib.c
++++ b/mib.c
+@@ -372,7 +372,7 @@ static int data_alloc(data_t *data, int type)
+ case BER_TYPE_COUNTER:
+ case BER_TYPE_GAUGE:
+ case BER_TYPE_TIME_TICKS:
+- data->max_length = sizeof(unsigned int) + 2;
++ data->max_length = sizeof(unsigned int) + 3;
+ data->encoded_length = 0;
+ data->buffer = allocate(data->max_length);
+ break;
+--
+2.13.2
+
--- /dev/null
+config BR2_PACKAGE_MINI_SNMPD
+ bool "mini-snmpd"
+ help
+ Mini SNMPd is a minimal implementation targeted at small or
+ embedded UNIX systems with limited resources
+
+ http://troglobit.com/mini-snmpd.html
--- /dev/null
+# Locally calculated
+sha256 59f84e94ef7c9ff36d243c7974a100903a4a9a0bb529b67cf6f0d3352138a86b mini-snmpd-v1.4.tar.gz
+sha256 8a43b895972a24567297f44f35dab0f5f9ed3b7db6dac0bf6094075b27ab9d56 COPYING
--- /dev/null
+################################################################################
+#
+# mini-snmpd
+#
+################################################################################
+
+MINI_SNMPD_VERSION = v1.4
+MINI_SNMPD_SITE = $(call github,troglobit,mini-snmpd,$(MINI_SNMPD_VERSION))
+MINI_SNMPD_LICENSE = GPL-2.0
+MINI_SNMPD_LICENSE_FILES = COPYING
+MINI_SNMPD_AUTORECONF = YES
+
+define MINI_SNMPD_INSTALL_INIT_SYSTEMD
+ $(INSTALL) -D -m 644 package/mini-snmpd/mini-snmpd.service \
+ $(TARGET_DIR)/usr/lib/systemd/system/mini-snmpd.service
+ mkdir -p $(TARGET_DIR)/etc/systemd/system/multi-user.target.wants
+ ln -sf ../../../../usr/lib/systemd/system/mini-snmpd.service \
+ $(TARGET_DIR)/etc/systemd/system/multi-user.target.wants/mini-snmpd.service
+endef
+
+$(eval $(autotools-package))
--- /dev/null
+[Unit]
+Description=Mini SNMP Daemon
+StartLimitIntervalSec=0
+
+[Service]
+Environment='COMMUNITY=public'
+ExecStart=/sbin/mini_snmpd -a -n -c ${COMMUNITY} $EXTRA_PARAMS
+Restart=always
+RestartSec=1
+
+[Install]
+WantedBy=multi-user.target