[PATCH v2 1/3] wlcore/wl12xx: spi: add power operation function

Uri Mashiach uri.mashiach at compulab.co.il
Sun Dec 27 09:14:32 PST 2015


Hello Grygorii,

On 12/24/2015 06:32 PM, Grygorii Strashko wrote:
> On 12/24/2015 05:35 PM, Uri Mashiach wrote:
>> The power function uses a consumer regulator access to update the WiFi
>> enable GPIO value.
>>
>> Signed-off-by: Uri Mashiach <uri.mashiach at compulab.co.il>
>> ---
>> v1 -> v2: oops fix was removed to a separate fix.
>>
>>   drivers/net/wireless/ti/wlcore/spi.c | 37
>> ++++++++++++++++++++++++++++++++++++
>>   1 file changed, 37 insertions(+)
>>
>> diff --git a/drivers/net/wireless/ti/wlcore/spi.c
>> b/drivers/net/wireless/ti/wlcore/spi.c
>>
>
> [...]
>
>> +
>>   static struct wl1271_if_operations spi_ops = {
>>       .read        = wl12xx_spi_raw_read,
>>       .write        = wl12xx_spi_raw_write,
>>       .reset        = wl12xx_spi_reset,
>>       .init        = wl12xx_spi_init,
>> +    .power        = wl12xx_spi_set_power,
>>       .set_block_size = NULL,
>>   };
>>
>> @@ -353,6 +384,12 @@ static int wl1271_probe(struct spi_device *spi)
>>        * comes from the board-peripherals file */
>>       spi->bits_per_word = 32;
>>
>> +    glue->reg = devm_regulator_get(&spi->dev, "vwlan");
>> +    if (IS_ERR(glue->reg)) {
>
> It will be more correct to handle -EPROBE_DEFER here also. Like:
>           if (PTR_ERR(glue->reg) == -EPROBE_DEFER)
>              return PTR_ERR(glue->reg);
>

It seems that the IS_ERR(glue->reg) condition covers the EPROBE_DEFER case.

>> +        dev_err(glue->dev, "can't get regulator\n");
>> +        return PTR_ERR(glue->reg);
>> +    }
>> +
>>       ret = spi_setup(spi);
>>       if (ret < 0) {
>>           dev_err(glue->dev, "spi_setup failed\n");
>>
>
>

-- 
Thanks,
Uri



More information about the linux-arm-kernel mailing list