uint32_t current_max_memkb = 0;
char *memmax, *endptr, *videoram_s = NULL, *target = NULL;
char *dompath = libxl__xs_get_dompath(gc, domid);
- xc_domaininfo_t info;
libxl_dominfo ptr;
char *uuid;
xs_transaction_t t;
+ libxl_dominfo_init(&ptr);
+ if (libxl_domain_info(ctx, &ptr, domid) < 0)
+ goto out_no_transaction;
+
+ uuid = libxl__uuid2string(gc, ptr.uuid);
+
retry_transaction:
t = xs_transaction_start(ctx->xsh);
}
if (enforce) {
- memorykb = new_target_memkb + videoram;
- rc = xc_domain_setmaxmem(ctx->xch, domid, memorykb +
- LIBXL_MAXMEM_CONSTANT);
+ memorykb = ptr.max_memkb - current_target_memkb + new_target_memkb;
+ rc = xc_domain_setmaxmem(ctx->xch, domid, memorykb);
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, memorykb, rc);
abort_transaction = 1;
goto out;
}
libxl__xs_write(gc, t, libxl__sprintf(gc, "%s/memory/target",
dompath), "%"PRIu32, new_target_memkb);
- rc = xc_domain_getinfolist(ctx->xch, domid, 1, &info);
- if (rc != 1 || info.domain != domid) {
- abort_transaction = 1;
- goto out;
- }
- libxl_dominfo_init(&ptr);
- xcinfo2xlinfo(ctx, &info, &ptr);
- uuid = libxl__uuid2string(gc, ptr.uuid);
libxl__xs_write(gc, t, libxl__sprintf(gc, "/vm/%s/memory", uuid),
"%"PRIu32, new_target_memkb / 1024);
- libxl_dominfo_dispose(&ptr);
out:
if (!xs_transaction_end(ctx->xsh, t, abort_transaction)
goto retry_transaction;
out_no_transaction:
+ libxl_dominfo_dispose(&ptr);
GC_FREE;
return rc;
}