Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp1094912pxb; Wed, 27 Oct 2021 19:23:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxiYJNeq6bmpSrUxoFqe2sIL/SosvNPmoDqHrXH/YAzOFHTdyZ4H+75quo6FPbj5a+zapMS X-Received: by 2002:a17:90a:191a:: with SMTP id 26mr9859451pjg.118.1635387795081; Wed, 27 Oct 2021 19:23:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635387795; cv=none; d=google.com; s=arc-20160816; b=gxJe0HiQ6BaHr3OHyKdEiEu7ePmz1tYDDqpVoEltID8qauXhXwYJAlPvWmsxaqT1bN ryz0PMYdpK8wisEGsbEYdrSdeQtrraWMxd2IFYSjLgv5eyYmfB7tTn/1SnAn5KCA6LkX aL4oQ4gOkvvHURFepd5diCJMc75yykVtsf5X0PsHrU1Gd2MSZZ4pTXYqVanVc93xMpUu AaWZYJ7Qez9NSn65f223j5YIkC9M6tczaILBTtIdqA91U4vevNgFteZ+DMFCXYqOU6PU pTyWyh5EBnLsjER197wYNlbja/aB1+hAqa/mFj3UPbsRthiL7MrL1ab4XJBzILUicgZ/ Y/hA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=GUccu+hZ5v1x2kZ4zf0NHWyXpWznjW1R7WFZElFvnQc=; b=OoLcdtKR9Lmt/gUONUqg2Javqa2y1wP/n6ngjJzi6TljiRTwXjcl9FV2iopHw5nlmX lX5s4bvoL/3BKdGQW5wAtcjQl3EAZK5N399wsUyTDQk96NY6UHgW5S+uw5e8HOal6KVq FEckj/++7LMltVY66aR71tPzBKPHoNHPlTjtLLQsEK1jRWibgwh65Cul/uZjom3H+ykc 2C6ibTGZ7Yq7VY6EVhOoR5suCq7Nm/wCRiXskmIiqwChRoJp9Kz1oAIEKXCa6MWZG4xr +ADQBdk/Q5O1miGSNw/XaZCrWqJLfYB8mYDyrxqVX8o3JWxtvYlrUlhxrR9fM6E6Nk7i 1DMg== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d14si2392654pgu.252.2021.10.27.19.23.02; Wed, 27 Oct 2021 19:23:15 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229846AbhJ1CXZ (ORCPT + 99 others); Wed, 27 Oct 2021 22:23:25 -0400 Received: from mailgw01.mediatek.com ([60.244.123.138]:44216 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S229809AbhJ1CXY (ORCPT ); Wed, 27 Oct 2021 22:23:24 -0400 X-UUID: 1de94ce069ba4bd59c11ecb3b1595b5d-20211028 X-UUID: 1de94ce069ba4bd59c11ecb3b1595b5d-20211028 Received: from mtkcas10.mediatek.inc [(172.21.101.39)] by mailgw01.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 52249534; Thu, 28 Oct 2021 10:20:54 +0800 Received: from mtkmbs10n1.mediatek.inc (172.21.101.34) by mtkmbs10n2.mediatek.inc (172.21.101.183) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.792.3; Thu, 28 Oct 2021 10:20:52 +0800 Received: from localhost.localdomain (10.17.3.154) by mtkmbs10n1.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.2.792.15 via Frontend Transport; Thu, 28 Oct 2021 10:20:52 +0800 From: Wenbin Mei To: Ulf Hansson CC: Matthias Brugger , Chaotian Jing , Chun-Hung Wu , "Yong Mao" , , , , , , "Wenbin Mei" , Subject: [PATCH] mmc: mediatek: move cqhci init behind ungate clock Date: Thu, 28 Oct 2021 10:20:49 +0800 Message-ID: <20211028022049.22129-1-wenbin.mei@mediatek.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-MTK: N Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We must enable clock before cqhci init, because crypto needs read information from CQHCI registers, otherwise, it will hang in MediaTek mmc host controller. Signed-off-by: Wenbin Mei Fixes: 88bd652b3c74 ("mmc: mediatek: command queue support") Cc: stable@vger.kernel.org --- drivers/mmc/host/mtk-sd.c | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/drivers/mmc/host/mtk-sd.c b/drivers/mmc/host/mtk-sd.c index b124cfee05a1..943940b44e83 100644 --- a/drivers/mmc/host/mtk-sd.c +++ b/drivers/mmc/host/mtk-sd.c @@ -2656,6 +2656,25 @@ static int msdc_drv_probe(struct platform_device *pdev) host->dma_mask = DMA_BIT_MASK(32); mmc_dev(mmc)->dma_mask = &host->dma_mask; + host->timeout_clks = 3 * 1048576; + host->dma.gpd = dma_alloc_coherent(&pdev->dev, + 2 * sizeof(struct mt_gpdma_desc), + &host->dma.gpd_addr, GFP_KERNEL); + host->dma.bd = dma_alloc_coherent(&pdev->dev, + MAX_BD_NUM * sizeof(struct mt_bdma_desc), + &host->dma.bd_addr, GFP_KERNEL); + if (!host->dma.gpd || !host->dma.bd) { + ret = -ENOMEM; + goto release_mem; + } + msdc_init_gpd_bd(host, &host->dma); + INIT_DELAYED_WORK(&host->req_timeout, msdc_request_timeout); + spin_lock_init(&host->lock); + + platform_set_drvdata(pdev, mmc); + msdc_ungate_clock(host); + msdc_init_hw(host); + if (mmc->caps2 & MMC_CAP2_CQE) { host->cq_host = devm_kzalloc(mmc->parent, sizeof(*host->cq_host), @@ -2676,25 +2695,6 @@ static int msdc_drv_probe(struct platform_device *pdev) mmc->max_seg_size = 64 * 1024; } - host->timeout_clks = 3 * 1048576; - host->dma.gpd = dma_alloc_coherent(&pdev->dev, - 2 * sizeof(struct mt_gpdma_desc), - &host->dma.gpd_addr, GFP_KERNEL); - host->dma.bd = dma_alloc_coherent(&pdev->dev, - MAX_BD_NUM * sizeof(struct mt_bdma_desc), - &host->dma.bd_addr, GFP_KERNEL); - if (!host->dma.gpd || !host->dma.bd) { - ret = -ENOMEM; - goto release_mem; - } - msdc_init_gpd_bd(host, &host->dma); - INIT_DELAYED_WORK(&host->req_timeout, msdc_request_timeout); - spin_lock_init(&host->lock); - - platform_set_drvdata(pdev, mmc); - msdc_ungate_clock(host); - msdc_init_hw(host); - ret = devm_request_irq(&pdev->dev, host->irq, msdc_irq, IRQF_TRIGGER_NONE, pdev->name, host); if (ret) -- 2.25.1