diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2014-12-17 16:10:00 +0100 |
---|---|---|
committer | Stefan Hajnoczi <stefanha@redhat.com> | 2015-01-13 11:47:56 +0000 |
commit | ee82310f8a6cc9ba9e8d1ac892f1a3cfc0debd8c (patch) | |
tree | 2e70198af3d637f0f9b99ecb0a99bff4867c5d42 /async.c | |
parent | e012b78cf5bc42f20ef1a1f78383035f2293ceea (diff) | |
download | qemu-ee82310f8a6cc9ba9e8d1ac892f1a3cfc0debd8c.zip qemu-ee82310f8a6cc9ba9e8d1ac892f1a3cfc0debd8c.tar.gz qemu-ee82310f8a6cc9ba9e8d1ac892f1a3cfc0debd8c.tar.bz2 |
block: replace g_new0 with g_new for bottom half allocation.
This saves about 15% of the clock cycles spent on allocation. Using the
slice allocator does not add a visible improvement; allocation is faster
than malloc, while freeing seems to be slower.
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'async.c')
-rw-r--r-- | async.c | 10 |
1 files changed, 6 insertions, 4 deletions
@@ -44,10 +44,12 @@ struct QEMUBH { QEMUBH *aio_bh_new(AioContext *ctx, QEMUBHFunc *cb, void *opaque) { QEMUBH *bh; - bh = g_new0(QEMUBH, 1); - bh->ctx = ctx; - bh->cb = cb; - bh->opaque = opaque; + bh = g_new(QEMUBH, 1); + *bh = (QEMUBH){ + .ctx = ctx, + .cb = cb, + .opaque = opaque, + }; qemu_mutex_lock(&ctx->bh_lock); bh->next = ctx->first_bh; /* Make sure that the members are ready before putting bh into list */ |