From: "K. Y. Srinivasan" <kys@microsoft.com>
To: gregkh@linuxfoundation.org, linux-kernel@vger.kernel.org,
devel@linuxdriverproject.org, virtualization@lists.osdl.org,
olaf@aepfle.de, apw@canonical.com, netdev@vger.kernel.org,
ben@decadent.org.uk
Cc: "K. Y. Srinivasan" <kys@microsoft.com>
Subject: [PATCH 10/17] Tools: hv: Gather ipv[4,6] gateway information
Date: Tue, 24 Jul 2012 09:01:34 -0700 [thread overview]
Message-ID: <1343145701-3691-10-git-send-email-kys@microsoft.com> (raw)
In-Reply-To: <1343145701-3691-1-git-send-email-kys@microsoft.com>
Gather information on the default gateways - ipv4/ipv6.
Signed-off-by: K. Y. Srinivasan <kys@microsoft.com>
Reviewed-by: Haiyang Zhang <haiyangz@microsoft.com>
---
tools/hv/hv_kvp_daemon.c | 72 ++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 72 insertions(+), 0 deletions(-)
diff --git a/tools/hv/hv_kvp_daemon.c b/tools/hv/hv_kvp_daemon.c
index 007e698..b627236 100644
--- a/tools/hv/hv_kvp_daemon.c
+++ b/tools/hv/hv_kvp_daemon.c
@@ -491,6 +491,72 @@ done:
return;
}
+static void kvp_process_ipconfig_file(char *cmd,
+ char *config_buf, int len,
+ int element_size, int offset)
+{
+ char buf[256];
+ char *p;
+ char *x;
+ FILE *file;
+
+ /*
+ * First execute the command.
+ */
+ file = popen(cmd, "r");
+ if (file == NULL)
+ return;
+
+ if (offset == 0)
+ memset(config_buf, 0, len);
+ while ((p = fgets(buf, sizeof(buf), file)) != NULL) {
+ if ((len - strlen(config_buf)) < (element_size + 1))
+ break;
+
+ x = strchr(p, '\n');
+ *x = '\0';
+ strcat(config_buf, p);
+ strcat(config_buf, ";");
+ }
+ pclose(file);
+}
+
+static void kvp_get_ipconfig_info(char *if_name,
+ struct hv_kvp_ipaddr_value *buffer)
+{
+ char cmd[512];
+
+ /*
+ * Get the address of default gateway (ipv4).
+ */
+ memset(cmd, 0, sizeof(cmd));
+ strcat(cmd, "/sbin/ip -f inet route | grep -w ");
+ strcat(cmd, if_name);
+ strcat(cmd, " | awk '/default/ {print $3 }'");
+
+ /*
+ * Execute the command to gather gateway info.
+ */
+ kvp_process_ipconfig_file(cmd, (char *)buffer->gate_way,
+ (MAX_GATEWAY_SIZE * 2), INET_ADDRSTRLEN, 0);
+
+ /*
+ * Get the address of default gateway (ipv6).
+ */
+ memset(cmd, 0, sizeof(cmd));
+ strcat(cmd, "/sbin/ip -f inet6 route | grep -w ");
+ strcat(cmd, if_name);
+ strcat(cmd, " | awk '/default/ {print $3 }'");
+
+ /*
+ * Execute the command to gather gateway info (ipv6).
+ */
+ kvp_process_ipconfig_file(cmd, (char *)buffer->gate_way,
+ (MAX_GATEWAY_SIZE * 2), INET6_ADDRSTRLEN, 1);
+
+}
+
+
static unsigned int hweight32(unsigned int *w)
{
unsigned int res = *w - ((*w >> 1) & 0x55555555);
@@ -649,6 +715,12 @@ kvp_get_ip_address(int family, char *if_name, int op,
strcat((char *)ip_buffer->sub_net, ";");
sn_offset += strlen(sn_str) + 1;
}
+
+ /*
+ * Collect other ip related configuration info.
+ */
+
+ kvp_get_ipconfig_info(if_name, ip_buffer);
}
gather_ipaddr:
--
1.7.4.1
next prev parent reply other threads:[~2012-07-24 15:47 UTC|newest]
Thread overview: 45+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-07-24 16:01 [PATCH 00/17] drivers: hv: kvp K. Y. Srinivasan
2012-07-24 15:54 ` Greg KH
2012-07-29 22:50 ` KY Srinivasan
2012-07-24 16:01 ` [PATCH 01/17] Drivers: hv: vmbus: Use the standard format string to format GUIDs K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 02/17] Drivers: hv: Add KVP definitions for IP address injection K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 03/17] Drivers: hv: kvp: Cleanup error handling in KVP K. Y. Srinivasan
2012-07-25 1:10 ` Ben Hutchings
2012-07-25 14:10 ` KY Srinivasan
2012-07-25 14:47 ` Ben Hutchings
2012-07-25 14:51 ` KY Srinivasan
2012-07-25 7:59 ` Olaf Hering
2012-07-24 16:01 ` [PATCH 04/17] Drivers: hv: kvp: Support the new IP injection messages K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 05/17] Tools: hv: Prepare to expand kvp_get_ip_address() functionality K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 06/17] Tools: hv: Further refactor kvp_get_ip_address() K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 07/17] Tools: hv: Gather address family information K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 08/17] Tools: hv: Gather subnet information K. Y. Srinivasan
2012-07-25 1:14 ` Ben Hutchings
2012-07-25 14:10 ` KY Srinivasan
2012-07-24 16:01 ` [PATCH 09/17] Tools: hv: Represent the ipv6 mask using CIDR notation K. Y. Srinivasan
2012-07-24 16:01 ` Borislav Petkov
2012-07-24 16:53 ` KY Srinivasan
2012-07-24 17:08 ` Borislav Petkov
2012-07-24 16:01 ` K. Y. Srinivasan [this message]
2012-07-24 16:29 ` [PATCH 10/17] Tools: hv: Gather ipv[4,6] gateway information Stephen Hemminger
2012-07-24 16:53 ` Olaf Hering
2012-07-24 16:56 ` Stephen Hemminger
2012-07-24 18:36 ` Dan Williams
2012-07-24 22:13 ` KY Srinivasan
2012-07-24 17:17 ` KY Srinivasan
2012-07-24 16:01 ` [PATCH 11/17] Tools: hv: Gather DNS information K. Y. Srinivasan
2012-07-24 23:38 ` Ben Hutchings
2012-07-24 16:01 ` [PATCH 12/17] Tools: hv: Gather DHCP information K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 13/17] Tools: hv: Implement the KVP verb - KVP_OP_SET_IP_INFO K. Y. Srinivasan
2012-07-25 1:24 ` Ben Hutchings
2012-07-25 14:48 ` KY Srinivasan
2012-07-30 17:33 ` Olaf Hering
2012-07-30 19:12 ` KY Srinivasan
2012-07-30 18:03 ` Olaf Hering
2012-07-30 18:32 ` KY Srinivasan
2012-07-30 19:19 ` Ben Hutchings
2012-07-31 10:34 ` KY Srinivasan
2012-07-24 16:01 ` [PATCH 14/17] Tools: hv: Rename the function kvp_get_ip_address() K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 15/17] Tools: hv: Implement the KVP verb - KVP_OP_GET_IP_INFO K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 16/17] Tools: hv: Get rid of some unused variables K. Y. Srinivasan
2012-07-24 16:01 ` [PATCH 17/17] Tools: hv: Correctly type string variables K. Y. Srinivasan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1343145701-3691-10-git-send-email-kys@microsoft.com \
--to=kys@microsoft.com \
--cc=apw@canonical.com \
--cc=ben@decadent.org.uk \
--cc=devel@linuxdriverproject.org \
--cc=gregkh@linuxfoundation.org \
--cc=linux-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=olaf@aepfle.de \
--cc=virtualization@lists.osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox