From: Julien Grall <julien@xen.org>
To: Bertrand Marquis <Bertrand.Marquis@arm.com>
Cc: "xen-devel@lists.xenproject.org" <xen-devel@lists.xenproject.org>,
"iwj@xenproject.org" <iwj@xenproject.org>,
Julien Grall <jgrall@amazon.com>,
Stefano Stabellini <sstabellini@kernel.org>,
Volodymyr Babchuk <Volodymyr_Babchuk@epam.com>
Subject: Re: [PATCH for-4.15] xen/vgic: Implement write to ISPENDR in vGICv{2, 3}
Date: Thu, 25 Feb 2021 12:22:34 +0000 [thread overview]
Message-ID: <0c4e6015-f969-9b6b-91b5-bffa952d47d5@xen.org> (raw)
In-Reply-To: <F86904EB-91E9-475C-B60B-E08C5C9E76C3@arm.com>
On 22/02/2021 13:45, Bertrand Marquis wrote:
> Hi Julien,
>
>> On 20 Feb 2021, at 14:04, Julien Grall <julien@xen.org> wrote:
>>
>> From: Julien Grall <jgrall@amazon.com>
>>
>> Currently, Xen will send a data abort to a guest trying to write to the
>> ISPENDR.
>>
>> Unfortunately, recent version of Linux (at least 5.9+) will start
>> writing to the register if the interrupt needs to be re-triggered
>> (see the callback irq_retrigger). This can happen when a driver (such as
>> the xgbe network driver on AMD Seattle) re-enable an interrupt:
>>
>> (XEN) d0v0: vGICD: unhandled word write 0x00000004000000 to ISPENDR44
>> [...]
>> [ 25.635837] Unhandled fault at 0xffff80001000522c
>> [...]
>> [ 25.818716] gic_retrigger+0x2c/0x38
>> [ 25.822361] irq_startup+0x78/0x138
>> [ 25.825920] __enable_irq+0x70/0x80
>> [ 25.829478] enable_irq+0x50/0xa0
>> [ 25.832864] xgbe_one_poll+0xc8/0xd8
>> [ 25.836509] net_rx_action+0x110/0x3a8
>> [ 25.840328] __do_softirq+0x124/0x288
>> [ 25.844061] irq_exit+0xe0/0xf0
>> [ 25.847272] __handle_domain_irq+0x68/0xc0
>> [ 25.851442] gic_handle_irq+0xa8/0xe0
>> [ 25.855171] el1_irq+0xb0/0x180
>> [ 25.858383] arch_cpu_idle+0x18/0x28
>> [ 25.862028] default_idle_call+0x24/0x5c
>> [ 25.866021] do_idle+0x204/0x278
>> [ 25.869319] cpu_startup_entry+0x24/0x68
>> [ 25.873313] rest_init+0xd4/0xe4
>> [ 25.876611] arch_call_rest_init+0x10/0x1c
>> [ 25.880777] start_kernel+0x5b8/0x5ec
>>
>> As a consequence, the OS may become unusable.
>>
>> Implementing the write part of ISPENDR is somewhat easy. For
>> virtual interrupt, we only need to inject the interrupt again.
>>
>> For physical interrupt, we need to be more careful as the de-activation
>> of the virtual interrupt will be propagated to the physical distributor.
>> For simplicity, the physical interrupt will be set pending so the
>> workflow will not differ from a "real" interrupt.
>>
>> Longer term, we could possible directly activate the physical interrupt
>> and avoid taking an exception to inject the interrupt to the domain.
>> (This is the approach taken by the new vGIC based on KVM).
>>
>> Signed-off-by: Julien Grall <jgrall@amazon.com>
>
> This is something which will not be done by a guest very often so I think your
> implementation actually makes it simpler and reduce possibilities of race conditions
> so I am not even sure that the XXX comment is needed.
I think the XXX is useful as if someone notice an issue with the code,
then they know what they could try.
I am open to suggestion how we could keep track of potential improvement.
> But i am ok with it being in or not so:
>
> Reviewed-by: Bertrand Marquis <bertrand.marquis@arm.com>
Thanks!
Cheers,
--
Julien Grall
next prev parent reply other threads:[~2021-02-25 12:22 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-02-20 14:04 [PATCH for-4.15] xen/vgic: Implement write to ISPENDR in vGICv{2, 3} Julien Grall
2021-02-22 11:10 ` Ian Jackson
2021-02-22 13:45 ` Bertrand Marquis
2021-02-23 1:24 ` Stefano Stabellini
2021-02-23 10:31 ` Julien Grall
2021-02-23 20:40 ` Stefano Stabellini
2021-02-25 12:22 ` Julien Grall [this message]
2021-02-25 21:27 ` Stefano Stabellini
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=0c4e6015-f969-9b6b-91b5-bffa952d47d5@xen.org \
--to=julien@xen.org \
--cc=Bertrand.Marquis@arm.com \
--cc=Volodymyr_Babchuk@epam.com \
--cc=iwj@xenproject.org \
--cc=jgrall@amazon.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).