Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3069906yba; Mon, 8 Apr 2019 10:25:11 -0700 (PDT) X-Google-Smtp-Source: APXvYqx0u5zZzLg5d5D3S7NtjUEh9ip4N+8UWVFctRktCHvbocG1vCtesC7po2jBH5ZfGH3Tm1bp X-Received: by 2002:a17:902:784d:: with SMTP id e13mr31979021pln.152.1554744311805; Mon, 08 Apr 2019 10:25:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554744311; cv=none; d=google.com; s=arc-20160816; b=INMm7JXlbi2ndEDfGQsn6JLYL3KPr+G67JD5jnRS4Imd3lDmDZnSDEmj8Cbgj2bhOV cjpuLFsSqaniPnSgzCg+GkIlOyjGf1k+HlwyoqzPlc/AowsToa4xmIqzyDn0kMxdzIO9 eoIsIEPx0lbugQ3WvTFo/lcGB/F77Y/E6EIr2cIgjmbaZ6e92/7dYCl70cATiz2YRoj/ om82OP+SEFff/s5fnLL7I9NQMdPmXtTNgkJuWvO6IT05Vv82egKc8MQYiRp/yC9gghiL 98zlfkFDtLiWEvnUiym1mNp+S6igW8MH2wF2HR7hbHH1HM6WxPt3XBQur9lzkhgFlChH YXoQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=CzkhWpRYPOmlT9VD2G/d+dI/JEzYpliXkcMuNXJzuQo=; b=Nf7D00VvLAX0yczkKoqG3p6tDTsuPfPigp0t3zsRJXFfld2C1OhZwFk9QGeXVL5NT9 K3vbLkR7/CXWIC0Gem2lz9EnlGKaPZKXt7wYJ5pP9hAYorMoQzji+FK4/N/AoQFKsS+X 0USUxEHalhlszJbj/0i8fAcwZOvhldFJel/G3G1GWf+g15i75Znz+9gGMcErykVXuBdI ud36eNbHt+lnsb4Uw3HvpQeeKEbubkGPacEBn7MBZl2vOw1kGN1uho8UAZcV4dzXCnUK JaQ5OSo1YpwGXyZNTNT5hle6QY0qTq0Kocz2PY04gobLePh2JmSarfbamZkEiLm2A4bX KIJg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@alien8.de header.s=dkim header.b=E6ggRi1i; 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=alien8.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a13si27017584pgh.139.2019.04.08.10.24.56; Mon, 08 Apr 2019 10:25:11 -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=@alien8.de header.s=dkim header.b=E6ggRi1i; 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=alien8.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726997AbfDHPAQ (ORCPT + 99 others); Mon, 8 Apr 2019 11:00:16 -0400 Received: from mail.skyhub.de ([5.9.137.197]:47076 "EHLO mail.skyhub.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726228AbfDHPAQ (ORCPT ); Mon, 8 Apr 2019 11:00:16 -0400 Received: from zn.tnic (p200300EC2F07270021E2DB6109CF2936.dip0.t-ipconnect.de [IPv6:2003:ec:2f07:2700:21e2:db61:9cf:2936]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.skyhub.de (SuperMail on ZX Spectrum 128k) with ESMTPSA id 4BCEB1EC086F; Mon, 8 Apr 2019 17:00:15 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=alien8.de; s=dkim; t=1554735615; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:in-reply-to:in-reply-to: references:references; bh=CzkhWpRYPOmlT9VD2G/d+dI/JEzYpliXkcMuNXJzuQo=; b=E6ggRi1ip1hNuyNkwrTySvTH5TJ+H2uj1rpYnjUKr2WACi0+E40h20rI0pUnY3TuHxgS// NnNgIe1+sQ/Kv8TcDHpda7bgH1HwvfWuldW48ngwGV5iGYUN/VXKF3J+5vWKwU4NVucYPM vfwRnSzVd5j6PoCkYtUnBjS9WsGdVnU= Date: Mon, 8 Apr 2019 17:00:11 +0200 From: Borislav Petkov To: Zhao Yakui Cc: linux-kernel@vger.kernel.org, x86@kernel.org, tglx@linutronix.de, Jason Chen CJ Subject: Re: [RFC PATCH v3 3/4] x86: Use HYPERVISOR_CALLBACK_VECTOR for acrn_guest upcall vector Message-ID: <20190408150011.GH15689@zn.tnic> References: <1554711131-21514-1-git-send-email-yakui.zhao@intel.com> <1554711131-21514-4-git-send-email-yakui.zhao@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <1554711131-21514-4-git-send-email-yakui.zhao@intel.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org You can prefix your subject now like this: x86/acrn: Use ... On Mon, Apr 08, 2019 at 04:12:10PM +0800, Zhao Yakui wrote: > Linux kernel uses the HYPERVISOR_CALLBACK_VECTOR for hypervisor upcall > vector. And it is already used for Xen and HyperV. > After Acrn hypervisor is detected, it will also use this defined vector > to notify kernel. > > Co-developed-by: Jason Chen CJ > Signed-off-by: Jason Chen CJ > Signed-off-by: Zhao Yakui > --- > V1->V2: Remove the unused API definition of acrn_setup_intr_handler and > acrn_remove_intr_handler. > Adjust the order of header file > Add the declaration of acrn_hv_vector_handler and tracing > definition of acrn_hv_callback_vector. > --- > arch/x86/Kconfig | 1 + > arch/x86/entry/entry_64.S | 5 +++++ > arch/x86/include/asm/acrnhyper.h | 19 +++++++++++++++++++ > arch/x86/kernel/cpu/acrn.c | 22 ++++++++++++++++++++++ > 4 files changed, 47 insertions(+) > create mode 100644 arch/x86/include/asm/acrnhyper.h > > diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig > index d77d215..ae4d38b 100644 > --- a/arch/x86/Kconfig > +++ b/arch/x86/Kconfig > @@ -848,6 +848,7 @@ config JAILHOUSE_GUEST > config ACRN_GUEST > bool "ACRN Guest support" > depends on X86_64 > + select X86_HV_CALLBACK_VECTOR > help > This option allows to run Linux as guest in ACRN hypervisor. Enabling > this will allow the kernel to boot in virtualized environment under > diff --git a/arch/x86/entry/entry_64.S b/arch/x86/entry/entry_64.S > index 1f0efdb..d1b8ad3 100644 > --- a/arch/x86/entry/entry_64.S > +++ b/arch/x86/entry/entry_64.S > @@ -1129,6 +1129,11 @@ apicinterrupt3 HYPERV_STIMER0_VECTOR \ > hv_stimer0_callback_vector hv_stimer0_vector_handler > #endif /* CONFIG_HYPERV */ > > +#if IS_ENABLED(CONFIG_ACRN_GUEST) > +apicinterrupt3 HYPERVISOR_CALLBACK_VECTOR \ > + acrn_hv_callback_vector acrn_hv_vector_handler > +#endif > + > idtentry debug do_debug has_error_code=0 paranoid=1 shift_ist=DEBUG_STACK > idtentry int3 do_int3 has_error_code=0 > idtentry stack_segment do_stack_segment has_error_code=1 > diff --git a/arch/x86/include/asm/acrnhyper.h b/arch/x86/include/asm/acrnhyper.h > new file mode 100644 > index 0000000..9f9c239 > --- /dev/null > +++ b/arch/x86/include/asm/acrnhyper.h Simply .../acrn.h I'd say. > @@ -0,0 +1,19 @@ > +/* SPDX-License-Identifier: GPL-2.0 */ > +#ifndef _ASM_X86_ACRNHYPER_H > +#define _ASM_X86_ACRNHYPER_H > + > +#include > +#include > +#include > +#include > + > +#ifdef CONFIG_ACRN_GUEST Why is that ifdef needed? > +void acrn_hv_callback_vector(void); > +#ifdef CONFIG_TRACING > +#define trace_acrn_hv_callback_vector acrn_hv_callback_vector > +#endif > + > +void acrn_hv_vector_handler(struct pt_regs *regs); end marker: #endif /* _ASM_X86_ACRNHYPER_H */ > diff --git a/arch/x86/kernel/cpu/acrn.c b/arch/x86/kernel/cpu/acrn.c > index 3956567..7a233b5 100644 > --- a/arch/x86/kernel/cpu/acrn.c > +++ b/arch/x86/kernel/cpu/acrn.c > @@ -9,7 +9,11 @@ > * > */ > > +#include > #include > +#include > +#include > +#include What's the sorting order here? Length or alphabetic? Or none? :) linux/ path includes still need to come first, of course. -- Regards/Gruss, Boris. Good mailing practices for 400: avoid top-posting and trim the reply.