Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp7291334ybl; Mon, 23 Dec 2019 23:11:58 -0800 (PST) X-Google-Smtp-Source: APXvYqzwRVNKk2MM+bSR/0IC0gBTGdeLu8dg/Lfto8lf+Pp70MsRMkX9q0fkaCJ8+pTnGJH3GVVP X-Received: by 2002:a05:6830:194:: with SMTP id q20mr38250783ota.92.1577171517952; Mon, 23 Dec 2019 23:11:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1577171517; cv=none; d=google.com; s=arc-20160816; b=iQWP3uWceA8q3chqPOQN13YxOdBnuCtIfE6fp27Ye0FjSQHITHWH/G8pU1EBgkyRZT YJpOAhTpTdXuX0ewcXGN5MqY33MaXcLBnQmh1AxYz5za74f18oYrLz4t+piHSem9oU2w gzA8cWKUvLIjL5JLXA32OLpqOouwJd+IDRlfT4CD8a6GjcM0e7wT4xemnLpKlmIEBT2r u5MqnFbf96B9DB1/2ogoPivcVfXXLctcz7YoAdI/QGh60KROv2enkE9yhvot3LBYPZtT 0+JiWPFyTXkOej/+XKkJCO4ErW8glG7yCsXYTZJNMt0CNnirAZjUvwHIzje1RZb3cFt8 HlkA== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=3VfUKmiee3UCqpFItuwu6ZgdTjKNoh0/y05Qqu+pWhY=; b=I2ccEMc/y/GbXyLnBK43a9IMSDKIw0gWMmfb1rJuPCAPTrnuOXptNqSRGUoyewMNsT eZR08ExvnuLqI3m2jfXKrOs3w6SvCsQcQ2+dk2Gt1kiP7dsXaS8IkZOc75T853M5DsV3 PCH8ny9ywRHUK3nXHtwCbc+eSdXJ4RlHdkrAyG/SRUxIz2ykae1cGJeFybKHR7QGRbKk LQ2i1BbPmVX8RteZQNNhNOovGWDGwpHrn6huwDO0tq9njmxgNYjH8FtVk3HKbLme8kQc X1+N4tm4ylLKMn082I7hTjMx1nbwWRipvQ/z1SBCIzJU48LAyTdgUXM5kDkTDo97qfRL fTiA== 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 f23si11235069oto.205.2019.12.23.23.11.46; Mon, 23 Dec 2019 23:11:57 -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 S1726084AbfLXHLJ (ORCPT + 99 others); Tue, 24 Dec 2019 02:11:09 -0500 Received: from szxga06-in.huawei.com ([45.249.212.32]:60266 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725993AbfLXHLI (ORCPT ); Tue, 24 Dec 2019 02:11:08 -0500 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 87DA525A48C8506A8904; Tue, 24 Dec 2019 15:11:06 +0800 (CST) Received: from [127.0.0.1] (10.173.222.27) by DGGEMS405-HUB.china.huawei.com (10.3.19.205) with Microsoft SMTP Server id 14.3.439.0; Tue, 24 Dec 2019 15:10:56 +0800 Subject: Re: [PATCH v2 11/36] irqchip/gic-v4.1: VPE table (aka GICR_VPROPBASER) allocation To: Marc Zyngier , , CC: Eric Auger , James Morse , Julien Thierry , Suzuki K Poulose , Thomas Gleixner , Jason Cooper , Lorenzo Pieralisi , "Andrew Murray" , Jayachandran C , "Robert Richter" , , References: <20191027144234.8395-1-maz@kernel.org> <20191027144234.8395-12-maz@kernel.org> From: Zenghui Yu Message-ID: <61526052-aa00-0769-d5bb-3524161c5650@huawei.com> Date: Tue, 24 Dec 2019 15:10:54 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.2.0 MIME-Version: 1.0 In-Reply-To: <20191027144234.8395-12-maz@kernel.org> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit 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 Hi Marc, [ +Wudi and Nianyao. As they spotted the following issue but I forgot to send it out. ] On 2019/10/27 22:42, Marc Zyngier wrote: > GICv4.1 defines a new VPE table that is potentially shared between > both the ITSs and the redistributors, following complicated affinity > rules. > > To make things more confusing, the programming of this table at > the redistributor level is reusing the GICv4.0 GICR_VPROPBASER register > for something completely different. > > The code flow is somewhat complexified by the need to respect the > affinities required by the HW, meaning that tables can either be > inherited from a previously discovered ITS or redistributor. > > Signed-off-by: Marc Zyngier > ---[...] > diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c > index 40912b3fb0e1..478d3678850c 100644 > --- a/drivers/irqchip/irq-gic-v3-its.c > +++ b/drivers/irqchip/irq-gic-v3-its.c [...] > @@ -2025,6 +2098,214 @@ static int its_alloc_tables(struct its_node *its) > return 0; > } > > +static u64 inherit_vpe_l1_table_from_its(void) > +{ > + struct its_node *its; > + u64 val; > + u32 aff; > + > + val = gic_read_typer(gic_data_rdist_rd_base() + GICR_TYPER); > + aff = compute_common_aff(val); > + > + list_for_each_entry(its, &its_nodes, entry) { > + u64 baser; > + > + if (!is_v4_1(its)) > + continue; > + > + if (!FIELD_GET(GITS_TYPER_SVPET, its->typer)) > + continue; > + > + if (aff != compute_its_aff(its)) > + continue; > + > + /* GICv4.1 guarantees that the vPE table is GITS_BASER2 */ > + baser = its->tables[2].val; > + if (!(baser & GITS_BASER_VALID)) > + continue; > + > + /* We have a winner! */ > + val = GICR_VPROPBASER_4_1_VALID; > + if (baser & GITS_BASER_INDIRECT) > + val |= GICR_VPROPBASER_4_1_INDIRECT; > + val |= FIELD_PREP(GICR_VPROPBASER_4_1_PAGE_SIZE, > + FIELD_GET(GITS_BASER_PAGE_SIZE_MASK, baser)); > + val |= FIELD_PREP(GICR_VPROPBASER_4_1_ADDR, > + GITS_BASER_ADDR_48_to_52(baser) >> 12); We've used GITS_BASER_ADDR_48_to_52() only in the KVM code where the pagesize of ITS table is fixed to 64K. It may not work when the pagesize is 4K or 16K? Thanks, Zenghui > + val |= FIELD_PREP(GICR_VPROPBASER_SHAREABILITY_MASK, > + FIELD_GET(GITS_BASER_SHAREABILITY_MASK, baser)); > + val |= FIELD_PREP(GICR_VPROPBASER_INNER_CACHEABILITY_MASK, > + FIELD_GET(GITS_BASER_INNER_CACHEABILITY_MASK, baser)); > + val |= FIELD_PREP(GICR_VPROPBASER_4_1_SIZE, GITS_BASER_NR_PAGES(baser) - 1); > + > + return val; > + } > + > + return 0; > +}