Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp5678733pxv; Wed, 28 Jul 2021 17:18:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz5KniQBfnZRf6bPzDYNp6A6/xcuRilwHOVeR6YvCxJrqz5eFFDAAXUFj2jiyyEusrYx/ks X-Received: by 2002:a05:6e02:b43:: with SMTP id f3mr1148896ilu.94.1627517931495; Wed, 28 Jul 2021 17:18:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627517931; cv=none; d=google.com; s=arc-20160816; b=UfuL3czaex2YvgcGWYvsRYyD+gTSkevrTs5CpN6O8+9knLJT9FaIZ5E5LESLrRyHMg c07DKKrWXboWffuhskaDIZQWAP7P+7Ugs3L2uSKsO6h/ArF/HVGETlaLcMWh2Pe+X5fU p5EPI7YRDLvekE6JBove0yj7g4hB+EFOewg4HVdRnuCz7FYHalRUQOsIIoweBk77mr2i ubfS1y8nrH8YCDiWws2JdbkkJagj6+Ejx7WPUhXc97FUFORo3boVoFzhoS1fw5LbZelp T/c0PdzEJOzNtXSzubxHeUY66fIuESsx9u9JujVf1Hj6zwVFzIaBaYRQkY9zGTGsDLnf 3rcw== 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=fG0L255WTmZR0Oti+x7xgTmjSfhj9hnFQipkUdam2CI=; b=cor4KIDBf8bv/yZ5gxNAi7ztJGfJv7qOFUXQcdVlF96clwGCVf8Dg3qMdaQkYO4O8f A6lCQ1n/gzAD7QFEkqba1lw9i3czNfednaWA0Sm46nEO2NLlBo7VJP2ZIpPXEmKortx+ ARnlne7pXZKG+dZDmBNqSeNGFPZQ2F3SD+vYeaCxQ+JWETgZIp9ygsLDWt5evnlO54MZ Lv14qP/Um2grY+jCdZ3zGe64i3OB+/bkpEfU+SXclo2tJvewuBMIbDh9RnvTRPIu75xZ 5bu/NYo2HAkvQqbTE/ll+abB+B0SfRKkST0cu6ARm4yCSCfL92yseMlv/1TCnKFyuHBL ydMA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=hXU60vNY; 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 t8si1303029ils.46.2021.07.28.17.18.39; Wed, 28 Jul 2021 17:18:51 -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=hXU60vNY; 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 S232875AbhG2AR7 (ORCPT + 99 others); Wed, 28 Jul 2021 20:17:59 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:17068 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232727AbhG2AR6 (ORCPT ); Wed, 28 Jul 2021 20:17:58 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1627517876; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=fG0L255WTmZR0Oti+x7xgTmjSfhj9hnFQipkUdam2CI=; b=hXU60vNYj2bTISuFSCpZ7JvR1mSD0CHERjHG6kh3uefNKzvJystGZCekH6x/1KMwSGL3e1hJ lerXL8QUTzVknWoj6ezGZLt2liyDW55P/jh+C6rscJGTFzHk7BQPlIEQgQSg4XvHkZQf9ht+ XtsPEooPqScs0aWB8Ft6xuEnXTI= 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-n07.prod.us-east-1.postgun.com with SMTP id 6101f3af17c2b4047dd5214f (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Thu, 29 Jul 2021 00:17:51 GMT Sender: bbhatt=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 5AE51C43147; Thu, 29 Jul 2021 00:17:50 +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 5693FC433F1; Thu, 29 Jul 2021 00:17:49 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 5693FC433F1 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, linux-kernel@vger.kernel.org, loic.poulain@linaro.org, Bhaumik Bhatt Subject: [PATCH v2 1/2] bus: mhi: core: Move serial number read to power up phase Date: Wed, 28 Jul 2021 17:17:39 -0700 Message-Id: <1627517860-39417-2-git-send-email-bbhatt@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1627517860-39417-1-git-send-email-bbhatt@codeaurora.org> References: <1627517860-39417-1-git-send-email-bbhatt@codeaurora.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In some cases device may boot straight to ready and move to AMSS execution environment. Serial number and OEM PK Hash values would remain unpopulated in those scenarios. Move the reads for those power up preparation phase for controllers to always have them populated. Signed-off-by: Bhaumik Bhatt Reviewed-by: Manivannan Sadhasivam --- drivers/bus/mhi/core/boot.c | 17 +---------------- drivers/bus/mhi/core/init.c | 17 ++++++++++++++++- 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/drivers/bus/mhi/core/boot.c b/drivers/bus/mhi/core/boot.c index 0a97262..e13d34c 100644 --- a/drivers/bus/mhi/core/boot.c +++ b/drivers/bus/mhi/core/boot.c @@ -394,28 +394,13 @@ void mhi_fw_load_handler(struct mhi_controller *mhi_cntrl) void *buf; dma_addr_t dma_addr; size_t size; - int i, ret; + int ret; if (MHI_PM_IN_ERROR_STATE(mhi_cntrl->pm_state)) { dev_err(dev, "Device MHI is not in valid state\n"); return; } - /* save hardware info from BHI */ - ret = mhi_read_reg(mhi_cntrl, mhi_cntrl->bhi, BHI_SERIALNU, - &mhi_cntrl->serial_number); - if (ret) - dev_err(dev, "Could not capture serial number via BHI\n"); - - for (i = 0; i < ARRAY_SIZE(mhi_cntrl->oem_pk_hash); i++) { - ret = mhi_read_reg(mhi_cntrl, mhi_cntrl->bhi, BHI_OEMPKHASH(i), - &mhi_cntrl->oem_pk_hash[i]); - if (ret) { - dev_err(dev, "Could not capture OEM PK HASH via BHI\n"); - break; - } - } - /* wait for ready on pass through or any other execution environment */ if (mhi_cntrl->ee != MHI_EE_EDL && mhi_cntrl->ee != MHI_EE_PBL) goto fw_load_ready_state; diff --git a/drivers/bus/mhi/core/init.c b/drivers/bus/mhi/core/init.c index 5aaca6d..d98a14b 100644 --- a/drivers/bus/mhi/core/init.c +++ b/drivers/bus/mhi/core/init.c @@ -1065,7 +1065,7 @@ int mhi_prepare_for_power_up(struct mhi_controller *mhi_cntrl) { struct device *dev = &mhi_cntrl->mhi_dev->dev; u32 bhi_off, bhie_off; - int ret; + int i, ret; mutex_lock(&mhi_cntrl->pm_mutex); @@ -1124,6 +1124,21 @@ int mhi_prepare_for_power_up(struct mhi_controller *mhi_cntrl) mutex_unlock(&mhi_cntrl->pm_mutex); + /* save hardware info from BHI */ + ret = mhi_read_reg(mhi_cntrl, mhi_cntrl->bhi, BHI_SERIALNU, + &mhi_cntrl->serial_number); + if (ret) + dev_err(dev, "Could not capture serial number via BHI\n"); + + for (i = 0; i < ARRAY_SIZE(mhi_cntrl->oem_pk_hash); i++) { + ret = mhi_read_reg(mhi_cntrl, mhi_cntrl->bhi, BHI_OEMPKHASH(i), + &mhi_cntrl->oem_pk_hash[i]); + if (ret) { + dev_err(dev, "Could not capture OEM PK HASH via BHI\n"); + break; + } + } + return 0; error_reg_offset: -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project