Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp9604828pxu; Mon, 28 Dec 2020 23:10:51 -0800 (PST) X-Google-Smtp-Source: ABdhPJyziXGx8cPl26/9mJF+i9jKukueSbZN2scvZ/g3d0mrcaRvfr+YvVmSxLjOastzkv09SwCU X-Received: by 2002:a17:906:17d5:: with SMTP id u21mr29085953eje.109.1609225851714; Mon, 28 Dec 2020 23:10:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609225851; cv=none; d=google.com; s=arc-20160816; b=d2Y/NMfprb7rT98qfqftHZ7dslf9tiSXJGyo94RBx++2/qerISWUVFtq+VCp+OlxK2 /QCE3iU+DLf87upA3dviKEEEjk4yfFxBN6yocOf7K+CbkwHE/hauVGzm5+Kkhiz7SS2J HUDWNgrL9GdyNIVx8xPBX6K2lCIlK3dq0B27vlI7nT1WKDcqumWPOADr+rPCI61Rf5uX TfpBZfRSJyCaeg5hp7qRVRX6xRXLGGkSdWnt6KFaEFtmFB8Tca6aN9/vzx5TGEFq0fWi tN9EqGAix733B7oofaZ/WrYS8vXTp8OvetC61tNPiovmibVcbkzWO5q2+my9e60BRHSc IjBA== 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=7zGtIOyD/hhxxV+ykkqwv0Q59u5xzFt43Oi7tidUFG4=; b=CXorBtaKKQYU2NAjOo225xZn+556sOo6e3FZUG+3IfSTjaFr96DNx+hmV45VbSp52E 24WUDVSJBh3qtzGS84gJL9sJVLgKNbnWfE4jO2tDhCVTeQHnDX7nhdHqEZ0kb3kHWzNx kJrky32FLjlLUd/pK6+FUSw7YwmmvhDNsTJM5N7O0tT3js4K7ZIGPcxvCSe2xSq4rnQO XiboRMFhSJ6eUgX7N1LHD8bRQyqsQtsK7AbAVWhjr1nIW/LnCsNYbDoJgRZwidC8xf2e 5RueFwwCQPXmkd+wyu+1thYt67CQNuJRJojZC67uywBhV+gRBnqfrVCR6eLYuDgI4EJ1 WEeg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=uphdxaOb; 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 ce12si12012131edb.604.2020.12.28.23.10.30; Mon, 28 Dec 2020 23:10:51 -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=uphdxaOb; 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 S1726161AbgL2HHJ (ORCPT + 99 others); Tue, 29 Dec 2020 02:07:09 -0500 Received: from so254-31.mailgun.net ([198.61.254.31]:22709 "EHLO so254-31.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726037AbgL2HHI (ORCPT ); Tue, 29 Dec 2020 02:07:08 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1609225605; h=Message-Id: Date: Subject: Cc: To: From: Sender; bh=7zGtIOyD/hhxxV+ykkqwv0Q59u5xzFt43Oi7tidUFG4=; b=uphdxaObLakDrCgtgnDeTmdLB+WY0Gw+A2j4ADDHqWYr4Gdk9rv5J6+49FxML6LK+uN/xlyH xPFX/aoa/zVNF37OpM+OmOWrhKRH7yPEiYCpkEddlh/5nAiyxMkERrAZkeIjoO3t20DCqhBx zU/Z2hmmDkoxaa5xUods8yEUZTA= X-Mailgun-Sending-Ip: 198.61.254.31 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-n03.prod.us-west-2.postgun.com with SMTP id 5fead55ecfd94dd3284629c1 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Tue, 29 Dec 2020 07:06:06 GMT Sender: cjhuang=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id E074AC43461; Tue, 29 Dec 2020 07:06:05 +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-Inspiron-7590.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 A87E2C433C6; Tue, 29 Dec 2020 07:06:03 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org A87E2C433C6 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 v2] mhi: use irq_flags if client driver configures it Date: Tue, 29 Dec 2020 02:05:51 -0500 Message-Id: <20201229070551.3129-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 client 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 --- 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 0ffdebd..5f74e1e 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 client 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 d4841e5..918cf6a 100644 --- a/include/linux/mhi.h +++ b/include/linux/mhi.h @@ -353,6 +353,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) @@ -442,6 +443,7 @@ struct mhi_controller { bool fbc_download; bool pre_init; bool wake_set; + unsigned long irq_flags; }; /** -- 2.7.4