softflowd: Update to 1.0.0 9812/head
authorRosen Penev <rosenp@gmail.com>
Fri, 23 Aug 2019 19:29:29 +0000 (12:29 -0700)
committerRosen Penev <rosenp@gmail.com>
Fri, 23 Aug 2019 19:55:51 +0000 (12:55 -0700)
Development moved to GitHub. Update URLs.

Cleaned up Makefile a bit for consistency between packages.

Added patch that removes deprecated bzero.

Ran init script through shellcheck. Fixed minor warnings.

Signed-off-by: Rosen Penev <rosenp@gmail.com>
net/softflowd/Makefile
net/softflowd/files/softflowd.init
net/softflowd/patches/010-bzero.patch [new file with mode: 0644]

index 1726179a7aa81de8126deeb92317a8810b67c4b9..cf379ce7080f6ae7f70bd7bfa04e357c5ba6a701 100644 (file)
@@ -8,16 +8,21 @@
 include $(TOPDIR)/rules.mk
 
 PKG_NAME:=softflowd
-PKG_VERSION:=0.9.9
-PKG_RELEASE:=2
+PKG_VERSION:=1.0.0
+PKG_RELEASE:=1
 
 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
-PKG_SOURCE_URL:=https://storage.googleapis.com/google-code-archive-downloads/v2/code.google.com/softflowd
-PKG_HASH:=2313f2c50ea9b3f2db3524e38ec7cd71f9a6e885ac2e3b55ab037bccf8173612
+PKG_SOURCE_URL:=https://codeload.github.com/irino/softflowd/tar.gz/softflowd-$(PKG_VERSION)?
+PKG_HASH:=98aa66026d730211b45fe89670cd6ce50959846d536880b82f5afbca6281e108
+PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-softflowd-$(PKG_VERSION)
+
 PKG_MAINTAINER:=Ross Vandegrift <ross@kallisti.us>
 PKG_LICENSE:=BSD-3-Clause
+PKG_LICENSE_FILES:=LICENSE
 
 PKG_FIXUP:=autoreconf
+PKG_INSTALL:=1
+PKG_BUILD_PARALLEL:=1
 
 include $(INCLUDE_DIR)/package.mk
 
@@ -26,17 +31,13 @@ define Package/softflowd
   CATEGORY:=Network
   DEPENDS:=+libpcap
   TITLE:=softflowd
-  URL:=https://code.google.com/archive/p/softflowd/
+  URL:=https://github.com/irino/softflowd
 endef
 
 define Package/softflowd/description
        Software netflow exporter
 endef
 
-define Build/Compile
-       $(MAKE) -C $(PKG_BUILD_DIR) DESTDIR="$(PKG_INSTALL_DIR)" softflowd softflowctl
-endef
-
 define Package/softflowd/install
        $(INSTALL_DIR) $(1)/usr/sbin
        $(INSTALL_BIN) $(PKG_BUILD_DIR)/softflowd $(1)/usr/sbin/
