Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2097pxb; Mon, 8 Feb 2021 13:26:24 -0800 (PST) X-Google-Smtp-Source: ABdhPJz7fnBEK0y7kNM1ZbZyJYVvfvltKQeTRZ8OFjjhAMcdrEnto1lDx+lR9Zs1sTJW6cs+UenF X-Received: by 2002:a05:6402:4389:: with SMTP id o9mr19201618edc.164.1612819584706; Mon, 08 Feb 2021 13:26:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612819584; cv=none; d=google.com; s=arc-20160816; b=FyS9rjKt8Ae3RuzMKeAUqJ/14JjFcetJZS9aadgFaK1gClki2xljJC+dO4r/XYa2+Z 4yi8NdZ/oFAFoBS2af0LRVyfmosLWxFBpu+ihUMg2YCBsPGbcUdO656p+f5BunmyZE7H 5QSeFotBYEurucsJZv4QSNh9HBoXhKbjXDr4OtG1385M6DLoq5mVGvFiaWaOiG5+Hu9N XKbdlK9xjRkzbSQgZpxmfOZe1xCYIcPHXQsYOffcL1Zn8KFgx+/JsTx5Afi0aiPDJMAK girnOYtmSzSRqwaCrblgDCcFeKIs8Yfn1B9ImQK1po/CCLZ3GL/G4K8EVGiKUMZL81IZ 8SYA== 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=qmYyC+E3O4XyV15XgtkDOPv12aplhNxMGMCjOd5gNMY=; b=c1DBWAYBpDryk22vfldHYbd4l8BgdoC+q440oRkl3rKaAGQKp7zObeXebsG1Ezgshc NNi+PuzG3MP6wuJUOhtvKyOz+swCfh5GgmvaPfr/b3cDlt16MYethS7N4hMOmf10R3ie 5oANR43q6AgKs1OU/uJQEah22jmEUjpRs61YZuQTCd38T8JxQUK6a1DEYjnToqhQrrHv jrSwr0P28wf/Mm5eAOX0tWoImxdBhgewBBAmDxbfS5wzlWSy7hLntNNXcSXBIXIQKI7P ksdBtKRSZnUUE0sV1iMZ9AQpGVL7xxAZAnN5UZ/41lqGOlxuzpyEzA2NlwUPzMhUFfcI JCCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=AxYcC+oE; 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 sb9si14290985ejb.162.2021.02.08.13.26.00; Mon, 08 Feb 2021 13:26:24 -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=AxYcC+oE; 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 S236612AbhBHVXE (ORCPT + 99 others); Mon, 8 Feb 2021 16:23:04 -0500 Received: from so15.mailgun.net ([198.61.254.15]:35809 "EHLO so15.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236714AbhBHUMM (ORCPT ); Mon, 8 Feb 2021 15:12:12 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1612815112; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=qmYyC+E3O4XyV15XgtkDOPv12aplhNxMGMCjOd5gNMY=; b=AxYcC+oEMOyrh1GtNat1LKlWqsRZZcSZxBvrk7n/urnuGqJ+4Ak26crxP4q7MJsVZexhaGtT 3Gc4rZYP+GvDIY/osMmahZGpt1TM6ttoV2V3P6Ok97r7dsuNhEsXedxFG2mTWGJub+wDSdXj Xuan5ARaRPmogoPbLsBG+jPjxt4= X-Mailgun-Sending-Ip: 198.61.254.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-n02.prod.us-west-2.postgun.com with SMTP id 60219ae38e43a988b7f984a5 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Mon, 08 Feb 2021 20:11:15 GMT Sender: bbhatt=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id D2F8BC43466; Mon, 8 Feb 2021 20:11:14 +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 DF503C433ED; Mon, 8 Feb 2021 20:11:13 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org DF503C433ED 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, loic.poulain@linaro.org, carl.yin@quectel.com, naveen.kumar@quectel.com, Bhaumik Bhatt Subject: [PATCH v3 1/3] bus: mhi: core: Clear devices when moving execution environments Date: Mon, 8 Feb 2021 12:11:00 -0800 Message-Id: <1612815062-4738-2-git-send-email-bbhatt@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1612815062-4738-1-git-send-email-bbhatt@codeaurora.org> References: <1612815062-4738-1-git-send-email-bbhatt@codeaurora.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When moving from SBL to mission mode execution environment, there is no remove callback notification to MHI client drivers which operate on SBL mode only. Client driver devices are being created in SBL or AMSS(mission mode) and only destroyed after power down or SYS_ERROR. If there exist any SBL-specific channels, those are left open and client drivers are thus unaware of the new execution environment where those channels cannot operate. Close the gap and issue remove callbacks to SBL-specific client drivers once device enters mission mode. Signed-off-by: Bhaumik Bhatt --- drivers/bus/mhi/core/main.c | 22 ++++++++++++++++++---- drivers/bus/mhi/core/pm.c | 3 +++ 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/drivers/bus/mhi/core/main.c b/drivers/bus/mhi/core/main.c index 4e0131b..a73ca03 100644 --- a/drivers/bus/mhi/core/main.c +++ b/drivers/bus/mhi/core/main.c @@ -244,8 +244,10 @@ static void mhi_del_ring_element(struct mhi_controller *mhi_cntrl, int mhi_destroy_device(struct device *dev, void *data) { + struct mhi_chan *ul_chan, *dl_chan; struct mhi_device *mhi_dev; struct mhi_controller *mhi_cntrl; + enum mhi_ee_type ee = MHI_EE_MAX; if (dev->bus != &mhi_bus_type) return 0; @@ -257,6 +259,12 @@ int mhi_destroy_device(struct device *dev, void *data) if (mhi_dev->dev_type == MHI_DEVICE_CONTROLLER) return 0; + ul_chan = mhi_dev->ul_chan; + dl_chan = mhi_dev->dl_chan; + + if (data) + ee = *(enum mhi_ee_type *)data; + /* * For the suspend and resume case, this function will get called * without mhi_unregister_controller(). Hence, we need to drop the @@ -264,11 +272,17 @@ int mhi_destroy_device(struct device *dev, void *data) * be sure that there will be no instances of mhi_dev left after * this. */ - if (mhi_dev->ul_chan) - put_device(&mhi_dev->ul_chan->mhi_dev->dev); + if (ul_chan) { + if (ee != MHI_EE_MAX && !(ul_chan->ee_mask & BIT(ee))) + return 0; + put_device(&ul_chan->mhi_dev->dev); + } - if (mhi_dev->dl_chan) - put_device(&mhi_dev->dl_chan->mhi_dev->dev); + if (dl_chan) { + if (ee != MHI_EE_MAX && !(dl_chan->ee_mask & BIT(ee))) + return 0; + put_device(&dl_chan->mhi_dev->dev); + } dev_dbg(&mhi_cntrl->mhi_dev->dev, "destroy device for chan:%s\n", mhi_dev->name); diff --git a/drivers/bus/mhi/core/pm.c b/drivers/bus/mhi/core/pm.c index 681960c..8da8806 100644 --- a/drivers/bus/mhi/core/pm.c +++ b/drivers/bus/mhi/core/pm.c @@ -377,6 +377,7 @@ static int mhi_pm_mission_mode_transition(struct mhi_controller *mhi_cntrl) { struct mhi_event *mhi_event; struct device *dev = &mhi_cntrl->mhi_dev->dev; + enum mhi_ee_type ee = MHI_EE_MAX, current_ee = mhi_cntrl->ee; int i, ret; dev_dbg(dev, "Processing Mission Mode transition\n"); @@ -395,6 +396,8 @@ static int mhi_pm_mission_mode_transition(struct mhi_controller *mhi_cntrl) wake_up_all(&mhi_cntrl->state_event); + device_for_each_child(&mhi_cntrl->mhi_dev->dev, ¤t_ee, + mhi_destroy_device); mhi_cntrl->status_cb(mhi_cntrl, MHI_CB_EE_MISSION_MODE); /* Force MHI to be in M0 state before continuing */ -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project