Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2446141pxb; Tue, 13 Apr 2021 01:58:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzWhDTKxTiSv8DEGZP76JJD//87msXK/Hz/w4RUssp8wV3vemh6XEtvi6C6K0AYubl/pcJd X-Received: by 2002:a63:5d6:: with SMTP id 205mr30335176pgf.278.1618304305059; Tue, 13 Apr 2021 01:58:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618304305; cv=none; d=google.com; s=arc-20160816; b=0mgzTw4awNiAIKZe447TEtMN90kvwm9ReDm809VAoW/eKUjqdtJUKnm5U9LcJ8a4+k FttDPrvBWYUj6Sk0QGd92IAata/Abp9JnnyW2ObLXS/jLu4GM+iKDiK0jnZv9XCqIAZx 0hv/yujxEoJD0MzWz+sTuv1ItwnnIlw9MIU0RJqESYObnvcyo4+zMxN3XNdysiuvereI r6+cg+CxBVnv5GVTWxaK9TJ/Z8xHCT/FkDqzTJyhHe6S/3t9Mm56DiLZYsmTWYm8d34j mCEYciTxzJuwJfa6S3qPgXQjd6dRnoIHOrnX1BNJqvUkDf+2bY/RFeO34omhndkrzLAo uqEQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject; bh=bHW59HlYNbRFoMomgl/mePLmSkcHPTHj1b0A7xJxm28=; b=zGkOTA0+8BTSMiaqcwT1SfoGSohDWNCMCuI2xTJ703OjjsM7xIl9HOCBPj30vu4h3r tmzwddh5oRJwgdq6/3Nx84famvoyW33h1uKRgf7MmcpN0ps/Aia7tfalPELfbuHZOo0Z O/PUyS+O0jhyXwXe5sZVJR8meXcMTZ0EXi+wkMLtsXdtf7wCSrPW/en0Pdj++iUWmhH1 HwLoMaBZKU+Fxb64XnOVmBcShH9fP9CCqNdR4Qa/uupEMdS1u6dstsg5rPjgP1pUbSuf 51JM4/cvq2gLCLVPMqmC+5nbOc3FA8ccap01V6M/Wap2Lo4+jG3XkEbX8VZAYiBjBKFg cnBA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s11si12551905pgq.582.2021.04.13.01.58.12; Tue, 13 Apr 2021 01:58:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344276AbhDMGG2 (ORCPT + 99 others); Tue, 13 Apr 2021 02:06:28 -0400 Received: from szxga04-in.huawei.com ([45.249.212.190]:15671 "EHLO szxga04-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343930AbhDMGGZ (ORCPT ); Tue, 13 Apr 2021 02:06:25 -0400 Received: from DGGEMS410-HUB.china.huawei.com (unknown [172.30.72.60]) by szxga04-in.huawei.com (SkyGuard) with ESMTP id 4FKFQP1sdyznWcp; Tue, 13 Apr 2021 14:03:09 +0800 (CST) Received: from [10.174.187.224] (10.174.187.224) by DGGEMS410-HUB.china.huawei.com (10.3.19.210) with Microsoft SMTP Server id 14.3.498.0; Tue, 13 Apr 2021 14:05:58 +0800 Subject: Re: [PATCH] KVM: arm/arm64: Fix KVM_VGIC_V3_ADDR_TYPE_REDIST read To: Eric Auger , , , , , , , , References: <20210412150034.29185-1-eric.auger@redhat.com> CC: , From: Keqian Zhu Message-ID: Date: Tue, 13 Apr 2021 14:05:47 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Thunderbird/45.7.1 MIME-Version: 1.0 In-Reply-To: <20210412150034.29185-1-eric.auger@redhat.com> Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.174.187.224] X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021/4/12 23:00, Eric Auger wrote: > When reading the base address of the a REDIST region > through KVM_VGIC_V3_ADDR_TYPE_REDIST we expect the > redistributor region list to be populated with a single > element. > > However list_first_entry() expects the list to be non empty. Indeed, list_first_entry() always return a non-null ptr. If the list is empty, it will mistake the list head as the first element. > Instead we should use list_first_entry_or_null which effectively > returns NULL if the list is empty. > > Fixes: dbd9733ab674 ("KVM: arm/arm64: Replace the single rdist region by a list") > Cc: # v4.18+ > Signed-off-by: Eric Auger > Reported-by: Gavin Shan > --- > arch/arm64/kvm/vgic/vgic-kvm-device.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/arch/arm64/kvm/vgic/vgic-kvm-device.c b/arch/arm64/kvm/vgic/vgic-kvm-device.c > index 44419679f91a..5eaede3e3b5a 100644 > --- a/arch/arm64/kvm/vgic/vgic-kvm-device.c > +++ b/arch/arm64/kvm/vgic/vgic-kvm-device.c > @@ -87,8 +87,8 @@ int kvm_vgic_addr(struct kvm *kvm, unsigned long type, u64 *addr, bool write) > r = vgic_v3_set_redist_base(kvm, 0, *addr, 0); > goto out; > } > - rdreg = list_first_entry(&vgic->rd_regions, > - struct vgic_redist_region, list); > + rdreg = list_first_entry_or_null(&vgic->rd_regions, > + struct vgic_redist_region, list); > if (!rdreg) > addr_ptr = &undef_value; > else >