@@ -34,6 +34,7 @@ OBJ += backbonetable.o
ifeq ($(CONFIG_BATCTL_BISECT),y)
OBJ += $(OBJ_BISECT)
endif
+OBJ += claimtable.o
OBJ += debugfs.o
OBJ += debug.o
OBJ += functions.o
new file mode 100644
@@ -0,0 +1,132 @@
+// SPDX-License-Identifier: GPL-2.0
+/* Copyright (C) 2009-2018 B.A.T.M.A.N. contributors:
+ *
+ * Andrew Lunn <andrew@lunn.ch>
+ * Simon Wunderlich <sw@simonwunderlich.de>
+ * Sven Eckelmann <sven@narfation.org>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of version 2 of the GNU General Public
+ * License as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301, USA
+ *
+ * License-Filename: LICENSES/preferred/GPL-2.0
+ */
+
+#include <netinet/if_ether.h>
+#include <netlink/netlink.h>
+#include <netlink/genl/genl.h>
+#include <netlink/genl/ctrl.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <stdint.h>
+
+#include "batadv_packet.h"
+#include "batman_adv.h"
+#include "bat-hosts.h"
+#include "debug.h"
+#include "functions.h"
+#include "main.h"
+#include "netlink.h"
+
+static const int bla_claim_mandatory[] = {
+ BATADV_ATTR_BLA_ADDRESS,
+ BATADV_ATTR_BLA_VID,
+ BATADV_ATTR_BLA_BACKBONE,
+ BATADV_ATTR_BLA_CRC,
+};
+
+static int bla_claim_callback(struct nl_msg *msg, void *arg)
+{
+ struct nlattr *attrs[BATADV_ATTR_MAX+1];
+ struct nlmsghdr *nlh = nlmsg_hdr(msg);
+ struct print_opts *opts = arg;
+ struct bat_host *bat_host;
+ struct genlmsghdr *ghdr;
+ uint16_t backbone_crc;
+ uint8_t *backbone;
+ uint8_t *client;
+ uint16_t vid;
+ char c = ' ';
+
+ if (!genlmsg_valid_hdr(nlh, 0)) {
+ fputs("Received invalid data from kernel.\n", stderr);
+ exit(1);
+ }
+
+ ghdr = nlmsg_data(nlh);
+
+ if (ghdr->cmd != BATADV_CMD_GET_BLA_CLAIM)
+ return NL_OK;
+
+ if (nla_parse(attrs, BATADV_ATTR_MAX, genlmsg_attrdata(ghdr, 0),
+ genlmsg_len(ghdr), batadv_netlink_policy)) {
+ fputs("Received invalid data from kernel.\n", stderr);
+ exit(1);
+ }
+
+ if (missing_mandatory_attrs(attrs, bla_claim_mandatory,
+ ARRAY_SIZE(bla_claim_mandatory))) {
+ fputs("Missing attributes from kernel\n", stderr);
+ exit(1);
+ }
+
+ if (attrs[BATADV_ATTR_BLA_OWN])
+ c = '*';
+
+ client = nla_data(attrs[BATADV_ATTR_BLA_ADDRESS]);
+ vid = nla_get_u16(attrs[BATADV_ATTR_BLA_VID]);
+ backbone = nla_data(attrs[BATADV_ATTR_BLA_BACKBONE]);
+ backbone_crc = nla_get_u16(attrs[BATADV_ATTR_BLA_CRC]);
+
+ bat_host = bat_hosts_find_by_mac((char *)client);
+ if (!(opts->read_opt & USE_BAT_HOSTS) || !bat_host)
+ printf("%02x:%02x:%02x:%02x:%02x:%02x ",
+ client[0], client[1], client[2],
+ client[3], client[4], client[5]);
+ else
+ printf("%17s ", bat_host->name);
+
+ printf("on %5d by ", BATADV_PRINT_VID(vid));
+
+ bat_host = bat_hosts_find_by_mac((char *)backbone);
+ if (!(opts->read_opt & USE_BAT_HOSTS) || !bat_host)
+ printf("%02x:%02x:%02x:%02x:%02x:%02x ",
+ backbone[0], backbone[1], backbone[2],
+ backbone[3], backbone[4], backbone[5]);
+ else
+ printf("%17s ", bat_host->name);
+
+ printf("[%c] (0x%04x)\n", c, backbone_crc);
+
+ return NL_OK;
+}
+
+static int netlink_print_bla_claim(char *mesh_iface, char *orig_iface,
+ int read_opts, float orig_timeout,
+ float watch_interval)
+{
+ return netlink_print_common(mesh_iface, orig_iface, read_opts,
+ orig_timeout, watch_interval,
+ "Client VID Originator [o] (CRC )\n",
+ BATADV_CMD_GET_BLA_CLAIM,
+ bla_claim_callback);
+}
+
+static struct debug_table_data batctl_debug_table_claimtable = {
+ .debugfs_name = DEBUG_CLAIMTABLE,
+ .header_lines = 2,
+ .netlink_fn = netlink_print_bla_claim,
+};
+
+COMMAND_NAMED(DEBUGTABLE, claimtable, "cl", handle_debug_table,
+ COMMAND_FLAG_MESH_IFACE, &batctl_debug_table_claimtable, "");
@@ -251,15 +251,6 @@ static struct debug_table_data batctl_debug_table_transglobal = {
COMMAND_NAMED(DEBUGTABLE, transglobal, "tg", handle_debug_table,
COMMAND_FLAG_MESH_IFACE, &batctl_debug_table_transglobal, "");
-static struct debug_table_data batctl_debug_table_claimtable = {
- .debugfs_name = DEBUG_CLAIMTABLE,
- .header_lines = 2,
- .netlink_fn = netlink_print_bla_claim,
-};
-
-COMMAND_NAMED(DEBUGTABLE, claimtable, "cl", handle_debug_table,
- COMMAND_FLAG_MESH_IFACE, &batctl_debug_table_claimtable, "");
-
static struct debug_table_data batctl_debug_table_dat_cache = {
.debugfs_name = DEBUG_DAT_CACHE,
.header_lines = 2,
@@ -964,79 +964,6 @@ static int gateways_callback(struct nl_msg *msg, void *arg)
return NL_OK;
}
-static const int bla_claim_mandatory[] = {
- BATADV_ATTR_BLA_ADDRESS,
- BATADV_ATTR_BLA_VID,
- BATADV_ATTR_BLA_BACKBONE,
- BATADV_ATTR_BLA_CRC,
-};
-
-static int bla_claim_callback(struct nl_msg *msg, void *arg)
-{
- struct nlattr *attrs[BATADV_ATTR_MAX+1];
- struct nlmsghdr *nlh = nlmsg_hdr(msg);
- struct print_opts *opts = arg;
- struct bat_host *bat_host;
- struct genlmsghdr *ghdr;
- uint16_t backbone_crc;
- uint8_t *backbone;
- uint8_t *client;
- uint16_t vid;
- char c = ' ';
-
- if (!genlmsg_valid_hdr(nlh, 0)) {
- fputs("Received invalid data from kernel.\n", stderr);
- exit(1);
- }
-
- ghdr = nlmsg_data(nlh);
-
- if (ghdr->cmd != BATADV_CMD_GET_BLA_CLAIM)
- return NL_OK;
-
- if (nla_parse(attrs, BATADV_ATTR_MAX, genlmsg_attrdata(ghdr, 0),
- genlmsg_len(ghdr), batadv_netlink_policy)) {
- fputs("Received invalid data from kernel.\n", stderr);
- exit(1);
- }
-
- if (missing_mandatory_attrs(attrs, bla_claim_mandatory,
- ARRAY_SIZE(bla_claim_mandatory))) {
- fputs("Missing attributes from kernel\n", stderr);
- exit(1);
- }
-
- if (attrs[BATADV_ATTR_BLA_OWN])
- c = '*';
-
- client = nla_data(attrs[BATADV_ATTR_BLA_ADDRESS]);
- vid = nla_get_u16(attrs[BATADV_ATTR_BLA_VID]);
- backbone = nla_data(attrs[BATADV_ATTR_BLA_BACKBONE]);
- backbone_crc = nla_get_u16(attrs[BATADV_ATTR_BLA_CRC]);
-
- bat_host = bat_hosts_find_by_mac((char *)client);
- if (!(opts->read_opt & USE_BAT_HOSTS) || !bat_host)
- printf("%02x:%02x:%02x:%02x:%02x:%02x ",
- client[0], client[1], client[2],
- client[3], client[4], client[5]);
- else
- printf("%17s ", bat_host->name);
-
- printf("on %5d by ", BATADV_PRINT_VID(vid));
-
- bat_host = bat_hosts_find_by_mac((char *)backbone);
- if (!(opts->read_opt & USE_BAT_HOSTS) || !bat_host)
- printf("%02x:%02x:%02x:%02x:%02x:%02x ",
- backbone[0], backbone[1], backbone[2],
- backbone[3], backbone[4], backbone[5]);
- else
- printf("%17s ", bat_host->name);
-
- printf("[%c] (0x%04x)\n", c, backbone_crc);
-
- return NL_OK;
-}
-
static const int dat_cache_mandatory[] = {
BATADV_ATTR_DAT_CACHE_IP4ADDRESS,
BATADV_ATTR_DAT_CACHE_HWADDRESS,
@@ -1388,17 +1315,6 @@ int netlink_print_gateways(char *mesh_iface, char *orig_iface, int read_opts,
gateways_callback);
}
-int netlink_print_bla_claim(char *mesh_iface, char *orig_iface, int read_opts,
- float orig_timeout,
- float watch_interval)
-{
- return netlink_print_common(mesh_iface, orig_iface, read_opts,
- orig_timeout, watch_interval,
- "Client VID Originator [o] (CRC )\n",
- BATADV_CMD_GET_BLA_CLAIM,
- bla_claim_callback);
-}
-
int netlink_print_dat_cache(char *mesh_iface, char *orig_iface, int read_opts,
float orig_timeout, float watch_interval)
{
@@ -51,8 +51,6 @@ int netlink_print_translocal(char *mesh_iface, char *orig_iface, int read_opt,
float orig_timeout, float watch_interval);
int netlink_print_gateways(char *mesh_iface, char *orig_iface, int read_opt,
float orig_timeout, float watch_interval);
-int netlink_print_bla_claim(char *mesh_iface, char *orig_iface, int read_opt,
- float orig_timeout, float watch_interval);
int netlink_print_dat_cache(char *mesh_iface, char *orig_iface, int read_opt,
float orig_timeout, float watch_interval);
int netlink_print_mcast_flags(char *mesh_iface, char *orig_iface, int read_opt,