All of lore.kernel.org
 help / color / mirror / Atom feed
From: Oleksii Kurochko <oleksii.kurochko@gmail.com>
To: Jan Beulich <jbeulich@suse.com>
Cc: "Alistair Francis" <alistair.francis@wdc.com>,
	"Bob Eshleman" <bobbyeshleman@gmail.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>,
	xen-devel@lists.xenproject.org
Subject: Re: [PATCH v1 13/15] xen/riscv: implement reprogram_timer() using SBI
Date: Wed, 14 Jan 2026 11:33:23 +0100	[thread overview]
Message-ID: <4141bb71-7aef-4287-aefd-92009977294f@gmail.com> (raw)
In-Reply-To: <c6b2f360-5ec5-4299-9eb0-de88bf9f9ad9@suse.com>


On 1/14/26 10:53 AM, Jan Beulich wrote:
> On 14.01.2026 10:41, Oleksii Kurochko wrote:
>> On 1/14/26 10:13 AM, Jan Beulich wrote:
>>> On 13.01.2026 17:50, Oleksii Kurochko wrote:
>>>> On 1/12/26 4:24 PM, Jan Beulich wrote:
>>>>> On 24.12.2025 18:03, Oleksii Kurochko wrote:
>>>>>> @@ -39,6 +43,33 @@ static void __init preinit_dt_xen_time(void)
>>>>>>         cpu_khz = rate / 1000;
>>>>>>     }
>>>>>>     
>>>>>> +int reprogram_timer(s_time_t timeout)
>>>>>> +{
>>>>>> +    uint64_t deadline, now;
>>>>>> +    int rc;
>>>>>> +
>>>>>> +    if ( timeout == 0 )
>>>>>> +    {
>>>>>> +        /* Disable timers */
>>>>>> +        csr_clear(CSR_SIE, BIT(IRQ_S_TIMER, UL));
>>>>>> +
>>>>>> +        return 1;
>>>>>> +    }
>>>>>> +
>>>>>> +    deadline = ns_to_ticks(timeout) + boot_clock_cycles;
>>>>>> +    now = get_cycles();
>>>>>> +    if ( deadline <= now )
>>>>>> +        return 0;
>>>>>> +
>>>>>> +    /* Enable timer */
>>>>>> +    csr_set(CSR_SIE, BIT(IRQ_S_TIMER, UL));
>>>>> Still learning RISC-V, so question for my understanding: Even if the timeout
>>>>> is short enough to expire before the one SIE bit will be set, the interrupt
>>>>> will still occur (effectively immediately)? (Else the bit may need setting
>>>>> first.)
>>>> The interrupt will become pending first (when mtime >= mtimecmp or
>>>> mtime >= CSR_STIMECMP in case of SSTC) and then fire immediately once
>>>> |SIE.STIE |(and global|SIE|) are enabled.
>>>>
>>>>>> +    if ( (rc = sbi_set_timer(deadline)) )
>>>>>> +        panic("%s: timer wasn't set because: %d\n", __func__, rc);
>>>>> Hmm, if this function ends up being used from any guest accessible path (e.g.
>>>>> a hypercall), such panic()-ing better shouldn't be there.
>>>> I don't have such use cases now and I don't expect that guest should use
>>>> this function.
>>> How do you envision supporting e.g. VCPUOP_set_singleshot_timer without
>>> involving this function?
>> Looking at what is in common code for VCPUOP_set_singleshot_timer, it doesn't
>> use reprogram_timer(), it is just activate/deactivate timer.
> And how would that work without, eventually, using reprogram_timer()? While not
> directly on a hypercall path, the use can still be guest-induced.

Of course, eventually|reprogram_timer()| will be used. I incorrectly thought
that we were talking about its direct use on the hypercall path.

I am not really sure what we should do in the case when rc != 0. Looking at the
OpenSBI call, it always returns 0, except when sbi_set_timer() is not supported,
in which case it returns -SBI_ENOTSUPP. With such a return value, I think it would
be acceptable to call domain_crash(current->domain). On the other hand, if some
other negative error code is returned, it might be better to return 0 and simply
allow the timer programming to be retried later.
However, if we look at the comments for other architectures, the meaning of a
return value of 0 from this function is:
  Returns 1 on success; 0 if the timeout is too soon or is in the past.
In that case, it becomes difficult to distinguish whether 0 was returned due to
an error or because the timeout was too soon or already in the past.

It seems like at the moment it is better to call domain_crash() and change it
if it will be necessity in the future as I expect that the only negative code
which will be returned by sbi_set_timer() will -SBI_ENOTSUPP and if this SBI
call isn't supported then we anyway need a different way to set a timer.

~ Oleksii



  reply	other threads:[~2026-01-14 10:33 UTC|newest]

Thread overview: 93+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-12-24 17:03 [PATCH v1 00/15] xen/riscv: introduce vtimer related things Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 01/15] xen/riscv: introduce struct arch_vcpu Oleksii Kurochko
2026-01-05 16:58   ` Jan Beulich
2026-01-06 14:19     ` Oleksii Kurochko
2026-01-06 14:26       ` Jan Beulich
2026-01-06 14:59         ` Andrew Cooper
2026-01-06 15:05         ` Oleksii Kurochko
2026-01-06 15:33           ` Jan Beulich
2026-01-06 16:00             ` Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 02/15] xen/riscv: implement arch_vcpu_{create,destroy}() Oleksii Kurochko
2026-01-06 15:56   ` Jan Beulich
2026-01-12 10:19     ` Oleksii Kurochko
2026-01-12 10:42       ` Jan Beulich
2025-12-24 17:03 ` [PATCH v1 03/15] xen/riscv: implement vcpu_csr_init() Oleksii Kurochko
2026-01-07  8:46   ` Jan Beulich
2026-01-12 12:59     ` Oleksii Kurochko
2026-01-12 14:28       ` Jan Beulich
2026-01-12 15:46         ` Oleksii Kurochko
2026-01-12 15:54           ` Jan Beulich
2026-01-12 16:39             ` Oleksii Kurochko
2026-01-12 16:42               ` Jan Beulich
2025-12-24 17:03 ` [PATCH v1 04/15] xen/riscv: introduce vtimer Oleksii Kurochko
2026-01-07 15:21   ` Jan Beulich
2026-01-12 16:28     ` Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 05/15] xen/riscv: implement stub for smp_send_event_check_mask() Oleksii Kurochko
2026-01-07 15:47   ` Jan Beulich
2026-01-12 16:53     ` Oleksii Kurochko
2026-01-12 17:05       ` Jan Beulich
2026-01-13  9:58         ` Oleksii Kurochko
2026-01-13 10:22           ` Jan Beulich
2026-01-13 11:39             ` Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 06/15] xen/riscv: introduce vcpu_kick() implementation Oleksii Kurochko
2026-01-07 16:04   ` Jan Beulich
2025-12-24 17:03 ` [PATCH v1 07/15] xen/riscv: introduce tracking of pending vCPU interrupts, part 1 Oleksii Kurochko
2026-01-07 16:28   ` Jan Beulich
2026-01-13 12:51     ` Oleksii Kurochko
2026-01-13 13:54       ` Jan Beulich
2026-01-14 15:39         ` Oleksii Kurochko
2026-01-14 15:56           ` Jan Beulich
2026-01-15  9:14             ` Oleksii Kurochko
2026-01-15  9:52               ` Jan Beulich
2026-01-15 10:55                 ` Oleksii Kurochko
2026-01-15 10:59                   ` Jan Beulich
2026-01-15 11:46                     ` Oleksii Kurochko
2026-01-15 12:09                       ` Jan Beulich
2026-01-15 12:25                         ` Oleksii Kurochko
2026-01-15 12:30                           ` Jan Beulich
2026-01-16 14:25     ` Oleksii Kurochko
2026-01-16 14:42       ` Jan Beulich
2025-12-24 17:03 ` [PATCH v1 08/15] xen/riscv: introduce vtimer_set_timer() and vtimer_expired() Oleksii Kurochko
2026-01-08 10:28   ` Jan Beulich
2026-01-13 14:44     ` Oleksii Kurochko
2026-01-13 15:12       ` Jan Beulich
2026-01-14 12:27         ` Oleksii Kurochko
2026-01-14 14:57           ` Jan Beulich
2026-01-14 15:59             ` Oleksii Kurochko
2026-01-15  7:52               ` Jan Beulich
2026-01-15  9:30                 ` Oleksii Kurochko
2026-01-15  9:55                   ` Jan Beulich
2025-12-24 17:03 ` [PATCH v1 09/15] xen/riscv: add vtimer_{save,restore}() Oleksii Kurochko
2026-01-08 10:43   ` Jan Beulich
2026-01-13 15:32     ` Oleksii Kurochko
2026-01-14  9:00       ` Jan Beulich
2025-12-24 17:03 ` [PATCH v1 10/15] xen/riscv: implement SBI legacy SET_TIMER support for guests Oleksii Kurochko
2026-01-08 10:45   ` Jan Beulich
2026-01-13 15:41     ` Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 11/15] xen/riscv: introduce ns_to_ticks() Oleksii Kurochko
2026-01-12 14:59   ` [Arm] " Jan Beulich
2026-01-21  0:23     ` Volodymyr Babchuk
2026-01-21  1:19       ` Stefano Stabellini
2025-12-24 17:03 ` [PATCH v1 12/15] xen/riscv: introduce sbi_set_timer() Oleksii Kurochko
2026-01-12 15:12   ` Jan Beulich
2026-01-13 16:33     ` Oleksii Kurochko
2026-01-14  9:07       ` Jan Beulich
2026-01-14  9:59         ` Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 13/15] xen/riscv: implement reprogram_timer() using SBI Oleksii Kurochko
2026-01-12 15:24   ` Jan Beulich
2026-01-13 16:50     ` Oleksii Kurochko
2026-01-14  9:13       ` Jan Beulich
2026-01-14  9:41         ` Oleksii Kurochko
2026-01-14  9:53           ` Jan Beulich
2026-01-14 10:33             ` Oleksii Kurochko [this message]
2026-01-14 11:17               ` Jan Beulich
2026-01-14 12:41                 ` Oleksii Kurochko
2026-01-14 15:04                   ` Jan Beulich
2026-01-14 15:53                     ` Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 14/15] xen/riscv: handle hypervisor timer interrupts Oleksii Kurochko
2026-01-12 16:15   ` Jan Beulich
2026-01-13 16:53     ` Oleksii Kurochko
2025-12-24 17:03 ` [PATCH v1 15/15] xen/riscv: init tasklet subsystem Oleksii Kurochko
2026-01-12 16:20   ` Jan Beulich
2026-01-13 17:03     ` Oleksii Kurochko
2026-01-14  9:15       ` 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=4141bb71-7aef-4287-aefd-92009977294f@gmail.com \
    --to=oleksii.kurochko@gmail.com \
    --cc=alistair.francis@wdc.com \
    --cc=andrew.cooper3@citrix.com \
    --cc=anthony.perard@vates.tech \
    --cc=bobbyeshleman@gmail.com \
    --cc=connojdavis@gmail.com \
    --cc=jbeulich@suse.com \
    --cc=julien@xen.org \
    --cc=michal.orzel@amd.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.