Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp5393538img; Wed, 27 Mar 2019 07:45:38 -0700 (PDT) X-Google-Smtp-Source: APXvYqz6hbqqiD6wU2loepUh2Z9uuQ4DELbtj8x7WxOlxgcVYA1bXvynaUuMFWUf7I9mkl5N9PvR X-Received: by 2002:aa7:914d:: with SMTP id 13mr13229045pfi.149.1553697938121; Wed, 27 Mar 2019 07:45:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553697938; cv=none; d=google.com; s=arc-20160816; b=TCo7Sxv+9Tv1l6W86QK4zJHC21DCUt4MT1b9O4Sv/JO/9i2dnhJC9by5vxCirFKVg+ jJ0Dg/WqIRNlp6Y9UbqG9bUxzDB7c08byv9XlrGjeeLbbBi1Hg3JlDNp176aeofj1dir 8If3dEtiEfi+6nQUwVv/wPrWAPijHyjr5vOkTxiaWAZrC7WLM0zw9b/B3Takf0rPoasO eU54XGj9KEdhjf2ZLZEOMkr1oibZwSzqFHE3sycHgQSmVdpPDdaODcAJwQ+0r7h/wvhM 8sxSKxFI0v+b3YqUKTxuJZz+TnEuI0RjnFjYpAdHueUe1M+uLeysME9vykvoJQ+qW3D3 aPPA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=7xhT5hbQUriarqldUrDHT/eKADHWCY+cXxavBP9nFjM=; b=Q9+J1FLtTEPylmW4pZ8yJJmQ8A5j3BSWCSNR7RMH9CwYxqRM9aAjTdbWsr5VZ1HfKc yZZCXR8daUEf/jlbY3SUnek7I9xhUpqWcFSJ+GC8ILWWK4c22aNCz4uqV+kCdR0hRRHN epcZXYWbiYE8nQTU7mmVOZ5KWj2+scsj/4hnIMdWyF39rcJxWeI7OxlB8XYC1ZY6iU7U 1qmCvsxyuYy3GI4suaF3up4XsvFA+2L+NekQEhE2EjCDpNvXZsRR5Tqj4x6IIzvXl3ot lJzHLHwRXBhLm0VvrGv0we219hUwg50qgipAsJHzKpv3LwCSplbgudC1hZxQF1D/xvHi UEsg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a89si20809769pla.362.2019.03.27.07.45.22; Wed, 27 Mar 2019 07:45:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728314AbfC0Oon (ORCPT + 99 others); Wed, 27 Mar 2019 10:44:43 -0400 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:1545 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726147AbfC0Oon (ORCPT ); Wed, 27 Mar 2019 10:44:43 -0400 Received: from pps.filterd (m0046668.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.27/8.16.0.27) with SMTP id x2REetnp016025; Wed, 27 Mar 2019 15:44:23 +0100 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 2rddhbrg0u-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Wed, 27 Mar 2019 15:44:23 +0100 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id DA55834; Wed, 27 Mar 2019 14:44:22 +0000 (GMT) Received: from Webmail-eu.st.com (sfhdag6node1.st.com [10.75.127.16]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id ACA615905; Wed, 27 Mar 2019 14:44:22 +0000 (GMT) Received: from [10.48.0.237] (10.75.127.46) by SFHDAG6NODE1.st.com (10.75.127.16) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Wed, 27 Mar 2019 15:44:21 +0100 Subject: Re: [PATCH V4 4/5] mmc: mmci: stm32: define get_dctrl_cfg To: Ulf Hansson CC: Rob Herring , Srinivas Kandagatla , Maxime Coquelin , Alexandre Torgue , Linux ARM , Linux Kernel Mailing List , DTML , "linux-mmc@vger.kernel.org" , References: <1553677532-3539-1-git-send-email-ludovic.Barre@st.com> <1553677532-3539-5-git-send-email-ludovic.Barre@st.com> From: Ludovic BARRE Message-ID: Date: Wed, 27 Mar 2019 15:44:21 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.5.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.75.127.46] X-ClientProxiedBy: SFHDAG5NODE1.st.com (10.75.127.13) To SFHDAG6NODE1.st.com (10.75.127.16) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2019-03-27_09:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/27/19 11:54 AM, Ulf Hansson wrote: > On Wed, 27 Mar 2019 at 10:05, Ludovic Barre wrote: >> >> From: Ludovic Barre >> >> This patch defines get_dctrl_cfg callback for sdmmc variant. >> sdmmc variant has specific stm32 transfer modes. >> sdmmc data transfer mode selection could be: >> -Block data transfer ending on block count. >> -SDIO multibyte data transfer. >> -MMC Stream data transfer (not used). >> -Block data transfer ending with STOP_TRANSMISSION command. >> >> Signed-off-by: Ludovic Barre >> --- >> drivers/mmc/host/mmci.h | 5 +++++ >> drivers/mmc/host/mmci_stm32_sdmmc.c | 18 ++++++++++++++++++ >> 2 files changed, 23 insertions(+) >> >> diff --git a/drivers/mmc/host/mmci.h b/drivers/mmc/host/mmci.h >> index 35c91d0..82e9f94 100644 >> --- a/drivers/mmc/host/mmci.h >> +++ b/drivers/mmc/host/mmci.h >> @@ -131,6 +131,11 @@ >> /* Control register extensions in the Qualcomm versions */ >> #define MCI_DPSM_QCOM_DATA_PEND BIT(17) >> #define MCI_DPSM_QCOM_RX_DATA_PEND BIT(20) >> +/* Control register extensions in STM32 versions */ >> +#define MCI_DPSM_STM32_MODE_BLOCK (0 << 2) >> +#define MCI_DPSM_STM32_MODE_SDIO (1 << 2) >> +#define MCI_DPSM_STM32_MODE_STREAM (2 << 2) >> +#define MCI_DPSM_STM32_MODE_BLOCK_STOP (3 << 2) >> >> #define MMCIDATACNT 0x030 >> #define MMCISTATUS 0x034 >> diff --git a/drivers/mmc/host/mmci_stm32_sdmmc.c b/drivers/mmc/host/mmci_stm32_sdmmc.c >> index cfbfc6f..8e83ae6 100644 >> --- a/drivers/mmc/host/mmci_stm32_sdmmc.c >> +++ b/drivers/mmc/host/mmci_stm32_sdmmc.c >> @@ -265,10 +265,28 @@ static void mmci_sdmmc_set_pwrreg(struct mmci_host *host, unsigned int pwr) >> } >> } >> >> +static u32 sdmmc_get_dctrl_cfg(struct mmci_host *host) >> +{ >> + u32 datactrl; >> + >> + datactrl = mmci_dctrl_blksz(host); >> + >> + if (host->mmc->card && mmc_card_sdio(host->mmc->card) && >> + host->data->blocks == 1) >> + datactrl |= MCI_DPSM_STM32_MODE_SDIO; >> + else if (host->data->stop && !host->mrq->sbc) >> + datactrl |= MCI_DPSM_STM32_MODE_BLOCK_STOP; > > Just a question here. Does this mean that the controller sends the > stop command automatically when a transfer has finished successfully? The controller not sends the stop command, this bit is just an information for the Data State Machine to know how the data transfer finish. Regards, Ludo > >> + else >> + datactrl |= MCI_DPSM_STM32_MODE_BLOCK; >> + >> + return datactrl; >> +} >> + >> static struct mmci_host_ops sdmmc_variant_ops = { >> .validate_data = sdmmc_idma_validate_data, >> .prep_data = sdmmc_idma_prep_data, >> .unprep_data = sdmmc_idma_unprep_data, >> + .get_datactrl_cfg = sdmmc_get_dctrl_cfg, >> .dma_setup = sdmmc_idma_setup, >> .dma_start = sdmmc_idma_start, >> .dma_finalize = sdmmc_idma_finalize, >> -- >> 2.7.4 >> > > Kind regards > Uffe >