提交 58889fe5 编写于 作者: M Markus Armbruster 提交者: Stefan Hajnoczi

net: Use g_new() & friends where that makes obvious sense

g_new(T, n) is neater than g_malloc(sizeof(T) * n).  It's also safer,
for two reasons.  One, it catches multiplication overflowing size_t.
Two, it returns T * rather than void *, which lets the compiler catch
more type errors.

This commit only touches allocations with size arguments of the form
sizeof(T).
Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
上级 71e28e3c
...@@ -489,12 +489,12 @@ static struct mmsghdr *build_l2tpv3_vector(NetL2TPV3State *s, int count) ...@@ -489,12 +489,12 @@ static struct mmsghdr *build_l2tpv3_vector(NetL2TPV3State *s, int count)
struct iovec *iov; struct iovec *iov;
struct mmsghdr *msgvec, *result; struct mmsghdr *msgvec, *result;
msgvec = g_malloc(sizeof(struct mmsghdr) * count); msgvec = g_new(struct mmsghdr, count);
result = msgvec; result = msgvec;
for (i = 0; i < count ; i++) { for (i = 0; i < count ; i++) {
msgvec->msg_hdr.msg_name = NULL; msgvec->msg_hdr.msg_name = NULL;
msgvec->msg_hdr.msg_namelen = 0; msgvec->msg_hdr.msg_namelen = 0;
iov = g_malloc(sizeof(struct iovec) * IOVSIZE); iov = g_new(struct iovec, IOVSIZE);
msgvec->msg_hdr.msg_iov = iov; msgvec->msg_hdr.msg_iov = iov;
iov->iov_base = g_malloc(s->header_size); iov->iov_base = g_malloc(s->header_size);
iov->iov_len = s->header_size; iov->iov_len = s->header_size;
...@@ -729,7 +729,7 @@ int net_init_l2tpv3(const NetClientOptions *opts, ...@@ -729,7 +729,7 @@ int net_init_l2tpv3(const NetClientOptions *opts,
} }
s->msgvec = build_l2tpv3_vector(s, MAX_L2TPV3_MSGCNT); s->msgvec = build_l2tpv3_vector(s, MAX_L2TPV3_MSGCNT);
s->vec = g_malloc(sizeof(struct iovec) * MAX_L2TPV3_IOVCNT); s->vec = g_new(struct iovec, MAX_L2TPV3_IOVCNT);
s->header_buf = g_malloc(s->header_size); s->header_buf = g_malloc(s->header_size);
qemu_set_nonblock(fd); qemu_set_nonblock(fd);
......
...@@ -62,7 +62,7 @@ NetQueue *qemu_new_net_queue(void *opaque) ...@@ -62,7 +62,7 @@ NetQueue *qemu_new_net_queue(void *opaque)
{ {
NetQueue *queue; NetQueue *queue;
queue = g_malloc0(sizeof(NetQueue)); queue = g_new0(NetQueue, 1);
queue->opaque = opaque; queue->opaque = opaque;
queue->nq_maxlen = 10000; queue->nq_maxlen = 10000;
......
...@@ -652,7 +652,7 @@ static int slirp_guestfwd(SlirpState *s, const char *config_str, ...@@ -652,7 +652,7 @@ static int slirp_guestfwd(SlirpState *s, const char *config_str,
return -1; return -1;
} }
} else { } else {
fwd = g_malloc(sizeof(struct GuestFwd)); fwd = g_new(struct GuestFwd, 1);
fwd->hd = qemu_chr_new(buf, p, NULL); fwd->hd = qemu_chr_new(buf, p, NULL);
if (!fwd->hd) { if (!fwd->hd) {
error_report("could not open guest forwarding device '%s'", buf); error_report("could not open guest forwarding device '%s'", buf);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册