index 98b4e349431568fb7a34bbe4f0843cf45fe82e00..3f1c5f8aa36fd28e1a735b7e637c721eea047b6d 100755 (executable)
@@ -26,7 +26,7 @@ start_instance() {
        local section="$1"
 
        config_get_bool enabled "$section" 'enabled' '0'
-       [ $enabled -gt 0 ] || return 1
+       [ "$enabled" -gt 0 ] || return 1
 
        config_get pid_file "$section" 'pid_file'
 
@@ -51,7 +51,8 @@ start_instance() {
 }
 
 start_service() {
-        mkdir -m 0755 -p /var/empty
+        mkdir -p /var/empty
+        chmod 0755 /var/empty
 
        config_load 'softflowd'
        config_foreach start_instance 'softflowd'
diff --git a/net/softflowd/patches/010-bzero.patch b/net/softflowd/patches/010-bzero.patch
new file mode 100644 (file)
index 0000000..8743a58
--- /dev/null
@@ -0,0 +1,134 @@
+--- a/freelist.c
++++ b/freelist.c
+@@ -46,7 +46,7 @@ freelist_init(struct freelist *fl, size_t allocsz)
+ {
+       size_t sizeof_fl = sizeof(fl);
+       FLOGIT((LOG_DEBUG, "%s: %s(%p, %zu)", __func__, __func__, fl, allocsz));
+-      bzero(fl, sizeof_fl);
++      memset(fl, 0, sizeof_fl);
+       fl->allocsz = roundup(allocsz, FREELIST_ALLOC_ALIGN);
+       fl->free_entries = NULL;
+ }
+--- a/ipfix.c
++++ b/ipfix.c
+@@ -388,7 +388,7 @@ ipfix_init_template_unity (struct FLOWTRACKPARAMETERS *param,
+                            u_int8_t icmp_flag, u_int8_t bi_flag,
+                            u_int16_t version) {
+   u_int index = 0, bi_index = 0, length = 0;
+-  bzero (template, sizeof (*template));
++  memset (template, 0, sizeof (*template));
+   template->h.c.set_id = htons (version == 10 ?
+                                 IPFIX_TEMPLATE_SET_ID :
+                                 NFLOW9_TEMPLATE_SET_ID);
+@@ -510,7 +510,7 @@ nflow9_init_option (u_int16_t ifidx, struct OPTION *option) {
+     NFLOW9_SOFTFLOWD_OPTION_TEMPLATE_NRECORDS *
+     sizeof (struct IPFIX_FIELD_SPECIFIER);
+-  bzero (&option_template, sizeof (option_template));
++  memset (&option_template, 0, sizeof (option_template));
+   option_template.h.c.set_id = htons (NFLOW9_OPTION_TEMPLATE_SET_ID);
+   option_template.h.c.length =
+     htons (sizeof (option_template.h) + scope_len + opt_len);
+@@ -524,7 +524,7 @@ nflow9_init_option (u_int16_t ifidx, struct OPTION *option) {
+   ipfix_init_fields (option_template.r, &option_index,
+                      field_nf9option,
+                      NFLOW9_SOFTFLOWD_OPTION_TEMPLATE_NRECORDS);
+-  bzero (&nf9opt_data, sizeof (nf9opt_data));
++  memset (&nf9opt_data, 0, sizeof (nf9opt_data));
+   nf9opt_data.c.set_id = htons (IPFIX_SOFTFLOWD_OPTION_TEMPLATE_ID);
+   nf9opt_data.c.length = htons (sizeof (nf9opt_data));
+   nf9opt_data.scope_ifidx = htonl (ifidx);
+@@ -536,7 +536,7 @@ nflow9_init_option (u_int16_t ifidx, struct OPTION *option) {
+ static void
+ ipfix_init_option (struct timeval *system_boot_time, struct OPTION *option) {
+   u_int scope_index = 0, option_index = 0;
+-  bzero (&option_template, sizeof (option_template));
++  memset (&option_template, 0, sizeof (option_template));
+   option_template.h.c.set_id = htons (IPFIX_OPTION_TEMPLATE_SET_ID);
+   option_template.h.c.length = htons (sizeof (option_template));
+   option_template.h.u.i.r.template_id =
+@@ -553,7 +553,7 @@ ipfix_init_option (struct timeval *system_boot_time, struct OPTION *option) {
+   ipfix_init_fields (option_template.r, &option_index, field_option,
+                      IPFIX_SOFTFLOWD_OPTION_TEMPLATE_NRECORDS);
+-  bzero (&option_data, sizeof (option_data));
++  memset (&option_data, 0, sizeof (option_data));
+   option_data.c.set_id = htons (IPFIX_SOFTFLOWD_OPTION_TEMPLATE_ID);
+   option_data.c.length = htons (sizeof (option_data));
+   option_data.scope_pid = htonl ((u_int32_t) option->meteringProcessId);
+@@ -809,7 +809,7 @@ send_ipfix_common (struct FLOW **flows, int num_flows,
+   last_valid = num_packets = 0;
+   for (j = 0; j < num_flows;) {
+-    bzero (packet, sizeof (packet));
++    memset (packet, 0, sizeof (packet));
+     if (version == 10) {
+       ipfix = (struct IPFIX_HEADER *) packet;
+       ipfix->version = htons (version);
+--- a/netflow9.c
++++ b/netflow9.c
+@@ -145,7 +145,7 @@ static int nf9_pkts_until_template = -1;
+ static void
+ nf9_init_template (void) {
+-  bzero (&v4_template, sizeof (v4_template));
++  memset (&v4_template, 0, sizeof (v4_template));
+   v4_template.h.c.flowset_id = htons (NFLOW9_TEMPLATE_SET_ID);
+   v4_template.h.c.length = htons (sizeof (v4_template));
+   v4_template.h.template_id = htons (NF9_SOFTFLOWD_V4_TEMPLATE_ID);
+@@ -182,7 +182,7 @@ nf9_init_template (void) {
+   v4_template.r[14].length = htons (2);
+   v4_template.r[15].type = htons (NF9_SRC_VLAN);
+   v4_template.r[15].length = htons (2);
+-  bzero (&v6_template, sizeof (v6_template));
++  memset (&v6_template, 0, sizeof (v6_template));
+   v6_template.h.c.flowset_id = htons (NFLOW9_TEMPLATE_SET_ID);
+   v6_template.h.c.length = htons (sizeof (v6_template));
+   v6_template.h.template_id = htons (NF9_SOFTFLOWD_V6_TEMPLATE_ID);
+@@ -223,7 +223,7 @@ nf9_init_template (void) {
+ static void
+ nf9_init_option (u_int16_t ifidx, struct OPTION *option) {
+-  bzero (&option_template, sizeof (option_template));
++  memset (&option_template, 0, sizeof (option_template));
+   option_template.h.c.flowset_id = htons (NFLOW9_OPTION_TEMPLATE_SET_ID);
+   option_template.h.c.length = htons (sizeof (option_template));
+   option_template.h.template_id = htons (NF9_SOFTFLOWD_OPTION_TEMPLATE_ID);
+@@ -238,7 +238,7 @@ nf9_init_option (u_int16_t ifidx, struct OPTION *option) {
+   option_template.r[1].length =
+     htons (sizeof (option_data.sampling_algorithm));
+-  bzero (&option_data, sizeof (option_data));
++  memset (&option_data, 0, sizeof (option_data));
+   option_data.c.flowset_id = htons (NF9_SOFTFLOWD_OPTION_TEMPLATE_ID);
+   option_data.c.length = htons (sizeof (option_data));
+   option_data.scope_ifidx = htonl (ifidx);
+@@ -257,7 +257,7 @@ nf_flow_to_flowset (const struct FLOW *flow, u_char * packet, u_int len,
+   struct NF9_SOFTFLOWD_DATA_COMMON *dc[2];
+   u_int freclen, ret_len, nflows;
+-  bzero (d, sizeof (d));
++  memset (d, 0, sizeof (d));
+   *len_used = nflows = ret_len = 0;
+   switch (flow->af) {
+   case AF_INET:
+@@ -363,7 +363,7 @@ send_netflow_v9 (struct SENDPARAMETER sp) {
+   last_valid = num_packets = 0;
+   for (j = 0; j < num_flows;) {
+-    bzero (packet, sizeof (packet));
++    memset (packet, 0, sizeof (packet));
+     nf9 = (struct NFLOW9_HEADER *) packet;
+     nf9->version = htons (9);
+--- a/psamp.c
++++ b/psamp.c
+@@ -51,7 +51,7 @@ static int psamp_pkts_until_template = -1;
+ static void
+ psamp_init_template (struct PSAMP_SOFTFLOWD_TEMPLATE *template_p) {
+   u_int index = 0;
+-  bzero (template_p, sizeof (*template_p));
++  memset (template_p, 0, sizeof (*template_p));
+   template_p->h.c.set_id = htons (IPFIX_TEMPLATE_SET_ID);
+   template_p->h.c.length = htons (sizeof (struct PSAMP_SOFTFLOWD_TEMPLATE));
+   template_p->h.r.template_id = htons (PSAMP_SOFTFLOWD_TEMPLATE_ID);