From: Nuno Das Neves <nunodasneves@linux.microsoft.com>
To: Michael Kelley <mhklinux@outlook.com>,
Stanislav Kinsburskii <skinsburskii@linux.microsoft.com>
Cc: "linux-hyperv@vger.kernel.org" <linux-hyperv@vger.kernel.org>,
"x86@kernel.org" <x86@kernel.org>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"linux-arch@vger.kernel.org" <linux-arch@vger.kernel.org>,
"linux-acpi@vger.kernel.org" <linux-acpi@vger.kernel.org>,
"kys@microsoft.com" <kys@microsoft.com>,
"haiyangz@microsoft.com" <haiyangz@microsoft.com>,
"wei.liu@kernel.org" <wei.liu@kernel.org>,
"decui@microsoft.com" <decui@microsoft.com>,
"catalin.marinas@arm.com" <catalin.marinas@arm.com>,
"will@kernel.org" <will@kernel.org>,
"tglx@linutronix.de" <tglx@linutronix.de>,
"mingo@redhat.com" <mingo@redhat.com>,
"bp@alien8.de" <bp@alien8.de>,
"dave.hansen@linux.intel.com" <dave.hansen@linux.intel.com>,
"hpa@zytor.com" <hpa@zytor.com>,
"daniel.lezcano@linaro.org" <daniel.lezcano@linaro.org>,
"joro@8bytes.org" <joro@8bytes.org>,
"robin.murphy@arm.com" <robin.murphy@arm.com>,
"arnd@arndb.de" <arnd@arndb.de>,
"jinankjain@linux.microsoft.com" <jinankjain@linux.microsoft.com>,
"muminulrussell@gmail.com" <muminulrussell@gmail.com>,
"mrathor@linux.microsoft.com" <mrathor@linux.microsoft.com>,
"ssengar@linux.microsoft.com" <ssengar@linux.microsoft.com>,
"apais@linux.microsoft.com" <apais@linux.microsoft.com>,
"Tianyu.Lan@microsoft.com" <Tianyu.Lan@microsoft.com>,
"stanislav.kinsburskiy@gmail.com"
<stanislav.kinsburskiy@gmail.com>,
"gregkh@linuxfoundation.org" <gregkh@linuxfoundation.org>,
"vkuznets@redhat.com" <vkuznets@redhat.com>,
"prapal@linux.microsoft.com" <prapal@linux.microsoft.com>,
"muislam@microsoft.com" <muislam@microsoft.com>,
"anrayabh@linux.microsoft.com" <anrayabh@linux.microsoft.com>,
"rafael@kernel.org" <rafael@kernel.org>,
"lenb@kernel.org" <lenb@kernel.org>,
"corbet@lwn.net" <corbet@lwn.net>
Subject: Re: [PATCH v5 08/10] x86: hyperv: Add mshv_handler irq handler and setup function
Date: Mon, 10 Mar 2025 14:46:45 -0700 [thread overview]
Message-ID: <71a95f7d-d38b-4f4f-b384-9ad4095bd272@linux.microsoft.com> (raw)
In-Reply-To: <SN6PR02MB41573673D5F786E6C47FC08ED4D52@SN6PR02MB4157.namprd02.prod.outlook.com>
On 3/7/2025 9:38 AM, Michael Kelley wrote:
> From: Nuno Das Neves <nunodasneves@linux.microsoft.com> Sent: Friday, February 28, 2025 4:38 PM
>>
>> On 2/26/2025 3:43 PM, Stanislav Kinsburskii wrote:
>>> On Wed, Feb 26, 2025 at 03:08:02PM -0800, Nuno Das Neves wrote:
>>>> This will handle SYNIC interrupts such as intercepts, doorbells, and
>>>> scheduling messages intended for the mshv driver.
>>>>
>>>> Signed-off-by: Nuno Das Neves <nunodasneves@linux.microsoft.com>
>>>> Reviewed-by: Wei Liu <wei.liu@kernel.org>
>>>> Reviewed-by: Tianyu Lan <tiala@microsoft.com>
>>>> ---
>>>> arch/x86/kernel/cpu/mshyperv.c | 9 +++++++++
>>>> drivers/hv/hv_common.c | 5 +++++
>>>> include/asm-generic/mshyperv.h | 1 +
>>>> 3 files changed, 15 insertions(+)
>>>>
>>>> diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c
>>>> index 0116d0e96ef9..616e9a5d77b4 100644
>>>> --- a/arch/x86/kernel/cpu/mshyperv.c
>>>> +++ b/arch/x86/kernel/cpu/mshyperv.c
>>>> @@ -107,6 +107,7 @@ void hv_set_msr(unsigned int reg, u64 value)
>>>> }
>>>> EXPORT_SYMBOL_GPL(hv_set_msr);
>>>>
>>>> +static void (*mshv_handler)(void);
>>>> static void (*vmbus_handler)(void);
>>>> static void (*hv_stimer0_handler)(void);
>>>> static void (*hv_kexec_handler)(void);
>>>> @@ -117,6 +118,9 @@ DEFINE_IDTENTRY_SYSVEC(sysvec_hyperv_callback)
>>>> struct pt_regs *old_regs = set_irq_regs(regs);
>>>>
>>>> inc_irq_stat(irq_hv_callback_count);
>>>> + if (mshv_handler)
>>>> + mshv_handler();
>>>
>>> Can mshv_handler be defined as a weak symbol doing nothing instead
>>> of defining it a null pointer?
>>> This should allow to simplify this code and get rid of
>>> hv_setup_mshv_handler, which looks redundant.
>>>
>> Interesting, I tested this and it does seems to work! It seems like
>> a good change, thanks.
>
> Just be a bit careful. When CONFIG_HYPERV=n, mshyperv.c still gets
> built even through none of the other Hyper-V related files do. There
> are #ifdef CONFIG_HYPERV in mshyperv.c to eliminate references to
> Hyper-V files that wouldn't be built. I'd suggest doing a test build with
> that configuration to make sure it's all clean.
>
Thanks Michael - I don't think it would be an issue since the __weak version
would be defined in mshyperv.c itself, replacing the function pointer.
However, I went and tested this __weak version again with CONFIG_MSHV_ROOT=m
and it does not actually work. Everything seems ok at first (it compiles,
can insert the module), but upon starting a guest, the interrupts don't get
delivered to the root (or rather, they don't get handled by mshv_hander()).
This seems to match with what the ld docs say - There's an option
LD_DYNAMIC_LINK to allow __weak symbols to be overridden by the dynamic
linker, but this is not enabled in the kernel.
So I will stick with the current implementation.
Nuno
> Michael
>
>>
>>> Reviewed-by: Stanislav Kinsburskii <skinsburskii@linux.microsoft.com>
>>>
>>>> +
>>>> if (vmbus_handler)
>>>> vmbus_handler();
>>>>
>>>> @@ -126,6 +130,11 @@ DEFINE_IDTENTRY_SYSVEC(sysvec_hyperv_callback)
>>>> set_irq_regs(old_regs);
>>>> }
>>>>
>>>> +void hv_setup_mshv_handler(void (*handler)(void))
>>>> +{
>>>> + mshv_handler = handler;
>>>> +}
>>>> +
>>>> void hv_setup_vmbus_handler(void (*handler)(void))
>>>> {
>>>> vmbus_handler = handler;
>>>> diff --git a/drivers/hv/hv_common.c b/drivers/hv/hv_common.c
>>>> index 2763cb6d3678..f5a07fd9a03b 100644
>>>> --- a/drivers/hv/hv_common.c
>>>> +++ b/drivers/hv/hv_common.c
>>>> @@ -677,6 +677,11 @@ void __weak hv_remove_vmbus_handler(void)
>>>> }
>>>> EXPORT_SYMBOL_GPL(hv_remove_vmbus_handler);
>>>>
>>>> +void __weak hv_setup_mshv_handler(void (*handler)(void))
>>>> +{
>>>> +}
>>>> +EXPORT_SYMBOL_GPL(hv_setup_mshv_handler);
>>>> +
>>>> void __weak hv_setup_kexec_handler(void (*handler)(void))
>>>> {
>>>> }
>>>> diff --git a/include/asm-generic/mshyperv.h b/include/asm-generic/mshyperv.h
>>>> index 1f46d19a16aa..a05f12e63ccd 100644
>>>> --- a/include/asm-generic/mshyperv.h
>>>> +++ b/include/asm-generic/mshyperv.h
>>>> @@ -208,6 +208,7 @@ void hv_setup_kexec_handler(void (*handler)(void));
>>>> void hv_remove_kexec_handler(void);
>>>> void hv_setup_crash_handler(void (*handler)(struct pt_regs *regs));
>>>> void hv_remove_crash_handler(void);
>>>> +void hv_setup_mshv_handler(void (*handler)(void));
>>>>
>>>> extern int vmbus_interrupt;
>>>> extern int vmbus_irq;
>>>> --
>>>> 2.34.1
>>>>
>
next prev parent reply other threads:[~2025-03-10 21:47 UTC|newest]
Thread overview: 108+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-26 23:07 [PATCH v5 00/10] Introduce /dev/mshv root partition driver Nuno Das Neves
2025-02-26 23:07 ` [PATCH v5 01/10] hyperv: Convert Hyper-V status codes to strings Nuno Das Neves
2025-02-26 23:26 ` Stanislav Kinsburskii
2025-02-27 4:22 ` Easwar Hariharan
2025-02-27 23:48 ` Nuno Das Neves
2025-02-27 17:02 ` Roman Kisel
2025-02-27 22:54 ` Easwar Hariharan
2025-02-27 23:08 ` Roman Kisel
2025-02-27 23:25 ` Easwar Hariharan
2025-02-28 17:20 ` Roman Kisel
2025-02-28 20:22 ` Easwar Hariharan
2025-02-28 22:26 ` Roman Kisel
2025-02-27 23:21 ` Roman Kisel
2025-02-28 0:15 ` Nuno Das Neves
2025-02-28 16:40 ` Roman Kisel
2025-03-06 17:57 ` Michael Kelley
2025-03-06 18:09 ` Michael Kelley
2025-03-06 18:40 ` Nuno Das Neves
2025-03-06 18:57 ` Michael Kelley
2025-03-07 19:38 ` Nuno Das Neves
2025-02-26 23:07 ` [PATCH v5 02/10] x86/mshyperv: Add support for extended Hyper-V features Nuno Das Neves
2025-02-26 23:27 ` Stanislav Kinsburskii
2025-02-27 17:59 ` Roman Kisel
2025-02-28 0:17 ` Nuno Das Neves
2025-02-28 16:42 ` Roman Kisel
2025-02-27 18:17 ` Easwar Hariharan
2025-03-06 18:30 ` Michael Kelley
2025-03-12 18:04 ` Nuno Das Neves
2025-03-10 13:17 ` Tianyu Lan
2025-02-26 23:07 ` [PATCH v5 03/10] arm64/hyperv: Add some missing functions to arm64 Nuno Das Neves
2025-02-26 23:27 ` Stanislav Kinsburskii
2025-02-27 5:56 ` Easwar Hariharan
2025-02-28 0:21 ` Nuno Das Neves
2025-03-06 19:05 ` Michael Kelley
2025-03-07 21:36 ` Nuno Das Neves
2025-03-07 21:55 ` Easwar Hariharan
2025-02-27 18:09 ` Roman Kisel
2025-02-26 23:07 ` [PATCH v5 04/10] hyperv: Introduce hv_recommend_using_aeoi() Nuno Das Neves
2025-02-26 23:28 ` Stanislav Kinsburskii
2025-02-27 18:04 ` Roman Kisel
2025-02-28 0:21 ` Nuno Das Neves
2025-02-27 23:03 ` Easwar Hariharan
2025-02-28 0:33 ` Nuno Das Neves
2025-02-28 0:49 ` Easwar Hariharan
2025-03-06 19:12 ` Michael Kelley
2025-03-10 12:51 ` Tianyu Lan
2025-02-26 23:07 ` [PATCH v5 05/10] acpi: numa: Export node_to_pxm() Nuno Das Neves
2025-02-26 23:31 ` Stanislav Kinsburskii
2025-02-27 23:05 ` Easwar Hariharan
2025-03-06 19:16 ` Michael Kelley
2025-03-10 12:50 ` Tianyu Lan
2025-02-26 23:08 ` [PATCH v5 06/10] Drivers/hv: Export some functions for use by root partition module Nuno Das Neves
2025-02-26 23:32 ` Stanislav Kinsburskii
2025-02-27 18:11 ` Roman Kisel
2025-02-28 0:51 ` Easwar Hariharan
2025-03-06 19:23 ` Michael Kelley
2025-03-07 21:38 ` Nuno Das Neves
2025-02-26 23:08 ` [PATCH v5 07/10] Drivers: hv: Introduce per-cpu event ring tail Nuno Das Neves
2025-02-26 23:39 ` Stanislav Kinsburskii
2025-03-07 17:02 ` Michael Kelley
2025-03-07 22:06 ` Nuno Das Neves
2025-03-07 23:21 ` Michael Kelley
2025-03-07 23:31 ` Nuno Das Neves
2025-03-07 23:37 ` Michael Kelley
2025-03-10 13:01 ` Tianyu Lan
2025-03-12 19:44 ` Nuno Das Neves
2025-03-13 7:34 ` Tianyu Lan
2025-03-13 15:56 ` Nuno Das Neves
2025-03-13 16:00 ` Tianyu Lan
2025-02-26 23:08 ` [PATCH v5 08/10] x86: hyperv: Add mshv_handler irq handler and setup function Nuno Das Neves
2025-02-26 23:43 ` Stanislav Kinsburskii
2025-03-01 0:38 ` Nuno Das Neves
2025-03-07 17:38 ` Michael Kelley
2025-03-10 21:46 ` Nuno Das Neves [this message]
2025-03-10 22:23 ` Michael Kelley
2025-03-07 17:44 ` Michael Kelley
2025-03-07 23:29 ` Nuno Das Neves
2025-03-07 23:45 ` Michael Kelley
2025-02-26 23:08 ` [PATCH v5 09/10] hyperv: Add definitions for root partition driver to hv headers Nuno Das Neves
2025-02-26 23:51 ` Stanislav Kinsburskii
2025-03-01 0:46 ` Nuno Das Neves
2025-02-27 18:13 ` Roman Kisel
2025-02-28 1:27 ` Easwar Hariharan
2025-03-01 0:52 ` Nuno Das Neves
2025-03-07 17:26 ` Michael Kelley
2025-03-07 23:35 ` Nuno Das Neves
2025-03-10 12:40 ` Tianyu Lan
2025-03-12 20:17 ` Nuno Das Neves
2025-02-26 23:08 ` [PATCH v5 10/10] Drivers: hv: Introduce mshv_root module to expose /dev/mshv to VMMs Nuno Das Neves
2025-02-27 4:59 ` Easwar Hariharan
2025-03-01 1:29 ` Nuno Das Neves
2025-02-27 18:50 ` Roman Kisel
2025-03-01 1:38 ` Nuno Das Neves
2025-03-06 17:32 ` Wei Liu
2025-03-07 18:06 ` Roman Kisel
2025-03-11 18:01 ` Jeff Johnson
2025-03-14 19:25 ` Nuno Das Neves
2025-03-13 16:43 ` Michael Kelley
2025-03-14 2:15 ` Nuno Das Neves
2025-03-14 3:27 ` Michael Kelley
2025-03-17 23:51 ` Michael Kelley
2025-03-18 17:24 ` Wei Liu
2025-03-18 17:45 ` Michael Kelley
2025-03-18 20:07 ` Wei Liu
2025-03-19 0:34 ` Nuno Das Neves
2025-03-19 2:10 ` Michael Kelley
2025-03-19 15:26 ` Michael Kelley
2025-03-19 18:04 ` Nuno Das Neves
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=71a95f7d-d38b-4f4f-b384-9ad4095bd272@linux.microsoft.com \
--to=nunodasneves@linux.microsoft.com \
--cc=Tianyu.Lan@microsoft.com \
--cc=anrayabh@linux.microsoft.com \
--cc=apais@linux.microsoft.com \
--cc=arnd@arndb.de \
--cc=bp@alien8.de \
--cc=catalin.marinas@arm.com \
--cc=corbet@lwn.net \
--cc=daniel.lezcano@linaro.org \
--cc=dave.hansen@linux.intel.com \
--cc=decui@microsoft.com \
--cc=gregkh@linuxfoundation.org \
--cc=haiyangz@microsoft.com \
--cc=hpa@zytor.com \
--cc=jinankjain@linux.microsoft.com \
--cc=joro@8bytes.org \
--cc=kys@microsoft.com \
--cc=lenb@kernel.org \
--cc=linux-acpi@vger.kernel.org \
--cc=linux-arch@vger.kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-hyperv@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mhklinux@outlook.com \
--cc=mingo@redhat.com \
--cc=mrathor@linux.microsoft.com \
--cc=muislam@microsoft.com \
--cc=muminulrussell@gmail.com \
--cc=prapal@linux.microsoft.com \
--cc=rafael@kernel.org \
--cc=robin.murphy@arm.com \
--cc=skinsburskii@linux.microsoft.com \
--cc=ssengar@linux.microsoft.com \
--cc=stanislav.kinsburskiy@gmail.com \
--cc=tglx@linutronix.de \
--cc=vkuznets@redhat.com \
--cc=wei.liu@kernel.org \
--cc=will@kernel.org \
--cc=x86@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.