Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4602075ybl; Wed, 22 Jan 2020 00:58:55 -0800 (PST) X-Google-Smtp-Source: APXvYqzNYqxPPaIyvQGag2HzztAy+CfuC1aS7X/FVEQ7Z8JVW7aJ8eJ5PoI3DFV19CrjChQi5EKZ X-Received: by 2002:a05:6830:1e8a:: with SMTP id n10mr6439137otr.303.1579683535364; Wed, 22 Jan 2020 00:58:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579683535; cv=none; d=google.com; s=arc-20160816; b=vWWv+CmSFQLyiJ+tk7vpy9lUG6i3EA5lZz2oOQKuyCcrGnpWynWaIyBjN2nQ0INilA OEPkQzYmkmIULsdJEPtnPYT9cneRcWp//ejMn+BX+Wd/WmFVL2Bo4gSFn7OP8RPUFEJ+ qGpONDyDvlErYiWSmW915q7HEBbaBVxDhvjMjC21FweYtRSBWRl0lv34w6bGX1P9drKe anHjf0vvxcH+bW3KwkY1l5OeRskl36PNOYqv2SYI/hKFWE5CKuJnpDU2/3TePNU63K4Z OnO5fwYbeiouEJ5Bmhml3kw2YRHvX0Qc9ixPDMna/cM9LtrXBxoaRpZalApSteIU9AIW ctLA== 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=jKC0ath1na41cWGe9f3BtHWius5WHsMQOQeGLlxq1SQ=; b=H0CKXGfnP82g2EUmm/8yNUKHP9vjYO/uoxXHSm/ETiT6w4bpgeijF9/ExOuxvS9t9m OHI4STqp0qOvK2Vg6Z9NbfCjFxJOdkTV2k9QubkftIBfihyzdOu3km4fHbbFTQLxfVLr n2Y4ALhFeQpBQrHJKTzRl1Sz6LMCmcXx0oONyuZgS0Gyx+jPofYNvNl4hpaN69oUxr0t bNqJ/7OOGIqB+xvtFy5Wrd0oer1ZpH2zTODP2AKfxAv7smNARFKdx8ydIdmKYwcyHasE axT2QAGLjndMbqmxCx3tvyDPGDqTq0FKmVw3eClgNzEGMPAVFABZ3SKDrqZ6WFJdaGlC BALw== 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 w1si21016590oia.169.2020.01.22.00.58.42; Wed, 22 Jan 2020 00:58:55 -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 S1726170AbgAVI4q (ORCPT + 99 others); Wed, 22 Jan 2020 03:56:46 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:9234 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725862AbgAVI4q (ORCPT ); Wed, 22 Jan 2020 03:56:46 -0500 Received: from DGGEMS413-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 5AA0BFA352067B42F98D; Wed, 22 Jan 2020 16:56:44 +0800 (CST) Received: from DESKTOP-8RFUVS3.china.huawei.com (10.173.222.27) by DGGEMS413-HUB.china.huawei.com (10.3.19.213) with Microsoft SMTP Server id 14.3.439.0; Wed, 22 Jan 2020 16:56:35 +0800 From: Zenghui Yu To: CC: , , , , , Zenghui Yu Subject: [PATCH] irqchip/gic-v3-its: Don't confuse get_vlpi_map() by writing DB config Date: Wed, 22 Jan 2020 16:56:09 +0800 Message-ID: <20200122085609.658-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 When we're writing config for the doorbell interrupt, get_vlpi_map() will get confused by doorbell's d->parent_data hack and find the wrong its_dev as chip data and the wrong event. Fix this issue by making sure no doorbells will be involved before invoking get_vlpi_map(), which restore some of the logic in lpi_write_config(). Fixes: c1d4d5cd203c ("irqchip/gic-v3-its: Add its_vlpi_map helpers") Signed-off-by: Zenghui Yu --- This is based on mainline and can't be directly applied to the current irqchip-next. drivers/irqchip/irq-gic-v3-its.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c index e05673bcd52b..cc8a4fcbd6d6 100644 --- a/drivers/irqchip/irq-gic-v3-its.c +++ b/drivers/irqchip/irq-gic-v3-its.c @@ -1181,12 +1181,13 @@ static struct its_vlpi_map *get_vlpi_map(struct irq_data *d) static void lpi_write_config(struct irq_data *d, u8 clr, u8 set) { - struct its_vlpi_map *map = get_vlpi_map(d); irq_hw_number_t hwirq; void *va; u8 *cfg; - if (map) { + if (irqd_is_forwarded_to_vcpu(d)) { + struct its_vlpi_map *map = get_vlpi_map(d); + va = page_address(map->vm->vprop_page); hwirq = map->vintid; -- 2.19.1