Return-path: Received: from bear.ext.ti.com ([192.94.94.41]:56889 "EHLO bear.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751770AbbLXQev (ORCPT ); Thu, 24 Dec 2015 11:34:51 -0500 Subject: Re: [PATCH v2 1/3] wlcore/wl12xx: spi: add power operation function To: Uri Mashiach , Kalle Valo , Rob Herring , Tony Lindgren References: <1450971335-15961-1-git-send-email-uri.mashiach@compulab.co.il> <1450971335-15961-2-git-send-email-uri.mashiach@compulab.co.il> CC: Pawel Moll , Mark Rutland , Ian Campbell , Kumar Gala , , Igor Grinberg , Eliad Peller , , , , From: Grygorii Strashko Message-ID: <567C1E3B.3020404@ti.com> (sfid-20151224_173456_473293_E7795DF0) Date: Thu, 24 Dec 2015 18:32:59 +0200 MIME-Version: 1.0 In-Reply-To: <1450971335-15961-2-git-send-email-uri.mashiach@compulab.co.il> Content-Type: text/plain; charset="windows-1252"; format=flowed Sender: linux-wireless-owner@vger.kernel.org List-ID: 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 > --- > 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); > + 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"); > -- regards, -grygorii