Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp4027389pxf; Mon, 29 Mar 2021 19:13:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJylWLMJP+LnoxA+kOjoqzrj1UC+qtBZfCEanr/ccBeWbF576d1HfbaxvgDAb5T0WdDA/Ps7 X-Received: by 2002:a17:907:766f:: with SMTP id kk15mr31677211ejc.24.1617070432448; Mon, 29 Mar 2021 19:13:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617070432; cv=none; d=google.com; s=arc-20160816; b=h8K6yvciwf6LHJcbYcqz868ZXwD21bYY104DXOBDHyvxveCUqdWFknS+aMtjeoKYU0 iw9dlgSh5toopSFqFtYWj4QzQpjasIRwQGnl9PJq+YmDrUdUz3Zp+dcRC3w/hY8alyBG 55ZjdQqDzgGZWcp2uyCTj/eEcK//SgulYx3I3u2WV3InerU47YrKMFSyIhZCE2Cfrudz D5Un44qx4mMRD+XNgXbQaxZPOam8f0pelT3FHEsCqk2jSm78/abA7s97U6kDYPseKZiH ZW6BhdtNJ28BYXNiECjq2niYiygI64AcgqxcEWyiVTdQ5k//xNus1gJOuV+eETqZQKl4 b4ww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dmarc-filter:sender:dkim-signature; bh=0p4+Y064Zt0iaT0MEXxLAVMn4eLJIOvJ1SOBmfw5K+c=; b=Qv1E7OhG7VtXzux4HrH7qUb5vxGZWp68whvh6c90buipwJTkITFAXF/DfQSaFpbS4T 3v65xbWMFXwheDyIny8vYrUsdOfvWCx9XKUdRAFdyJDQtYZl0XLaIEohEzgqyH4KCAI7 MEZrAn+0LMXrMYgLpZtFJ8L4GRdvqIzrKK8OllLv9AjKWyPmx/g7VgRMzSqsxqKLkN7P 6nJ4FtV04dqFArZBRI0u0vJgkf+Rh9NscY2Be368XeC8Pu5azXA1Lmd1YlqGQyV+5+x+ GCZ8+U8dIC5mWe0fySJEJljY38dFW78APxbTngDhc1ce3VgekL11AAHOUk0GlFpk/bnT 0mrw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=ax7n0vWj; 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 e12si14330801ejs.501.2021.03.29.19.13.30; Mon, 29 Mar 2021 19:13:52 -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; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=ax7n0vWj; 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 S231197AbhC3CMj (ORCPT + 99 others); Mon, 29 Mar 2021 22:12:39 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:39855 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230495AbhC3CMW (ORCPT ); Mon, 29 Mar 2021 22:12:22 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1617070342; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=0p4+Y064Zt0iaT0MEXxLAVMn4eLJIOvJ1SOBmfw5K+c=; b=ax7n0vWj30WngbjYKdzj1yg7eCbyQpddSqlqce8gb3H4xvTRsbmGVyMk3qzdhsuXmY72d7+c FlXyX+7SR6D0X/vLPJm/0L0Jc6gF4Qb0z3YoygELIz1obrZEqDYQ8zOazgGLWEL83QUFZYJ3 ZMws/kn0yGbgDtdp70Nxw0iVqzE= X-Mailgun-Sending-Ip: 69.72.43.7 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-n06.prod.us-east-1.postgun.com with SMTP id 606288fcc39407c3270cd445 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Tue, 30 Mar 2021 02:12:12 GMT Sender: bbhatt=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 6DA07C43465; Tue, 30 Mar 2021 02:12:11 +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 malabar-linux.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: bbhatt) by smtp.codeaurora.org (Postfix) with ESMTPSA id 43DA8C433CA; Tue, 30 Mar 2021 02:12:10 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 43DA8C433CA 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=bbhatt@codeaurora.org From: Bhaumik Bhatt To: manivannan.sadhasivam@linaro.org Cc: linux-arm-msm@vger.kernel.org, hemantk@codeaurora.org, jhugo@codeaurora.org, linux-kernel@vger.kernel.org, carl.yin@quectel.com, naveen.kumar@quectel.com, loic.poulain@linaro.org, Bhaumik Bhatt Subject: [PATCH v7 4/7] bus: mhi: core: Clear configuration from channel context during reset Date: Mon, 29 Mar 2021 19:11:44 -0700 Message-Id: <1617070307-5775-5-git-send-email-bbhatt@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1617070307-5775-1-git-send-email-bbhatt@codeaurora.org> References: <1617070307-5775-1-git-send-email-bbhatt@codeaurora.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When clearing up the channel context after client drivers are done using channels, the configuration is currently not being reset entirely. Ensure this is done to appropriately handle issues where clients unaware of the context state end up calling functions which expect a context. Signed-off-by: Bhaumik Bhatt Reviewed-by: Hemant Kumar Reviewed-by: Manivannan Sadhasivam --- drivers/bus/mhi/core/init.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/drivers/bus/mhi/core/init.c b/drivers/bus/mhi/core/init.c index 64846c4..8b840da 100644 --- a/drivers/bus/mhi/core/init.c +++ b/drivers/bus/mhi/core/init.c @@ -556,6 +556,7 @@ void mhi_deinit_chan_ctxt(struct mhi_controller *mhi_cntrl, struct mhi_ring *buf_ring; struct mhi_ring *tre_ring; struct mhi_chan_ctxt *chan_ctxt; + u32 tmp; buf_ring = &mhi_chan->buf_ring; tre_ring = &mhi_chan->tre_ring; @@ -569,7 +570,19 @@ void mhi_deinit_chan_ctxt(struct mhi_controller *mhi_cntrl, vfree(buf_ring->base); buf_ring->base = tre_ring->base = NULL; + tre_ring->ctxt_wp = NULL; chan_ctxt->rbase = 0; + chan_ctxt->rlen = 0; + chan_ctxt->rp = 0; + chan_ctxt->wp = 0; + + tmp = chan_ctxt->chcfg; + tmp &= ~CHAN_CTX_CHSTATE_MASK; + tmp |= (MHI_CH_STATE_DISABLED << CHAN_CTX_CHSTATE_SHIFT); + chan_ctxt->chcfg = tmp; + + /* Update to all cores */ + smp_wmb(); } int mhi_init_chan_ctxt(struct mhi_controller *mhi_cntrl, -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project