Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp13710661pxu; Mon, 4 Jan 2021 02:13:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJwdqSxqNhQBldFi9XVOtwHOZwHHlGHKNNg02ndYRB1ffkOrbMntLwFklgVo9WEu9a2zrJK3 X-Received: by 2002:a17:906:9452:: with SMTP id z18mr66935146ejx.389.1609755233774; Mon, 04 Jan 2021 02:13:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609755233; cv=none; d=google.com; s=arc-20160816; b=0vXnoymCL+VVtvMpEKlCa2PnkzNN2GvZDIhj/H/q9PCC9g1bYWeKUO/gRysYfl68sg 4nVo6VWyc0N9vTEBdFANxfpzfEMXHZ4hVIrQwV530Hhs6q+LxZ4xBwbqD6kY4HM64rbr MWeZfLnSIz+qReXILmOUITnVzv+qHLvga8vZyxFD7QsvkrjxtHM/4sYMo+K6UBsL12oI KJydt2jdwwj6ld1PKdOXYwoRhNTxD/SvwtyUJlu+I0Kx9uKAwrtAFHaSpvog1zgiklnL JyoAuc/DIhV4L4Rpl4AnmCU7JAaVO1CTFm/tUyJ/5DrJHINDl0Xj+NYti1HFj0aYZDS9 Ub3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from:dmarc-filter :sender:dkim-signature; bh=b1YdbSOxLE1TmKfcFnR94xmBHprCl+Qqt/okT9c2OCE=; b=L62gOROLKzFU7kharAcxFJ9Z5dm9/jGdEJpP5K7a/08eEOFbFDWTAZQeaM6HakWHoO KUuVjzB5zmKQ+eHiz+p0vML3BkRto2cQgw4c30IN01A29agjEjsC3g7FEV+1h58G6Fk9 OjyWb4dh/os2CTXla9HTdwtxUO2XJ77PCiUilZAnQH1tbzv+saGNVTLC4u7LNLPQLWR4 woy9N+Y4l42HulgQMCvWjMl3Q63UDLk9BrDJR76TdtkHdK9pgA3VZx6xrMZ56CI3ni3f qByklW3PIhAyAcODb4hYJZ2OS8JZVeuHA69ZPpqCJyJbB8eQ/4J9Pu2aS9wFtCHKclP3 XVNA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=GaoJnsyE; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i10si30405495edr.410.2021.01.04.02.13.29; Mon, 04 Jan 2021 02:13:53 -0800 (PST) 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; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=GaoJnsyE; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726189AbhADKMY (ORCPT + 99 others); Mon, 4 Jan 2021 05:12:24 -0500 Received: from m43-15.mailgun.net ([69.72.43.15]:30456 "EHLO m43-15.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725468AbhADKMX (ORCPT ); Mon, 4 Jan 2021 05:12:23 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1609755122; h=Message-Id: Date: Subject: Cc: To: From: Sender; bh=b1YdbSOxLE1TmKfcFnR94xmBHprCl+Qqt/okT9c2OCE=; b=GaoJnsyEi3uIiekNS+zPjb6mWSMZ6PDowzLM0kTbqaplQT8ZnYa+o3GMRlaJAAj5ScoR+i8/ YK7N5KKg6Ep+JA32rt0wvcw2S/IUJCHXWwIJCZ3ZlEk+ysid+dUlHDJZPMtMgrd2+Dg1ka0j nf90952DwtNjU9466yZ2F+nwIjU= X-Mailgun-Sending-Ip: 69.72.43.15 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n07.prod.us-east-1.postgun.com with SMTP id 5ff2e9d9cf8ceaa9eec0fa70 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Mon, 04 Jan 2021 10:11:37 GMT Sender: cjhuang=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id B2417C433C6; Mon, 4 Jan 2021 10:11:36 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00,SPF_FAIL, URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from cjhuang-Celadon-RN.qca.qualcomm.com (unknown [180.166.53.21]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: cjhuang) by smtp.codeaurora.org (Postfix) with ESMTPSA id 663C1C433CA; Mon, 4 Jan 2021 10:11:34 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 663C1C433CA Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=fail smtp.mailfrom=cjhuang@codeaurora.org From: Carl Huang To: manivannan.sadhasivam@linaro.org Cc: hemantk@codeaurora.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, ath11k@lists.infradead.org Subject: [PATCH v3] mhi: use irq_flags if controller driver configures it Date: Mon, 4 Jan 2021 18:11:28 +0800 Message-Id: <20210104101128.8217-1-cjhuang@codeaurora.org> X-Mailer: git-send-email 2.17.1 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If controller driver has specified the irq_flags, mhi uses this specified irq_flags. Otherwise, mhi uses default irq_flags. The purpose of this change is to support one MSI vector for QCA6390. MHI will use one same MSI vector too in this scenario. In case of one MSI vector, IRQ_NO_BALANCING is needed when irq handler is requested. The reason is if irq migration happens, the msi_data may change too. However, the msi_data is already programmed to QCA6390 hardware during initialization phase. This msi_data inconsistence will result in crash in kernel. Another issue is in case of one MSI vector, IRQF_NO_SUSPEND will trigger WARNINGS because QCA6390 wants to disable the IRQ during the suspend. To avoid above two issues, QCA6390 driver specifies the irq_flags in case of one MSI vector when mhi_register_controller is called. Signed-off-by: Carl Huang Reviewed-by: Manivannan Sadhasivam --- v3: - replace "client driver" with "controller driver" - add Reviewed-by: Manivannan Sadhasivam v2: - document irq_flags added to mhi_controller drivers/bus/mhi/core/init.c | 9 +++++++-- include/linux/mhi.h | 2 ++ 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/drivers/bus/mhi/core/init.c b/drivers/bus/mhi/core/init.c index 381fdea..37903a8 100644 --- a/drivers/bus/mhi/core/init.c +++ b/drivers/bus/mhi/core/init.c @@ -148,12 +148,17 @@ int mhi_init_irq_setup(struct mhi_controller *mhi_cntrl) { struct mhi_event *mhi_event = mhi_cntrl->mhi_event; struct device *dev = &mhi_cntrl->mhi_dev->dev; + unsigned long irq_flags = IRQF_SHARED | IRQF_NO_SUSPEND; int i, ret; + /* if controller driver has set irq_flags, use it */ + if (mhi_cntrl->irq_flags) + irq_flags = mhi_cntrl->irq_flags; + /* Setup BHI_INTVEC IRQ */ ret = request_threaded_irq(mhi_cntrl->irq[0], mhi_intvec_handler, mhi_intvec_threaded_handler, - IRQF_SHARED | IRQF_NO_SUSPEND, + irq_flags, "bhi", mhi_cntrl); if (ret) return ret; @@ -171,7 +176,7 @@ int mhi_init_irq_setup(struct mhi_controller *mhi_cntrl) ret = request_irq(mhi_cntrl->irq[mhi_event->irq], mhi_irq_handler, - IRQF_SHARED | IRQF_NO_SUSPEND, + irq_flags, "mhi", mhi_event); if (ret) { dev_err(dev, "Error requesting irq:%d for ev:%d\n", diff --git a/include/linux/mhi.h b/include/linux/mhi.h index cb7cd54..77f1e3f 100644 --- a/include/linux/mhi.h +++ b/include/linux/mhi.h @@ -351,6 +351,7 @@ struct mhi_controller_config { * @fbc_download: MHI host needs to do complete image transfer (optional) * @pre_init: MHI host needs to do pre-initialization before power up * @wake_set: Device wakeup set flag + * @irq_flags: irq flags passed to request_irq (optional) * * Fields marked as (required) need to be populated by the controller driver * before calling mhi_register_controller(). For the fields marked as (optional) @@ -440,6 +441,7 @@ struct mhi_controller { bool fbc_download; bool pre_init; bool wake_set; + unsigned long irq_flags; }; /** -- 2.7.4