Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp3062780ybl; Fri, 20 Dec 2019 03:20:17 -0800 (PST) X-Google-Smtp-Source: APXvYqzA+83pGZ6OWFMuSkwqvbASt/kl50QZneoyYvFvUYV7RFyrxX4Tl9RAvm4+0D79n0J5YB89 X-Received: by 2002:aca:5487:: with SMTP id i129mr3282067oib.167.1576840817609; Fri, 20 Dec 2019 03:20:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576840817; cv=none; d=google.com; s=arc-20160816; b=CO6K8fkTwJRnjV0MAK+TwepLUr61L7ClxwGqiQ76JGV0KKZqyT7leLiJS5NcixTr5P n2d9qikaDeGrBrZNRe5LyY06uPapcw9LHaH4YrWkOeiyqFUhC18FVj92l6pyGIY4WNlX HAht8+IUlG2Y6Gs6Sy74XU/NeFXVitKVrV9BGbWAgjQTBH2Tcrnw66Z6RQ4mVtPzVhiV 34tc0T8L1oflz8oz8yQWz0pDX6XQOSENRF0yhYWgbTcJ7Fz1BoL+haejm5UoWakp1S9m M69PjUgt/SLhjudh3G8i2LPKVNIMouBBOUq5v2xAPPzA/4Zf93TquguUd2Oqpl8+a3DQ qFaQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=SOoZzub9r/lkMheF/GaLzhXs+qamAQweuQdn7MwGVNQ=; b=QfM/Q41AfW5roLR5tRS7mCQDHVIvUzoVERkQhwjOfyfuEQotZHs5nNJT+KJVPS2rd+ lMxAlW6NCw8h2meTZItPaQlBxufD8/Uh5Las1U9zmQyo6vOMhTsBeX3V7tgM/jhbswCp pfPrQojBa1jd3yOx+wNPsycXqrcGK5qIbQIpj+yc9L5yw7sBegMBFr/Pbw6AUFUrlMWU Ok6mV2OtA5utybocyd9hyopKJC9/bVy8OsH1RRm54Zr6b0Ay4u0CNZjMQd3Bz0WftERd zzjVboX2Q/hXNJ3Gjr1aUSpdGI/KHgJdpBPcxhnwMnjfjAzoEzYLKI7qMSaxAdLhvcPe wGLw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d188si223659oib.273.2019.12.20.03.20.03; Fri, 20 Dec 2019 03:20:17 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727233AbfLTLTF (ORCPT + 99 others); Fri, 20 Dec 2019 06:19:05 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:7725 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727177AbfLTLTF (ORCPT ); Fri, 20 Dec 2019 06:19:05 -0500 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 4A1A6CC09BE5C294C012; Fri, 20 Dec 2019 19:19:02 +0800 (CST) Received: from DESKTOP-8RFUVS3.china.huawei.com (10.173.222.27) by DGGEMS405-HUB.china.huawei.com (10.3.19.205) with Microsoft SMTP Server id 14.3.439.0; Fri, 20 Dec 2019 19:18:54 +0800 From: Zenghui Yu To: CC: , , , , , , Zenghui Yu Subject: [PATCH] KVM: arm/arm64: vgic: Handle GICR_PENDBASER.PTZ filed as RAZ Date: Fri, 20 Dec 2019 19:18:33 +0800 Message-ID: <20191220111833.1422-1-yuzenghui@huawei.com> X-Mailer: git-send-email 2.23.0.windows.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.173.222.27] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Although guest will hardly read and use the PTZ (Pending Table Zero) bit in GICR_PENDBASER, let us emulate the architecture strictly. As per IHI 0069E 9.11.30, PTZ field is WO, and reads as 0. Signed-off-by: Zenghui Yu --- Noticed when checking all fields of GICR_PENDBASER register. But _not_ sure whether it's worth a fix, as Linux never sets the PTZ bit before enabling LPI (set GICR_CTLR_ENABLE_LPIS). And I wonder under which scenarios can this bit be written as 1. It seems difficult for software to determine whether the pending table contains all zeros when writing this bit. virt/kvm/arm/vgic/vgic-mmio-v3.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/virt/kvm/arm/vgic/vgic-mmio-v3.c b/virt/kvm/arm/vgic/vgic-mmio-v3.c index 7dfd15dbb308..ebc218840fc2 100644 --- a/virt/kvm/arm/vgic/vgic-mmio-v3.c +++ b/virt/kvm/arm/vgic/vgic-mmio-v3.c @@ -414,8 +414,11 @@ static unsigned long vgic_mmio_read_pendbase(struct kvm_vcpu *vcpu, gpa_t addr, unsigned int len) { struct vgic_cpu *vgic_cpu = &vcpu->arch.vgic_cpu; + u64 value = vgic_cpu->pendbaser; - return extract_bytes(vgic_cpu->pendbaser, addr & 7, len); + value &= ~GICR_PENDBASER_PTZ; + + return extract_bytes(value, addr & 7, len); } static void vgic_mmio_write_pendbase(struct kvm_vcpu *vcpu, -- 2.19.1