Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp160312yba; Thu, 25 Apr 2019 20:23:37 -0700 (PDT) X-Google-Smtp-Source: APXvYqxeRK7bA2K7R63agGBQf3ll1DrvqRCYxJPi/ZpLqxivfsS/HtWO1+btdaGcl9tSecg0zsWy X-Received: by 2002:a17:902:7883:: with SMTP id q3mr43149939pll.60.1556249016923; Thu, 25 Apr 2019 20:23:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556249016; cv=none; d=google.com; s=arc-20160816; b=jmOGg91VUT5j55ZUbCLfXw7a+k9hm74obVpZFUgVRjQfjb5gkdWq5H1CAl6e7i4NpV J5VxcIGXeD4wZwuO5K44NYDWhw/dJgJuGj0hQjcsa34+fzt4t/lJ5r1E6xWtj6cjLx2N w+wF8nq6kt48R5QAovdBcQ/DtsOhfIlmKPCFH5qxygD42QgjGNU1/cn1Z9ryKMfw3oi5 3RWLBsOpUTWINR7xbVwzMk6DdlfVX9UTz2USyjsUTirZJwAoBCoujznbpt+UNNHpGI7N EAwFIJOcWy0dVe1q9c1AXvj5QqsmPlEFLUD1IHVJGy9Ib16iPivwqY6C3nMbXNj7/1R1 7hbg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=Y6Af6uGG7sqjw7GOoHssaZ/SzPZ4ETumqdc/1ZMWr3I=; b=fzKL2MklD3czaj7W4G4rptEUGnY5/evypZAuxClxPkicUlZuBYjeP9WG0QHDOiDuoY gmGMq5FkaMx9hB4lBu5CH6rhAN6A6LKlMArJ7Gwyox8D6NzzR3D+6Q9y3++7v1/N3AL7 Xf/mA4usXPj0ZZrKE5dfl8ajbbryPZaCQkt470OWiGNnKCK5NbJJK2AR9lmWiOzgQ/EJ P0nz6tH7S4Osrhvp4QsXfu6zTs1ll6NpZq0PRZLvUX6nuYoaxam1SEKSLKuTz7c6+lxS 5qPEG6348u0YmmYN+AslQli5tGcs28milULKQTD73fKDZPYrjiXWkna4je2QdbJkkYvU qYOA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c16si2223222pgm.430.2019.04.25.20.23.22; Thu, 25 Apr 2019 20:23:36 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728651AbfDZDVV (ORCPT + 99 others); Thu, 25 Apr 2019 23:21:21 -0400 Received: from mga07.intel.com ([134.134.136.100]:35922 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726006AbfDZDVU (ORCPT ); Thu, 25 Apr 2019 23:21:20 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga105.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 25 Apr 2019 20:21:20 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.60,396,1549958400"; d="scan'208";a="137575842" Received: from genxtest-ykzhao.sh.intel.com (HELO [10.239.143.71]) ([10.239.143.71]) by orsmga008.jf.intel.com with ESMTP; 25 Apr 2019 20:21:18 -0700 Subject: Re: [RFC PATCH v5 4/4] x86/acrn: Add hypercall for ACRN guest To: Borislav Petkov Cc: Ingo Molnar , "linux-kernel@vger.kernel.org" , "x86@kernel.org" , "tglx@linutronix.de" , "Chen, Jason CJ" References: <1556067260-9128-1-git-send-email-yakui.zhao@intel.com> <1556067260-9128-5-git-send-email-yakui.zhao@intel.com> <20190425070712.GA57256@gmail.com> <6dd021a9-e2c0-ee84-55fd-3e6dfb4bd944@intel.com> <20190425110025.GA16164@zn.tnic> From: "Zhao, Yakui" Message-ID: <473d145c-4bfd-4ec8-34c3-8a26a78fe40d@intel.com> Date: Fri, 26 Apr 2019 11:18:48 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <20190425110025.GA16164@zn.tnic> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2019年04月25日 19:00, Borislav Petkov wrote: > On Thu, Apr 25, 2019 at 06:16:02PM +0800, Zhao, Yakui wrote: >> The parameter register for the VMCALL is predefined in ACRN hypervisor. Now >> the R8 is used to pass the hcall_id. >> It seems that there is no special constraint for R8~R15. >> So the explicit register variable is used so that the R8 can be passed. > > If you're going to use the constraint "D" for param1, you can just as > well do > > "=a" (result) > > everywhere since you have the letter constraint for %rax instead of > declaring it with "register". > > Also, you can completely get rid of those "register" declarations > and let gcc have all the freedom to pass in hcall_id and the other > parameters: Thanks Borislav for providing the code. It seems that it is seldom used in kernel although the explicit register variable is supported by GCC and makes the code look simpler. And it seems that the explicit register variable is not suppoorted by CLAG. So the explicit register variable will be removed. I will follow the asm code from Borislav. Of course one minor change is that the "movq" is used instead of "mov". Is this ok? Thanks > > unsigned long result; > > asm volatile("mov %[hcall_id], %%r8\n\t" > "vmcall\n\t" > : "=a" (result) > : [hcall_id] "g" (hcall_id) > : "r8"); > > return result; > > and %r8 will be in the clobber list so gcc will reload it if needed. > > gcc turns it into > > 0000000000001040
: > 1040: 4c 8b 05 e1 2f 00 00 mov 0x2fe1(%rip),%r8 # 4028 > 1047: 0f 01 c1 vmcall > 104a: c3 retq > 104b: 0f 1f 44 00 00 nopl 0x0(%rax,%rax,1) > > here. >