Re: [PATCH V4 4/7] mmc: sdhci: add 32-bit block count support for v4 mode

From: Adrian Hunter
Date: Tue Aug 14 2018 - 09:28:10 EST


On 07/08/18 04:58, Jason Wu (åéç) wrote:
> Â
>
> According the information of following picture, in this case I think, we
> just have 2 choice in sdio v4.1:
>
> 1 do not define SDHCI_AUTO_CMD23: argument of cmd23 will define in register
> 0x8(Argument register)

That would only need to be done for requests that use the upper bits. i.e.
Perhaps hook host->mmc_host_ops->request() and check if sbc argument is ok.
Then toggle SDHCI_AUTO_CMD23 accordingly.

>
> 2 or define SDHCI_USE_ADMA: block count of cmd18/28 will be get in âCommand
> Descriptor for SD Modâof ADMA. And block cnt register will be used as
> parameter of auto cmd23.
>
> -----Original Message-----
> From: Chunyan Zhang [mailto:zhang.lyra@xxxxxxxxx]
> Sent: Monday, August 06, 2018 7:29 PM
> To: Adrian Hunter
> Cc: Chunyan Zhang; Ulf Hansson; linux-mmc@xxxxxxxxxxxxxxx; Linux Kernel
> Mailing List; Orson Zhai; Baolin Wang; Billows Wu (æææ); Jason Wu (åéç)
> Subject: Re: [PATCH V4 4/7] mmc: sdhci: add 32-bit block count support for
> v4 mode
>
> Â
>
> Hi Adrian,
>
> Â
>
> On 30 July 2018 at 21:05, Adrian Hunter <adrian.hunter@xxxxxxxxx
> <mailto:adrian.hunter@xxxxxxxxx>> wrote:
>
>> On 24/07/18 05:51, Chunyan Zhang wrote:
>
>>> Host Controller Version 4.10 re-defines SDMA System Address register
>
>>> as 32-bit Block Count for v4 mode, and SDMA uses ADMA System Address
>
>>> register (05Fh-058h) instead if v4 mode is enabled. Also when using
>
>>> 32-bit block count, 16-bit block count register need to be set to
>
>>> zero.
>
>>>Â
>
>>> Signed-off-by: Chunyan Zhang <zhang.chunyan@xxxxxxxxxx <mailto:zhang.chunyan@xxxxxxxxxx>>
>
>>> ---
>
>>>Â drivers/mmc/host/sdhci.c | 14 +++++++++++++-Â
>
>>> drivers/mmc/host/sdhci.h |Â 1 +
>
>>>Â 2 files changed, 14 insertions(+), 1 deletion(-)
>
>>>Â
>
>>> diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c
>
>>> index 920d8ec..c272a2b 100644
>
>>> --- a/drivers/mmc/host/sdhci.c
>
>>> +++ b/drivers/mmc/host/sdhci.c
>
>>> @@ -1070,7 +1070,19 @@ static void sdhci_prepare_data(struct sdhci_host *host, struct mmc_command *cmd)
>
>>>ÂÂÂÂÂÂ /* Set the DMA boundary value and block size */
>
>>>ÂÂÂÂÂÂ sdhci_writew(host, SDHCI_MAKE_BLKSZ(host->sdma_boundary, data->blksz),
>
>>>ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂ SDHCI_BLOCK_SIZE);
>
>>> -ÂÂÂÂ sdhci_writew(host, data->blocks, SDHCI_BLOCK_COUNT);
>
>>> +
>
>>> +ÂÂÂÂ /*
>
>>> +ÂÂÂÂÂ * For Version 4.10 onwards, if v4 mode is enabled, 16-bit Block Count
>
>>> +ÂÂÂÂÂ * register need to be set to zero, 32-bit Block Count register would
>
>>> +ÂÂÂÂÂ * be selected.
>
>>> +ÂÂÂÂÂ */
>
>>> +ÂÂÂÂ if (host->version >= SDHCI_SPEC_410 && host->v4_mode) {
>
>>> +ÂÂÂÂÂÂÂÂÂÂÂÂ if (sdhci_readw(host, SDHCI_BLOCK_COUNT))
>
>>> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂ sdhci_writew(host, 0, SDHCI_BLOCK_COUNT);
>
>>> +ÂÂÂÂÂÂÂÂÂÂÂÂ sdhci_writew(host, data->blocks, SDHCI_32BIT_BLK_CNT);
>
>
>
>> So this is also SDHCI_ARGUMENT2 which is why there is a conflict with
>
>> auto-CMD23. We need to write SDHCI_32BIT_BLK_CNT only once, but also
>
>> cater for eMMC which uses the CMD23 argument for more than just block count.
>
>
>
> Â
>
> What you would suggest on how should we change here?
>
> Â
>
> I've double checked with the hardware fellow within the company, the sd host
> controller v4 (on our platform at least) would use this register as block
> count only, that's saying that it would not deal with the flags (i.e.
> reliable write and data tag) of CMD23.
>
> Â
>
> Thanks,
>
> Chunyan
>
> Â
>
>>> +ÂÂÂÂ } else {
>
>>> +ÂÂÂÂÂÂÂÂÂÂÂÂ sdhci_writew(host, data->blocks, SDHCI_BLOCK_COUNT);
>
>>> +ÂÂÂÂ }
>
>>>Â }
>
>>>Â
>
>>>Â static inline bool sdhci_auto_cmd12(struct sdhci_host *host, diff
>
>>> --git a/drivers/mmc/host/sdhci.h b/drivers/mmc/host/sdhci.h index
>
>>> 23318ff..81aae07 100644
>
>>> --- a/drivers/mmc/host/sdhci.h
>
>>> +++ b/drivers/mmc/host/sdhci.h
>
>>> @@ -28,6 +28,7 @@
>
>>>Â
>
>>>Â #define SDHCI_DMA_ADDRESSÂÂÂ 0x00
>
>>>Â #define SDHCI_ARGUMENT2ÂÂÂÂÂÂÂÂÂÂÂÂÂ SDHCI_DMA_ADDRESS
>
>>> +#define SDHCI_32BIT_BLK_CNTÂ SDHCI_DMA_ADDRESS
>
>>>Â
>
>>>Â #define SDHCI_BLOCK_SIZEÂÂÂÂ 0x04
>
>>> #define SDHCI_MAKE_BLKSZ(dma, blksz) (((dma & 0x7) << 12) | (blksz
>
>>> & 0xFFF))
>
>>>Â
>
>
>