- tools: hv: Improve error logging in VSS daemon.
[opensuse:kernel-source.git] / patches.suse / msft-hv-0533-Tools-hv-fix-send-recv-buffer-allocation.patch
1 From: Olaf Hering <olaf@aepfle.de>
2 Date: Thu, 1 Aug 2013 14:34:26 +0200
3 Patch-mainline: v3.12-rc1
4 Subject: Tools: hv: fix send/recv buffer allocation
5 Git-commit: b4919a5f95c09992f66d4b7cbe392c33731a5cec
6
7 hv_kvp_daemon fails to start in current openSuSE 13.1 snapshots because
8 the kvp_send_buffer is too small to hold cn_msg+hv_kvp_msg, the very
9 first sendmsg returns with EFAULT. In addition it fixes the Network info
10 tab in Windows Server 2012R2 in SLES11.
11
12 Adjust the code in kvp and vss daemon to allocate the needed buffers at
13 runtime. To keep the code simple, the buffer_len includes also the
14 nlmsghdr, although only the recv_buffer needs this extra space.
15
16 Signed-off-by: Olaf Hering <olaf@aepfle.de>
17 Signed-off-by: K. Y. Srinivasan <kys@microsoft.com>
18 Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
19 Acked-by: <ohering@suse.de>
20 ---
21  tools/hv/hv_kvp_daemon.c | 15 ++++++++++++---
22  tools/hv/hv_vss_daemon.c | 15 ++++++++++++---
23  2 files changed, 24 insertions(+), 6 deletions(-)
24
25 diff --git a/tools/hv/hv_kvp_daemon.c b/tools/hv/hv_kvp_daemon.c
26 index 07819bf..657c1d2 100644
27 --- a/tools/hv/hv_kvp_daemon.c
28 +++ b/tools/hv/hv_kvp_daemon.c
29 @@ -79,8 +79,6 @@ enum {
30         DNS
31  };
32  
33 -static char kvp_send_buffer[4096];
34 -static char kvp_recv_buffer[4096 * 2];
35  static struct sockaddr_nl addr;
36  static int in_hand_shake = 1;
37  
38 @@ -1437,10 +1435,21 @@ int main(void)
39         int     pool;
40         char    *if_name;
41         struct hv_kvp_ipaddr_value *kvp_ip_val;
42 +       char *kvp_send_buffer;
43 +       char *kvp_recv_buffer;
44 +       size_t kvp_recv_buffer_len;
45  
46         daemon(1, 0);
47         openlog("KVP", 0, LOG_USER);
48         syslog(LOG_INFO, "KVP starting; pid is:%d", getpid());
49 +
50 +       kvp_recv_buffer_len = NLMSG_HDRLEN + sizeof(struct cn_msg) + sizeof(struct hv_kvp_msg);
51 +       kvp_send_buffer = calloc(1, kvp_recv_buffer_len);
52 +       kvp_recv_buffer = calloc(1, kvp_recv_buffer_len);
53 +       if (!(kvp_send_buffer && kvp_recv_buffer)) {
54 +               syslog(LOG_ERR, "Failed to allocate netlink buffers");
55 +               exit(EXIT_FAILURE);
56 +       }
57         /*
58          * Retrieve OS release information.
59          */
60 @@ -1514,7 +1523,7 @@ int main(void)
61                                 continue;
62                 }
63  
64 -               len = recvfrom(fd, kvp_recv_buffer, sizeof(kvp_recv_buffer), 0,
65 +               len = recvfrom(fd, kvp_recv_buffer, kvp_recv_buffer_len, 0,
66                                 addr_p, &addr_l);
67  
68                 if (len < 0) {
69 diff --git a/tools/hv/hv_vss_daemon.c b/tools/hv/hv_vss_daemon.c
70 index 826d499..4213d0e 100644
71 --- a/tools/hv/hv_vss_daemon.c
72 +++ b/tools/hv/hv_vss_daemon.c
73 @@ -38,8 +38,6 @@
74  #include <linux/netlink.h>
75  #include <syslog.h>
76  
77 -static char vss_recv_buffer[4096];
78 -static char vss_send_buffer[4096];
79  static struct sockaddr_nl addr;
80  
81  #ifndef SOL_NETLINK
82 @@ -147,6 +145,9 @@ int main(void)
83         struct cn_msg   *incoming_cn_msg;
84         int     op;
85         struct hv_vss_msg *vss_msg;
86 +       char *vss_send_buffer;
87 +       char *vss_recv_buffer;
88 +       size_t vss_recv_buffer_len;
89  
90         if (daemon(1, 0))
91                 return 1;
92 @@ -154,6 +155,14 @@ int main(void)
93         openlog("Hyper-V VSS", 0, LOG_USER);
94         syslog(LOG_INFO, "VSS starting; pid is:%d", getpid());
95  
96 +       vss_recv_buffer_len = NLMSG_HDRLEN + sizeof(struct cn_msg) + sizeof(struct hv_vss_msg);
97 +       vss_send_buffer = calloc(1, vss_recv_buffer_len);
98 +       vss_recv_buffer = calloc(1, vss_recv_buffer_len);
99 +       if (!(vss_send_buffer && vss_recv_buffer)) {
100 +               syslog(LOG_ERR, "Failed to allocate netlink buffers");
101 +               exit(EXIT_FAILURE);
102 +       }
103 +
104         fd = socket(AF_NETLINK, SOCK_DGRAM, NETLINK_CONNECTOR);
105         if (fd < 0) {
106                 syslog(LOG_ERR, "netlink socket creation failed; error:%d %s",
107 @@ -215,7 +224,7 @@ int main(void)
108                                 continue;
109                 }
110  
111 -               len = recvfrom(fd, vss_recv_buffer, sizeof(vss_recv_buffer), 0,
112 +               len = recvfrom(fd, vss_recv_buffer, vss_recv_buffer_len, 0,
113                                 addr_p, &addr_l);
114  
115                 if (len < 0) {