From mboxrd@z Thu Jan 1 00:00:00 1970 From: Konrad Rzeszutek Wilk Subject: [PATCH 2/4] libxl: vcpuset: Check max_vcpus argument against the maximum number of vCPUs the guest has set. Date: Mon, 2 Feb 2015 15:47:47 -0500 Message-ID: <1422910069-15760-3-git-send-email-konrad.wilk@oracle.com> References: <1402045657.29759.34.camel@kazak.uk.xensource.com> <1422910069-15760-1-git-send-email-konrad.wilk@oracle.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: Received: from mail6.bemta3.messagelabs.com ([195.245.230.39]) by lists.xen.org with esmtp (Exim 4.72) (envelope-from ) id 1YINuf-0007kb-CH for xen-devel@lists.xenproject.org; Mon, 02 Feb 2015 20:48:05 +0000 In-Reply-To: <1422910069-15760-1-git-send-email-konrad.wilk@oracle.com> List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Sender: xen-devel-bounces@lists.xen.org Errors-To: xen-devel-bounces@lists.xen.org To: xen-devel@lists.xenproject.org, Ian.Campbell@citrix.com, ian.jackson@eu.citrix.com, wei.liu2@citrix.com Cc: Konrad Rzeszutek Wilk List-Id: xen-devel@lists.xenproject.org The maximum number of VCPUs the guest can have is determined during domain creation and is set by 'maxvcpus' parameter (in the guest config). Trying to set the amount of vCPUs above said value in vcpuset will result in an error - and we can catch it here (instead of later in the function) and print a nice warning to the user. Signed-off-by: Konrad Rzeszutek Wilk --- tools/libxl/xl_cmdimpl.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/tools/libxl/xl_cmdimpl.c b/tools/libxl/xl_cmdimpl.c index 378ede1..d22ba85 100644 --- a/tools/libxl/xl_cmdimpl.c +++ b/tools/libxl/xl_cmdimpl.c @@ -5018,6 +5018,7 @@ static int vcpuset(uint32_t domid, const char* nr_vcpus, int check_host) char *endptr; unsigned int max_vcpus, i; libxl_bitmap cpumap; + libxl_dominfo dominfo; int rc; libxl_bitmap_init(&cpumap); @@ -5026,7 +5027,20 @@ static int vcpuset(uint32_t domid, const char* nr_vcpus, int check_host) fprintf(stderr, "Error: Invalid argument.\n"); return -ERROR_INVAL; } - + rc = libxl_domain_info(ctx, &dominfo, domid); + if (rc == ERROR_INVAL) { + fprintf(stderr, "Error: Domain %u does not exist.\n", domid); + return -rc; + } + if (rc) { + fprintf(stderr, "libxl_domain_info failed (code %d).\n", rc); + return -rc; + } + if (max_vcpus > dominfo.vcpu_max_id + 1) { + fprintf(stderr, "You have a max of %d vCPUs and you want %d vCPUs!\n", + dominfo.vcpu_max_id + 1, max_vcpus); + return -ERROR_INVAL; + } /* * Maximum amount of vCPUS the guest is allowed to set is limited * by the host's amount of pCPUs. -- 1.8.4.2