All of lore.kernel.org
 help / color / mirror / Atom feed
From: <peng.hao2@zte.com.cn>
To: julien.thierry@arm.com
Cc: marc.zyngier@arm.com, linux-kernel@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org,
	kvmarm@lists.cs.columbia.edu
Subject: Re:Re: [PATCH] kvm: arm/arm64 : fix vm's hanging at startup time
Date: Thu, 15 Nov 2018 18:22:53 +0800 (CST)	[thread overview]
Message-ID: <201811151822532422079@zte.com.cn> (raw)
In-Reply-To: <63a0ea72-e0ce-b3e4-4fda-f1a359754cc5@arm.com>


[-- Attachment #1.1: Type: text/plain, Size: 2308 bytes --]

>Hi Peng,
>
>On 15/11/18 15:14, Peng Hao wrote:
>> When virtual machine starts, hang up. The kernel version of guest
>> is 4.16. Host support vgic_v3.
>
>I don't understand the issue here. the vgic_irq->group field does not
>exist in 4.16 (neither in the first nor the last version). Nor does the
>line you are modifying.
Guest's kernel version is 4.16 and Host's kernel version is mainline.
vgic_irq is a structure of Host's kvm.
>
>Both exist in mainline, but what you are mentioning shouldn't be an
>issue in mainline since vgic_irq->group gets initialized in
>kvm_vgic_vcpu_init for SGIs and PPIs (i.e. intid < 32) which includes
>your interrupt.
Initialization sequence of several components is like this;
1.       kvm_vgic_vcpu_init ---- here, dist is not initialized at this time.
                                             and the value of irq->group depends on
                                              dist->vgic_model. but now dist->vgic_model = 0
                                               and irq->group=0.
 2.      vgic_create         -----  assign to dist->vgic_model.
 3.     kvm_vgic_dist_init 

thanks.
>
>Cheers,
>
>> 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.
>> 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)
>>           val |= ICH_LR_GROUP;
>>
>>       val |= (u64)irq->priority << ICH_LR_PRIORITY_SHIFT;
>>
>
>--
>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

  reply	other threads:[~2018-11-15 10:23 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 [this message]
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
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=201811151822532422079@zte.com.cn \
    --to=peng.hao2@zte.com.cn \
    --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.