|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v4 3/4] libxl: Some optimizations in libxl_set_memory_target()
Some optimizations in libxl_set_memory_target().
Signed-off-by: Daniel Kiper <daniel.kiper@xxxxxxxxxx>
---
tools/libxl/libxl.c | 48 ++++++++++++++++++++++--------------------------
1 file changed, 22 insertions(+), 26 deletions(-)
diff --git a/tools/libxl/libxl.c b/tools/libxl/libxl.c
index 3427c13..683b700 100644
--- a/tools/libxl/libxl.c
+++ b/tools/libxl/libxl.c
@@ -3640,21 +3640,18 @@ int libxl_set_memory_target(libxl_ctx *ctx, uint32_t
domid,
{
GC_INIT(ctx);
int rc = 1, abort_transaction = 0;
- uint32_t guestkb, memorykb = 0, videoram = 0;
- uint32_t current_target_memkb = 0, new_target_memkb = 0;
- char *memmax, *endptr, *videoram_s = NULL, *target = NULL;
- char *dompath = libxl__xs_get_dompath(gc, domid);
+ uint32_t current_target_memkb, guestkb, memorykb = 0, new_target_memkb;
+ char *dompath = libxl__xs_get_dompath(gc, domid), *endptr, *s;
xc_domaininfo_t info;
libxl_dominfo ptr;
- char *uuid;
xs_transaction_t t;
retry_transaction:
t = xs_transaction_start(ctx->xsh);
- target = libxl__xs_read(gc, t, libxl__sprintf(gc,
+ s = libxl__xs_read(gc, t, libxl__sprintf(gc,
"%s/memory/target", dompath));
- if (!target && !domid) {
+ if (!s && !domid) {
xs_transaction_end(ctx->xsh, t, 1);
rc = libxl__fill_dom0_memory_info(gc, ¤t_target_memkb);
if (rc < 0) {
@@ -3662,18 +3659,18 @@ retry_transaction:
goto out;
}
goto retry_transaction;
- } else if (!target) {
+ } else if (!s) {
LIBXL__LOG_ERRNO(ctx, LIBXL__LOG_ERROR,
"cannot get target memory info from %s/memory/target\n",
dompath);
abort_transaction = 1;
goto out;
} else {
- current_target_memkb = strtoul(target, &endptr, 10);
+ current_target_memkb = strtoul(s, &endptr, 10);
if (*endptr != '\0') {
LIBXL__LOG_ERRNO(ctx, LIBXL__LOG_ERROR,
"invalid memory target %s from %s/memory/target\n",
- target, dompath);
+ s, dompath);
abort_transaction = 1;
goto out;
}
@@ -3688,21 +3685,21 @@ retry_transaction:
xcinfo2xlinfo(&info, &ptr);
- memmax = libxl__xs_read(gc, t, libxl__sprintf(gc,
+ s = libxl__xs_read(gc, t, libxl__sprintf(gc,
"%s/memory/guest-max", dompath));
- if (memmax) {
- guestkb = strtoul(memmax, &endptr, 10);
+ if (s) {
+ guestkb = strtoul(s, &endptr, 10);
if (*endptr != '\0')
guestkb = 0;
} else
guestkb = 0;
if (!guestkb) {
- memmax = libxl__xs_read(gc, t, libxl__sprintf(gc,
+ s = libxl__xs_read(gc, t, libxl__sprintf(gc,
"%s/memory/static-max", dompath));
- if (!memmax) {
+ if (!s) {
LIBXL__LOG_ERRNO(ctx, LIBXL__LOG_ERROR,
"cannot get memory info from %s/memory/static-max\n",
dompath);
@@ -3710,12 +3707,12 @@ retry_transaction:
goto out;
}
- memorykb = strtoul(memmax, &endptr, 10);
+ memorykb = strtoul(s, &endptr, 10);
if (*endptr != '\0') {
LIBXL__LOG_ERRNO(ctx, LIBXL__LOG_ERROR,
"invalid max memory %s from %s/memory/static-max\n",
- memmax, dompath);
+ s, dompath);
abort_transaction = 1;
goto out;
}
@@ -3752,18 +3749,14 @@ retry_transaction:
abort_transaction = 1;
goto out;
}
- videoram_s = libxl__xs_read(gc, t, libxl__sprintf(gc,
- "%s/memory/videoram", dompath));
- videoram = videoram_s ? atoi(videoram_s) : 0;
if (enforce) {
- memorykb = new_target_memkb;
- rc = xc_domain_setmaxmem(ctx->xch, domid, memorykb +
+ rc = xc_domain_setmaxmem(ctx->xch, domid, new_target_memkb +
LIBXL_MAXMEM_CONSTANT);
if (rc != 0) {
LIBXL__LOG_ERRNO(ctx, LIBXL__LOG_ERROR,
"xc_domain_setmaxmem domid=%d memkb=%d failed "
- "rc=%d\n", domid, memorykb + LIBXL_MAXMEM_CONSTANT, rc);
+ "rc=%d\n", domid, new_target_memkb +
LIBXL_MAXMEM_CONSTANT, rc);
abort_transaction = 1;
goto out;
}
@@ -3775,7 +3768,10 @@ retry_transaction:
goto out;
}
- new_target_memkb -= videoram;
+ s = libxl__xs_read(gc, t, libxl__sprintf(gc,
+ "%s/memory/videoram", dompath));
+ new_target_memkb -= s ? atoi(s) : 0;
+
rc = xc_domain_set_pod_target(ctx->xch, domid,
new_target_memkb / 4, NULL, NULL, NULL);
if (rc != 0) {
@@ -3790,8 +3786,8 @@ retry_transaction:
libxl__xs_write(gc, t, libxl__sprintf(gc, "%s/memory/target",
dompath), "%"PRIu32, new_target_memkb);
- uuid = libxl__uuid2string(gc, ptr.uuid);
- libxl__xs_write(gc, t, libxl__sprintf(gc, "/vm/%s/memory", uuid),
+ s = libxl__uuid2string(gc, ptr.uuid);
+ libxl__xs_write(gc, t, libxl__sprintf(gc, "/vm/%s/memory", s),
"%"PRIu32, new_target_memkb / 1024);
out:
--
1.7.10.4
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |