Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1206854imm; Wed, 11 Jul 2018 20:08:50 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdajm0k5qD53wOCm6ZYFJ8bLqe2dBT5z2dVUzDSlBRXd+h2f4EuDtgGlwpvKE4gUz+Qe+4j X-Received: by 2002:a63:6383:: with SMTP id x125-v6mr444462pgb.127.1531364930399; Wed, 11 Jul 2018 20:08:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531364930; cv=none; d=google.com; s=arc-20160816; b=B5elDzhlq0o6ptArKFOntrU+W3UV6jrsu6NCu/+KGkjpRYk+xsKoDl2EbBXLZHPO2w U4siPkza9uikQ1/aB4N/HLZ8g0HTjid2QT4DtJ4UfUjtz+TeqcUH+caljCryeFsahWxY hBXQNJpyXmXzOvxRsG/Di4F8aHdknTHpdSOsavesSFMyDFoqEL2waT8DIcdOjSS68HgH s60qH1q5fle+wC81siOuBGfcWO90e12WERYfTkFJVnDHamUCpkQYXeRp7zk+KkRO2qQD 3A1uLEy86VNqn0aedxpeoWuD2sKERO8ANx3s94zFwTJOz3/J0Bu1jsx1a0Zfitk4mfYP 5RYQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:to:from:dkim-signature:arc-authentication-results; bh=gCvt6QurdgS3KZsbEL+BvYkbmjbt98ZOD4kPsx//Qu8=; b=eNY6aY0Q23+uc400EjgadAxLaFydViKj4QEiwVQwYKawexlFEmJWTDbQcgWRqCZmO0 NpHFBjjYIoPAmEy72diJrJJG9YNq3amfcRkOYbEb6NjRacQSLtijy1IJKYA6e4RThC9A 4xsa5Z29q6rLGIrrg86mg/3nWFmB/WVub4cwA3fH/kQbAJxWO1mh9llGYmLMxKdLhzoo pRnWZB035h9LgleN++VxkjGWG/zdHM2tx7TnsOiJi6nkqEE0e/QFXsvUBauKzywlaA5w 3V8TBhxSGi1KHSL+WbEZBCQsj2JI3Ii6qUtEqfVJVth9Ike745XpK80whjDZHQcGNdwJ e2mg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b=mdHi++T6; 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=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c15-v6si19153126pgw.550.2018.07.11.20.08.35; Wed, 11 Jul 2018 20:08:50 -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; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b=mdHi++T6; 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=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391082AbeGLAOf (ORCPT + 99 others); Wed, 11 Jul 2018 20:14:35 -0400 Received: from aserp2120.oracle.com ([141.146.126.78]:35450 "EHLO aserp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390953AbeGLANK (ORCPT ); Wed, 11 Jul 2018 20:13:10 -0400 Received: from pps.filterd (aserp2120.oracle.com [127.0.0.1]) by aserp2120.oracle.com (8.16.0.22/8.16.0.22) with SMTP id w6C04aav185821; Thu, 12 Jul 2018 00:04:36 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=from : to : subject : date : message-id : in-reply-to : references; s=corp-2018-07-02; bh=gCvt6QurdgS3KZsbEL+BvYkbmjbt98ZOD4kPsx//Qu8=; b=mdHi++T6tRYl8lZs4eK3pBHvg/vM1VdgY/o3zof+apUDyWGBLhsPQFzLUchFEltYYP3l 5wMrtX5k8XnYYpbbU55eV3nSn5yQhmONHrNCOPKBMQUNsPbjghWwtbKUG7VtSPXa64p5 kHRCLXgwnalmfTlBxJpyRg0wbN6E4ofnnzqIDP1owiqlNd+NmOxJoNNY1YDuX1riCnQv j9YD3hMhpz9Gy6vrjUjJRS/K4fuLsZiUMgjVdzkhtaMXDH/mv9kSlpgW7882RxXowbu7 KOGttnhlrt442EyeC3J8cB+FN6kPP7nAYsMTLnhjiOrfp7D6Ypg8tfZWsi9XGFaT1EBG Yg== Received: from userv0022.oracle.com (userv0022.oracle.com [156.151.31.74]) by aserp2120.oracle.com with ESMTP id 2k2p7e09gf-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 12 Jul 2018 00:04:35 +0000 Received: from aserv0121.oracle.com (aserv0121.oracle.com [141.146.126.235]) by userv0022.oracle.com (8.14.4/8.14.4) with ESMTP id w6C04YDt029097 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 12 Jul 2018 00:04:35 GMT Received: from abhmp0003.oracle.com (abhmp0003.oracle.com [141.146.116.9]) by aserv0121.oracle.com (8.14.4/8.13.8) with ESMTP id w6C04Y7E031939; Thu, 12 Jul 2018 00:04:34 GMT Received: from localhost.localdomain (/73.69.118.222) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Wed, 11 Jul 2018 17:04:34 -0700 From: Pavel Tatashin To: steven.sistare@oracle.com, daniel.m.jordan@oracle.com, linux@armlinux.org.uk, schwidefsky@de.ibm.com, heiko.carstens@de.ibm.com, john.stultz@linaro.org, sboyd@codeaurora.org, x86@kernel.org, linux-kernel@vger.kernel.org, mingo@redhat.com, tglx@linutronix.de, hpa@zytor.com, douly.fnst@cn.fujitsu.com, peterz@infradead.org, prarit@redhat.com, feng.tang@intel.com, pmladek@suse.com, gnomes@lxorguk.ukuu.org.uk, linux-s390@vger.kernel.org, pasha.tatashin@oracle.com, boris.ostrovsky@oracle.com, jgross@suse.com Subject: [PATCH v13 05/18] kvm/x86: remove kvm memblock dependency Date: Wed, 11 Jul 2018 20:04:06 -0400 Message-Id: <20180712000419.5165-6-pasha.tatashin@oracle.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180712000419.5165-1-pasha.tatashin@oracle.com> References: <20180712000419.5165-1-pasha.tatashin@oracle.com> X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=8951 signatures=668706 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 suspectscore=2 malwarescore=0 phishscore=0 bulkscore=0 spamscore=0 mlxscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1806210000 definitions=main-1807110252 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org KVM clock is initialized later compared to other hypervisor because it has dependency on memblock allocator. Lets bring it inline with other hypervisors by removing this dependency by using memory from BSS instead of allocating it. The benefits: - remove ifdef from common code - earlier availability of TSC. - remove dependency on memblock, and reduce code - earlier kvm sched_clock() Signed-off-by: Pavel Tatashin Reviewed-by: Thomas Gleixner --- arch/x86/include/asm/kvm_para.h | 2 +- arch/x86/kernel/kvm.c | 1 + arch/x86/kernel/kvmclock.c | 66 +++++---------------------------- arch/x86/kernel/setup.c | 7 +--- 4 files changed, 14 insertions(+), 62 deletions(-) diff --git a/arch/x86/include/asm/kvm_para.h b/arch/x86/include/asm/kvm_para.h index 3aea2658323a..62872a862914 100644 --- a/arch/x86/include/asm/kvm_para.h +++ b/arch/x86/include/asm/kvm_para.h @@ -6,7 +6,7 @@ #include #include -extern void kvmclock_init(void); +extern void kvm_platform_init(void); extern int kvm_register_clock(char *txt); #ifdef CONFIG_KVM_GUEST diff --git a/arch/x86/kernel/kvm.c b/arch/x86/kernel/kvm.c index 5b2300b818af..874c53dd8ba2 100644 --- a/arch/x86/kernel/kvm.c +++ b/arch/x86/kernel/kvm.c @@ -628,6 +628,7 @@ const __initconst struct hypervisor_x86 x86_hyper_kvm = { .name = "KVM", .detect = kvm_detect, .type = X86_HYPER_KVM, + .init.init_platform = kvm_platform_init, .init.guest_late_init = kvm_guest_init, .init.x2apic_available = kvm_para_available, }; diff --git a/arch/x86/kernel/kvmclock.c b/arch/x86/kernel/kvmclock.c index bf8d1eb7fca3..d2af1b1f060e 100644 --- a/arch/x86/kernel/kvmclock.c +++ b/arch/x86/kernel/kvmclock.c @@ -23,9 +23,9 @@ #include #include #include -#include #include #include +#include #include #include @@ -44,6 +44,11 @@ static int parse_no_kvmclock(char *arg) } early_param("no-kvmclock", parse_no_kvmclock); +/* Aligned to page sizes to match whats mapped via vsyscalls to userspace */ +#define HV_CLOCK_SIZE (sizeof(struct pvclock_vsyscall_time_info) * NR_CPUS) +#define WALL_CLOCK_SIZE (sizeof(struct pvclock_wall_clock)) +static u8 hv_clock_mem[PAGE_ALIGN(HV_CLOCK_SIZE)] __aligned(PAGE_SIZE); +static u8 wall_clock_mem[PAGE_ALIGN(WALL_CLOCK_SIZE)] __aligned(PAGE_SIZE); /* The hypervisor will put information about time periodically here */ static struct pvclock_vsyscall_time_info *hv_clock; static struct pvclock_wall_clock *wall_clock; @@ -244,43 +249,12 @@ static void kvm_shutdown(void) native_machine_shutdown(); } -static phys_addr_t __init kvm_memblock_alloc(phys_addr_t size, - phys_addr_t align) -{ - phys_addr_t mem; - - mem = memblock_alloc(size, align); - if (!mem) - return 0; - - if (sev_active()) { - if (early_set_memory_decrypted((unsigned long)__va(mem), size)) - goto e_free; - } - - return mem; -e_free: - memblock_free(mem, size); - return 0; -} - -static void __init kvm_memblock_free(phys_addr_t addr, phys_addr_t size) -{ - if (sev_active()) - early_set_memory_encrypted((unsigned long)__va(addr), size); - - memblock_free(addr, size); -} - -void __init kvmclock_init(void) +void __init kvm_platform_init(void) { struct pvclock_vcpu_time_info *vcpu_time; - unsigned long mem, mem_wall_clock; - int size, cpu, wall_clock_size; + int cpu; u8 flags; - size = PAGE_ALIGN(sizeof(struct pvclock_vsyscall_time_info)*NR_CPUS); - if (!kvm_para_available()) return; @@ -290,28 +264,11 @@ void __init kvmclock_init(void) } else if (!(kvmclock && kvm_para_has_feature(KVM_FEATURE_CLOCKSOURCE))) return; - wall_clock_size = PAGE_ALIGN(sizeof(struct pvclock_wall_clock)); - mem_wall_clock = kvm_memblock_alloc(wall_clock_size, PAGE_SIZE); - if (!mem_wall_clock) - return; - - wall_clock = __va(mem_wall_clock); - memset(wall_clock, 0, wall_clock_size); - - mem = kvm_memblock_alloc(size, PAGE_SIZE); - if (!mem) { - kvm_memblock_free(mem_wall_clock, wall_clock_size); - wall_clock = NULL; - return; - } - - hv_clock = __va(mem); - memset(hv_clock, 0, size); + wall_clock = (struct pvclock_wall_clock *)wall_clock_mem; + hv_clock = (struct pvclock_vsyscall_time_info *)hv_clock_mem; if (kvm_register_clock("primary cpu clock")) { hv_clock = NULL; - kvm_memblock_free(mem, size); - kvm_memblock_free(mem_wall_clock, wall_clock_size); wall_clock = NULL; return; } @@ -354,13 +311,10 @@ int __init kvm_setup_vsyscall_timeinfo(void) int cpu; u8 flags; struct pvclock_vcpu_time_info *vcpu_time; - unsigned int size; if (!hv_clock) return 0; - size = PAGE_ALIGN(sizeof(struct pvclock_vsyscall_time_info)*NR_CPUS); - cpu = get_cpu(); vcpu_time = &hv_clock[cpu].pvti; diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c index 403b2d2c31d2..01fcc8bf7c8f 100644 --- a/arch/x86/kernel/setup.c +++ b/arch/x86/kernel/setup.c @@ -1014,6 +1014,8 @@ void __init setup_arch(char **cmdline_p) */ init_hypervisor_platform(); + tsc_early_delay_calibrate(); + x86_init.resources.probe_roms(); /* after parse_early_param, so could debug it */ @@ -1199,11 +1201,6 @@ void __init setup_arch(char **cmdline_p) memblock_find_dma_reserve(); -#ifdef CONFIG_KVM_GUEST - kvmclock_init(); -#endif - - tsc_early_delay_calibrate(); if (!early_xdbc_setup_hardware()) early_xdbc_register_console(); -- 2.18.0