From: <peng.hao2@zte.com.cn>
To: julien.thierry@arm.com
Cc: marc.zyngier@arm.com, andre.przywara@arm.com,
linux-kernel@vger.kernel.org, kvmarm@lists.cs.columbia.edu,
linux-arm-kernel@lists.infradead.org
Subject: Re:Re: [PATCH] kvm: arm/arm64 : fix vm's hanging at startup time
Date: Sat, 17 Nov 2018 10:58:37 +0800 (CST) [thread overview]
Message-ID: <201811171058376326562@zte.com.cn> (raw)
In-Reply-To: <851b61b1-786b-ef64-b8c4-fe6926bdf9f9@arm.com>
[-- Attachment #1.1: Type: text/plain, Size: 2560 bytes --]
>On 16/11/18 00:23, peng.hao2@zte.com.cn wrote:
>>> Hi,
>>>> When virtual machine starts, hang up.
>>>
>>> I take it you mean the *guest* hangs? Because it doesn't get a timer
>>> interrupt?
>>>
>>>> The kernel version of guest
>>>> is 4.16. Host support vgic_v3.
>>>
>>> Your host kernel is something recent, I guess?
>>>
>>>> It was mainly due to the incorrect vgic_irq's(intid=27) group value
>>>> during injection interruption. when kvm_vgic_vcpu_init is called,
>>>> dist is not initialized at this time. Unable to get vgic V3 or V2
>>>> correctly, so group is not set.
>>>
>>> Mmh, that shouldn't happen with (v)GICv3. Do you use QEMU (which
>>> version?) or some other userland tool?
>>>
>>
>> QEMU emulator version 3.0.50 .
>>
>>>> group is setted to 1 when vgic_mmio_write_group is invoked at some
>>>> time.
>>>> when irq->group=0 (intid=27), No ICH_LR_GROUP flag was set and
>>>> interrupt injection failed.
>>>>
>>>> Signed-off-by: Peng Hao <peng.hao2@zte.com.cn>
>>>> ---
>>>> virt/kvm/arm/vgic/vgic-v3.c | 2 +-
>>>> 1 file changed, 1 insertion(+), 1 deletion(-)
>>>>
>>>> diff --git a/virt/kvm/arm/vgic/vgic-v3.c b/virt/kvm/arm/vgic/vgic-v3.c
>>>> index 9c0dd23..d101000 100644
>>>> --- a/virt/kvm/arm/vgic/vgic-v3.c
>>>> +++ b/virt/kvm/arm/vgic/vgic-v3.c
>>>> @@ -198,7 +198,7 @@ void vgic_v3_populate_lr(struct kvm_vcpu *vcpu,
>>>> struct vgic_irq *irq, int lr) if (vgic_irq_is_mapped_level(irq) &&
>>>> (val & ICH_LR_PENDING_BIT)) irq->line_level = false;
>>>>
>>>> - if (irq->group)
>>>> + if (model == KVM_DEV_TYPE_ARM_VGIC_V3)
>>>
>>> This is not the right fix, not only because it basically reverts the
>>> GICv3 part of 87322099052 (KVM: arm/arm64: vgic: Signal IRQs using
>>> their configured group).
>>>
>>> Can you try to work out why kvm_vgic_vcpu_init() is apparently called
>>> before dist->vgic_model is set, also what value it has?
>>> If I understand the code correctly, that shouldn't happen for a GICv3.
>>>
>> Even if the value of group is correctly assigned in kvm_vgic_vcpu_init, the group is then written 0 through vgic_mmio_write_group.
>> If the interrupt comes at this time, the interrupt injection fails.
>>
>
>Does that mean that the guest is configuring its interrupts as Group0?
>That sounds wrong, Linux should configure all it's interrupts as
>non-secure group1.
no, I think that uefi dose this, not linux.
1. kvm_vgic_vcpu_init
2. vgic_create
3. kvm_vgic_dist_init
4.vgic_mmio_write_group: uefi as guest, write group=0
5.vgic_mmio_write_group: linux as guest, write group=1
>
>--
>Julien Thierry
[-- Attachment #2: Type: text/plain, Size: 151 bytes --]
_______________________________________________
kvmarm mailing list
kvmarm@lists.cs.columbia.edu
https://lists.cs.columbia.edu/mailman/listinfo/kvmarm
next prev parent reply other threads:[~2018-11-17 2:58 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-11-15 15:14 [PATCH] kvm: arm/arm64 : fix vm's hanging at startup time Peng Hao
2018-11-15 15:14 ` Peng Hao
2018-11-15 9:42 ` Julien Thierry
2018-11-15 9:42 ` Julien Thierry
2018-11-15 10:22 ` peng.hao2
2018-11-15 11:10 ` Julien Thierry
2018-11-15 11:10 ` Julien Thierry
2018-11-15 14:39 ` Andre Przywara
2018-11-15 14:39 ` Andre Przywara
2018-11-16 0:23 ` peng.hao2
2018-11-16 10:03 ` Julien Thierry
2018-11-16 10:03 ` Julien Thierry
2018-11-17 2:58 ` peng.hao2 [this message]
2018-11-19 9:10 ` Mark Rutland
2018-11-19 9:10 ` Mark Rutland
2018-11-19 9:26 ` Marc Zyngier
2018-11-19 9:26 ` Marc Zyngier
2018-11-19 9:26 ` Marc Zyngier
2018-11-19 12:49 ` Marc Zyngier
2018-11-19 12:49 ` Marc Zyngier
2018-11-19 13:08 ` peng.hao2
2018-11-21 8:56 ` peng.hao2
2018-11-21 11:06 ` Christoffer Dall
2018-11-21 11:06 ` Christoffer Dall
2018-11-21 12:17 ` Julien Thierry
2018-11-21 12:17 ` Julien Thierry
2018-11-21 15:24 ` Christoffer Dall
2018-11-21 15:24 ` Christoffer Dall
2018-11-21 15:53 ` Julien Thierry
2018-11-21 15:53 ` Julien Thierry
2018-11-22 10:45 ` Christoffer Dall
2018-11-22 10:45 ` Christoffer Dall
2018-11-23 6:01 ` peng.hao2
2018-11-23 10:03 ` Christoffer Dall
2018-11-23 10:03 ` Christoffer Dall
2018-11-24 4:15 ` peng.hao2
2018-11-15 15:06 ` Marc Zyngier
2018-11-15 15:06 ` Marc Zyngier
2018-11-15 15:06 ` Marc Zyngier
2018-11-16 0:55 ` peng.hao2
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=201811171058376326562@zte.com.cn \
--to=peng.hao2@zte.com.cn \
--cc=andre.przywara@arm.com \
--cc=julien.thierry@arm.com \
--cc=kvmarm@lists.cs.columbia.edu \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=marc.zyngier@arm.com \
/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.