Re: [PATCH 1/3] mmc: sdhci-esdhc-imx: get rid of support_vsel

From: Stefan Agner
Date: Thu Jul 05 2018 - 07:16:37 EST


On 05.07.2018 04:52, A.s. Dong wrote:
>> -----Original Message-----
>> From: Stefan Agner [mailto:stefan@xxxxxxxx]
>> Sent: Thursday, June 28, 2018 4:13 PM
>> To: adrian.hunter@xxxxxxxxx; ulf.hansson@xxxxxxxxxx
>> Cc: Fabio Estevam <fabio.estevam@xxxxxxx>; Bough Chen
>> <haibo.chen@xxxxxxx>; A.s. Dong <aisheng.dong@xxxxxxx>;
>> michael@xxxxxxxxxxxxxxxxxxxx; rmk+kernel@xxxxxxxxxxxxxxx; linux-
>> mmc@xxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx; Stefan Agner
>> <stefan@xxxxxxxx>
>> Subject: [PATCH 1/3] mmc: sdhci-esdhc-imx: get rid of support_vsel
>>
>> The field support_vsel is currently only used in the device tree case. Get rid
>> of it. No change in behavior.
>>
>
> I'm not sure if it's quite necessary to remove it as it's used to bypass
> 100Mhz above pad settings look up which is meaningless if user claims
> no 1-8 v support.
>
> If you remove it, probably you still need better check the quirk for
> Pad state look up.

There should be really no change in behavior, just simplifying code:

If no-1-8-v is set, SDHCI_QUIRK2_NO_1_8_V will be set in any case.

If no-1-8-v is not set, SDHCI_QUIRK2_NO_1_8_V will be set depending on
whether pinctrl states are available

This has been the case before and after this change.

--
Stefan

>
> Regards
> Dong Aisheng
>
>> Signed-off-by: Stefan Agner <stefan@xxxxxxxx>
>> ---
>> drivers/mmc/host/sdhci-esdhc-imx.c | 8 ++------
>> include/linux/platform_data/mmc-esdhc-imx.h | 2 --
>> 2 files changed, 2 insertions(+), 8 deletions(-)
>>
>> diff --git a/drivers/mmc/host/sdhci-esdhc-imx.c b/drivers/mmc/host/sdhci-
>> esdhc-imx.c
>> index 6f444731754d..20a420b765b3 100644
>> --- a/drivers/mmc/host/sdhci-esdhc-imx.c
>> +++ b/drivers/mmc/host/sdhci-esdhc-imx.c
>> @@ -1145,18 +1145,14 @@ sdhci_esdhc_imx_probe_dt(struct
>> platform_device *pdev,
>> &boarddata->tuning_start_tap);
>>
>> if (of_find_property(np, "no-1-8-v", NULL))
>> - boarddata->support_vsel = false;
>> - else
>> - boarddata->support_vsel = true;
>> + host->quirks2 |= SDHCI_QUIRK2_NO_1_8_V;
>>
>> if (of_property_read_u32(np, "fsl,delay-line", &boarddata-
>> >delay_line))
>> boarddata->delay_line = 0;
>>
>> mmc_of_parse_voltage(np, &host->ocr_mask);
>>
>> - /* sdr50 and sdr104 need work on 1.8v signal voltage */
>> - if ((boarddata->support_vsel) && esdhc_is_usdhc(imx_data) &&
>> - !IS_ERR(imx_data->pins_default)) {
>> + if (esdhc_is_usdhc(imx_data) && !IS_ERR(imx_data->pins_default))
>> {
>> imx_data->pins_100mhz = pinctrl_lookup_state(imx_data-
>> >pinctrl,
>>
>> ESDHC_PINCTRL_STATE_100MHZ);
>> imx_data->pins_200mhz = pinctrl_lookup_state(imx_data-
>> >pinctrl,
>> diff --git a/include/linux/platform_data/mmc-esdhc-imx.h
>> b/include/linux/platform_data/mmc-esdhc-imx.h
>> index 7daa78a2f342..640dec8b5b0c 100644
>> --- a/include/linux/platform_data/mmc-esdhc-imx.h
>> +++ b/include/linux/platform_data/mmc-esdhc-imx.h
>> @@ -34,7 +34,6 @@ enum cd_types {
>> * @cd_gpio: gpio for card_detect interrupt
>> * @wp_type: type of write_protect method (see wp_types enum above)
>> * @cd_type: type of card_detect method (see cd_types enum above)
>> - * @support_vsel: indicate it supports 1.8v switching
>> */
>>
>> struct esdhc_platform_data {
>> @@ -43,7 +42,6 @@ struct esdhc_platform_data {
>> enum wp_types wp_type;
>> enum cd_types cd_type;
>> int max_bus_width;
>> - bool support_vsel;
>> unsigned int delay_line;
>> unsigned int tuning_step; /* The delay cell steps in tuning
>> procedure */
>> unsigned int tuning_start_tap; /* The start delay cell point in tuning
>> procedure */
>> --
>> 2.18.0