- Fix send/recv buffer allocation (bnc#828714)

OBS-URL: https://build.opensuse.org/package/show/Virtualization/hyper-v?expand=0&rev=64
This commit is contained in:
Olaf Hering 2013-08-01 12:26:23 +00:00 committed by Git OBS Bridge
parent 09e12a20a4
commit d22cc8ce10
3 changed files with 33 additions and 12 deletions

View File

@ -1,7 +1,7 @@
------------------------------------------------------------------- -------------------------------------------------------------------
Thu Aug 1 13:49:42 CEST 2013 - ohering@suse.de Thu Aug 1 14:21:57 CEST 2013 - ohering@suse.de
- Double the size of kvp_send_buffer, for current struct hv_kvp_msg - Fix send/recv buffer allocation (bnc#828714)
------------------------------------------------------------------- -------------------------------------------------------------------
Wed Jul 24 10:18:34 CEST 2013 - ohering@suse.de Wed Jul 24 10:18:34 CEST 2013 - ohering@suse.de

View File

@ -79,8 +79,6 @@ enum {
DNS DNS
}; };
static char kvp_send_buffer[4096 * 2];
static char kvp_recv_buffer[4096 * 2];
static struct sockaddr_nl addr; static struct sockaddr_nl addr;
static int in_hand_shake = 1; static int in_hand_shake = 1;
@ -1437,10 +1435,21 @@ int main(void)
int pool; int pool;
char *if_name; char *if_name;
struct hv_kvp_ipaddr_value *kvp_ip_val; struct hv_kvp_ipaddr_value *kvp_ip_val;
char *kvp_send_buffer;
char *kvp_recv_buffer;
size_t kvp_recv_buffer_len;
daemon(1, 0); daemon(1, 0);
openlog("KVP", 0, LOG_USER); openlog("KVP", 0, LOG_USER);
syslog(LOG_INFO, "KVP starting; pid is:%d", getpid()); syslog(LOG_INFO, "KVP starting; pid is:%d", getpid());
kvp_recv_buffer_len = NLMSG_HDRLEN + sizeof(struct cn_msg) + sizeof(struct hv_kvp_msg);
kvp_send_buffer = calloc(1, kvp_recv_buffer_len);
kvp_recv_buffer = calloc(1, kvp_recv_buffer_len);
if (!(kvp_send_buffer && kvp_recv_buffer)) {
syslog(LOG_ERR, "Failed to allocate netlink buffers");
exit(EXIT_FAILURE);
}
/* /*
* Retrieve OS release information. * Retrieve OS release information.
*/ */
@ -1514,7 +1523,7 @@ int main(void)
continue; continue;
} }
len = recvfrom(fd, kvp_recv_buffer, sizeof(kvp_recv_buffer), 0, len = recvfrom(fd, kvp_recv_buffer, kvp_recv_buffer_len, 0,
addr_p, &addr_l); addr_p, &addr_l);
if (len < 0) { if (len < 0) {

View File

@ -38,8 +38,6 @@
#include <linux/netlink.h> #include <linux/netlink.h>
#include <syslog.h> #include <syslog.h>
static char vss_recv_buffer[4096];
static char vss_send_buffer[4096];
static struct sockaddr_nl addr; static struct sockaddr_nl addr;
#ifndef SOL_NETLINK #ifndef SOL_NETLINK
@ -52,7 +50,7 @@ static int vss_do_freeze(char *dir, unsigned int cmd, char *fs_op)
int ret, fd = open(dir, O_RDONLY); int ret, fd = open(dir, O_RDONLY);
if (fd < 0) if (fd < 0)
return -1; return 1;
ret = ioctl(fd, cmd, 0); ret = ioctl(fd, cmd, 0);
syslog(LOG_INFO, "VSS: %s of %s: %s\n", fs_op, dir, strerror(errno)); syslog(LOG_INFO, "VSS: %s of %s: %s\n", fs_op, dir, strerror(errno));
close(fd); close(fd);
@ -85,9 +83,11 @@ static int vss_operate(int operation)
if (mounts == NULL) if (mounts == NULL)
return -1; return -1;
while((ent = getmntent(mounts))) { while ((ent = getmntent(mounts))) {
if (strncmp(ent->mnt_fsname, match, strlen(match))) if (strncmp(ent->mnt_fsname, match, strlen(match)))
continue; continue;
if (strcmp(ent->mnt_type, "iso9660") == 0)
continue;
if (strcmp(ent->mnt_dir, "/") == 0) { if (strcmp(ent->mnt_dir, "/") == 0) {
root_seen = 1; root_seen = 1;
continue; continue;
@ -145,6 +145,9 @@ int main(void)
struct cn_msg *incoming_cn_msg; struct cn_msg *incoming_cn_msg;
int op; int op;
struct hv_vss_msg *vss_msg; struct hv_vss_msg *vss_msg;
char *vss_send_buffer;
char *vss_recv_buffer;
size_t vss_recv_buffer_len;
if (daemon(1, 0)) if (daemon(1, 0))
return 1; return 1;
@ -152,6 +155,14 @@ int main(void)
openlog("Hyper-V VSS", 0, LOG_USER); openlog("Hyper-V VSS", 0, LOG_USER);
syslog(LOG_INFO, "VSS starting; pid is:%d", getpid()); syslog(LOG_INFO, "VSS starting; pid is:%d", getpid());
vss_recv_buffer_len = NLMSG_HDRLEN + sizeof(struct cn_msg) + sizeof(struct hv_vss_msg);
vss_send_buffer = calloc(1, vss_recv_buffer_len);
vss_recv_buffer = calloc(1, vss_recv_buffer_len);
if (!(vss_send_buffer && vss_recv_buffer)) {
syslog(LOG_ERR, "Failed to allocate netlink buffers");
exit(EXIT_FAILURE);
}
fd = socket(AF_NETLINK, SOCK_DGRAM, NETLINK_CONNECTOR); fd = socket(AF_NETLINK, SOCK_DGRAM, NETLINK_CONNECTOR);
if (fd < 0) { if (fd < 0) {
syslog(LOG_ERR, "netlink socket creation failed; error:%d", fd); syslog(LOG_ERR, "netlink socket creation failed; error:%d", fd);
@ -199,7 +210,7 @@ int main(void)
pfd.revents = 0; pfd.revents = 0;
poll(&pfd, 1, -1); poll(&pfd, 1, -1);
len = recvfrom(fd, vss_recv_buffer, sizeof(vss_recv_buffer), 0, len = recvfrom(fd, vss_recv_buffer, vss_recv_buffer_len, 0,
addr_p, &addr_l); addr_p, &addr_l);
if (len < 0) { if (len < 0) {
@ -210,8 +221,9 @@ int main(void)
} }
if (addr.nl_pid) { if (addr.nl_pid) {
syslog(LOG_WARNING, "Received packet from untrusted pid:%u", syslog(LOG_WARNING,
addr.nl_pid); "Received packet from untrusted pid:%u",
addr.nl_pid);
continue; continue;
} }