All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jan Beulich <jbeulich@suse.com>
To: Oleksii Kurochko <oleksii.kurochko@gmail.com>
Cc: "Alistair Francis" <alistair.francis@wdc.com>,
	"Connor Davis" <connojdavis@gmail.com>,
	"Andrew Cooper" <andrew.cooper3@citrix.com>,
	"Anthony PERARD" <anthony.perard@vates.tech>,
	"Michal Orzel" <michal.orzel@amd.com>,
	"Julien Grall" <julien@xen.org>,
	"Roger Pau Monné" <roger.pau@citrix.com>,
	"Stefano Stabellini" <sstabellini@kernel.org>,
	"Romain Caritey" <Romain.Caritey@microchip.com>,
	xen-devel@lists.xenproject.org
Subject: Re: [PATCH v2 09/16] xen/riscv: introduce vcpu_kick() implementation
Date: Mon, 9 Feb 2026 13:54:24 +0100	[thread overview]
Message-ID: <089aeecb-4e58-407d-aa4d-e09f88f861a0@suse.com> (raw)
In-Reply-To: <d82c9acd-9a51-4a1a-af0f-ef3aba515bb0@gmail.com>

On 09.02.2026 13:35, Oleksii Kurochko wrote:
> On 2/9/26 10:51 AM, Jan Beulich wrote:
>> On 09.02.2026 10:40, Oleksii Kurochko wrote:
>>> On 2/9/26 10:07 AM, Jan Beulich wrote:
>>>> On 06.02.2026 17:36, Oleksii Kurochko wrote:
>>>>> On 1/22/26 5:47 PM, Oleksii Kurochko wrote:
>>>>>> Add a RISC-V implementation of vcpu_kick(), which unblocks the target
>>>>>> vCPU and sends an event check IPI if the vCPU was running on another
>>>>>> processor. This mirrors the behavior of Arm and enables proper vCPU
>>>>>> wakeup handling on RISC-V.
>>>>>>
>>>>>> Remove the stub implementation from stubs.c, as it is now provided by
>>>>>> arch/riscv/domain.c.
>>>>>>
>>>>>> Signed-off-by: Oleksii Kurochko <oleksii.kurochko@gmail.com>
>>>>>> Acked-by: Jan Beulich <jbeulich@suse.com>
>>>>>> ---
>>>>>> Changes in v2:
>>>>>>     - Add Acked-by: Jan Beulich <jbeulich@suse.com>.
>>>>>> ---
>>>>>>     xen/arch/riscv/domain.c | 14 ++++++++++++++
>>>>>>     xen/arch/riscv/stubs.c  |  5 -----
>>>>>>     2 files changed, 14 insertions(+), 5 deletions(-)
>>>>>>
>>>>>> diff --git a/xen/arch/riscv/domain.c b/xen/arch/riscv/domain.c
>>>>>> index e38c0db62cac..13ac384c4b76 100644
>>>>>> --- a/xen/arch/riscv/domain.c
>>>>>> +++ b/xen/arch/riscv/domain.c
>>>>>> @@ -1,8 +1,10 @@
>>>>>>     /* SPDX-License-Identifier: GPL-2.0-only */
>>>>>>     
>>>>>> +#include <xen/cpumask.h>
>>>>>>     #include <xen/init.h>
>>>>>>     #include <xen/mm.h>
>>>>>>     #include <xen/sched.h>
>>>>>> +#include <xen/smp.h>
>>>>>>     #include <xen/vmap.h>
>>>>>>     
>>>>>>     #include <asm/bitops.h>
>>>>>> @@ -240,3 +242,15 @@ void vcpu_sync_interrupts(struct vcpu *v)
>>>>>>     #   error "Update vsieh"
>>>>>>     #endif
>>>>>>     }
>>>>>> +
>>>>>> +void vcpu_kick(struct vcpu *v)
>>>>>> +{
>>>>>> +    bool running = v->is_running;
>>>>>> +
>>>>>> +    vcpu_unblock(v);
>>>>>> +    if ( running && v != current )
>>>>>> +    {
>>>>>> +        perfc_incr(vcpu_kick);
>>>>> Because of this it is needed to introduce:
>>>>>      PERFCOUNTER(vcpu_kick, "vcpu: notify other vcpu")
>>>>> Otherwise randconfig build will fail when CONFIG_PERF_COUNTERS=y.
>>>>>
>>>>> I would like to ask if it would be okay to add it xen/include/xen/perfc_defn.h
>>>>> just after PERFCOUNTER(need_flush_tlb_flush,...) or would it be better to have
>>>>> it in arch specific perfc_defn.h?
>>>> Arch-specific please - it's not used by x86 nor ppc.
>>> Then I will do the following changes:
>>>
>>> diff --git a/xen/arch/riscv/include/asm/Makefile b/xen/arch/riscv/include/asm/Makefile
>>> index 3824f31c395c..86c56251d5d7 100644
>>> --- a/xen/arch/riscv/include/asm/Makefile
>>> +++ b/xen/arch/riscv/include/asm/Makefile
>>> @@ -7,7 +7,6 @@ generic-y += hypercall.h
>>>    generic-y += iocap.h
>>>    generic-y += irq-dt.h
>>>    generic-y += percpu.h
>>> -generic-y += perfc_defn.h
>>>    generic-y += random.h
>>>    generic-y += softirq.h
>>>    generic-y += vm_event.h
>>> diff --git a/xen/arch/riscv/include/asm/perfc_defn.h b/xen/arch/riscv/include/asm/perfc_defn.h
>>> new file mode 100644
>>> index 000000000000..4fc161f1abad
>>> --- /dev/null
>>> +++ b/xen/arch/riscv/include/asm/perfc_defn.h
>>> @@ -0,0 +1,7 @@
>>> +/* This file is intended to be included multiple times. */
>>> +/*#ifndef __XEN_PERFC_DEFN_H__*/
>>> +/*#define __XEN_PERFC_DEFN_H__*/
>>> +
>>> +PERFCOUNTER(vcpu_kick, "vcpu: notify other vcpu")
>>> +
>>> +/*#endif*/ /* __XEN_PERFC_DEFN_H__ */
>>>
>>> and add the following to commit message:
>>>       Since vcpu_kick() calls perfc_incr(vcpu_kick), add perfcounter for
>>>       vcpu_kick to handle the case when CONFIG_PERF_COUNTERS=y. Although
>>>       CONFIG_PERF_COUNTERS is not enabled by default, it can be enabled,
>>>       for example, by randconfig what will lead to CI build issues.
>>>
>>> Note that I keep __XEN_PERFC_DEFN_H__ as other archictectures use the same,
>>> not something like ASM__<arch>__PERFC_DEFN_H.
>> Please don't copy this mistake. I actually question the commented-out pre-
>> processor directives altogether: Misra also has a rule against commented-
>> out code (directive 4.4, which we didn't accept [yet], but which exists
>> nevertheless). Yet at the very least what's commented out should not be
>> obviously wrong.
> 
> Do I understand correctly that it would be acceptable to simply drop the
> commented-out preprocessor directives and keep only /* This file is intended
> to be included multiple times. */ ?

I think so, yes. You could simply check how the same situation is covered
for elsewhere.

Jan


  reply	other threads:[~2026-02-09 12:54 UTC|newest]

Thread overview: 65+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-01-22 16:47 [PATCH v2 00/16] xen/riscv: introduce vtimer related things Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 01/16] xen/riscv: introduce struct arch_vcpu Oleksii Kurochko
2026-01-26 11:41   ` Jan Beulich
2026-01-26 12:30     ` Oleksii Kurochko
2026-01-26 12:53       ` Jan Beulich
2026-01-26 14:22         ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 02/16] xen/riscv: implement arch_vcpu_{create,destroy}() Oleksii Kurochko
2026-01-23 11:30   ` Teddy Astie
2026-01-26  9:00     ` Oleksii Kurochko
2026-01-26 11:47       ` Jan Beulich
2026-01-26 12:07         ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 03/16] xen/riscv: implement vcpu_csr_init() Oleksii Kurochko
2026-01-24 22:44   ` Teddy Astie
2026-01-26  8:36     ` Jan Beulich
2026-01-26  9:47       ` Oleksii Kurochko
2026-01-26  9:54         ` Jan Beulich
2026-01-26  9:39     ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 04/16] xen/riscv: introduce tracking of pending vCPU interrupts, part 1 Oleksii Kurochko
2026-01-29 16:44   ` Jan Beulich
2026-02-02 10:16     ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 05/16] xen/riscv: introduce tracking of pending vCPU interrupts, part 2 Oleksii Kurochko
2026-01-29 17:01   ` Jan Beulich
2026-02-02 10:50     ` Oleksii Kurochko
2026-02-02 14:22       ` Jan Beulich
2026-01-22 16:47 ` [PATCH v2 06/16] xen/time: move ticks<->ns helpers to common code Oleksii Kurochko
2026-01-29  8:48   ` Jan Beulich
2026-02-04  8:13     ` Jan Beulich
2026-02-04  9:00       ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 07/16] xen/riscv: introduce basic vtimer infrastructure for guests Oleksii Kurochko
2026-02-03 15:47   ` Jan Beulich
2026-02-03 16:55     ` Oleksii Kurochko
2026-02-03 17:04       ` Jan Beulich
2026-01-22 16:47 ` [PATCH v2 08/16] xen/riscv: add temporary stub for smp_send_event_check_mask() Oleksii Kurochko
2026-01-29 16:32   ` Jan Beulich
2026-01-29 16:46     ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 09/16] xen/riscv: introduce vcpu_kick() implementation Oleksii Kurochko
2026-02-06 16:36   ` Oleksii Kurochko
2026-02-09  9:07     ` Jan Beulich
2026-02-09  9:40       ` Oleksii Kurochko
2026-02-09  9:51         ` Jan Beulich
2026-02-09 12:35           ` Oleksii Kurochko
2026-02-09 12:54             ` Jan Beulich [this message]
2026-01-22 16:47 ` [PATCH v2 10/16] xen/riscv: add vtimer context switch helpers Oleksii Kurochko
2026-02-03 16:43   ` Jan Beulich
2026-02-03 16:56     ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 11/16] xen/riscv: implement SBI legacy SET_TIMER support for guests Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 12/16] xen/riscv: introduce sbi_set_timer() Oleksii Kurochko
2026-02-03 17:02   ` Jan Beulich
2026-02-04  9:29     ` Oleksii Kurochko
2026-02-04 10:11       ` Jan Beulich
2026-02-04  6:50   ` Jan Beulich
2026-02-04  9:36     ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 13/16] xen/riscv: implement reprogram_timer() via SBI Oleksii Kurochko
2026-01-24 23:13   ` Teddy Astie
2026-01-26 10:20     ` Oleksii Kurochko
2026-02-04 10:39   ` Jan Beulich
2026-02-05 16:25     ` Oleksii Kurochko
2026-01-22 16:47 ` [PATCH v2 14/16] xen/riscv: handle hypervisor timer interrupts Oleksii Kurochko
2026-02-04 10:42   ` Jan Beulich
2026-01-22 16:47 ` [PATCH v2 15/16] xen/riscv: init tasklet subsystem Oleksii Kurochko
2026-01-29 16:33   ` Jan Beulich
2026-01-22 16:47 ` [PATCH v2 16/16] xen/riscv: implement sync_vcpu_execstate() Oleksii Kurochko
2026-02-04 10:49   ` Jan Beulich
2026-02-05 16:51     ` Oleksii Kurochko
2026-02-05 16:53       ` Jan Beulich

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=089aeecb-4e58-407d-aa4d-e09f88f861a0@suse.com \
    --to=jbeulich@suse.com \
    --cc=Romain.Caritey@microchip.com \
    --cc=alistair.francis@wdc.com \
    --cc=andrew.cooper3@citrix.com \
    --cc=anthony.perard@vates.tech \
    --cc=connojdavis@gmail.com \
    --cc=julien@xen.org \
    --cc=michal.orzel@amd.com \
    --cc=oleksii.kurochko@gmail.com \
    --cc=roger.pau@citrix.com \
    --cc=sstabellini@kernel.org \
    --cc=xen-devel@lists.xenproject.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.