From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751581AbdHFOaL (ORCPT ); Sun, 6 Aug 2017 10:30:11 -0400 Received: from bh-25.webhostbox.net ([208.91.199.152]:56647 "EHLO bh-25.webhostbox.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751301AbdHFOaJ (ORCPT ); Sun, 6 Aug 2017 10:30:09 -0400 Subject: Re: [PATCH 10/18] staging: typec: fusb302: Add support for fcs,vbus-regulator-name device-property To: Hans de Goede , Darren Hart , Andy Shevchenko , Wolfram Sang , Sebastian Reichel , Greg Kroah-Hartman , Heikki Krogerus Cc: platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org, linux-i2c@vger.kernel.org, Liam Breck , Tony Lindgren , linux-pm@vger.kernel.org, devel@driverdev.osuosl.org References: <20170806123555.5124-1-hdegoede@redhat.com> <20170806123555.5124-11-hdegoede@redhat.com> From: Guenter Roeck Message-ID: <2d04e538-0594-0073-939e-feb6c1a66cdf@roeck-us.net> Date: Sun, 6 Aug 2017 07:30:05 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <20170806123555.5124-11-hdegoede@redhat.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Authenticated_sender: linux@roeck-us.net X-OutGoing-Spam-Status: No, score=-1.0 X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - bh-25.webhostbox.net X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - roeck-us.net X-Get-Message-Sender-Via: bh-25.webhostbox.net: authenticated_id: linux@roeck-us.net X-Authenticated-Sender: bh-25.webhostbox.net: linux@roeck-us.net X-Source: X-Source-Args: X-Source-Dir: Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/06/2017 05:35 AM, Hans de Goede wrote: > On devicetree platforms the fusb302 dt-node will have a vbus regulator > property with a phandle to the regulator. > > On ACPI platforms, there are no phandles and we need to get the vbus by a > system wide unique name. Add support for a new "fcs,vbus-regulator-name" > device-property which ACPI platform code can set to pass the name. > > Signed-off-by: Hans de Goede > --- > drivers/staging/typec/fusb302/fusb302.c | 28 ++++++++++++++++++++++------ > 1 file changed, 22 insertions(+), 6 deletions(-) > > diff --git a/drivers/staging/typec/fusb302/fusb302.c b/drivers/staging/typec/fusb302/fusb302.c > index e1e08f57af99..c3bcc5484ade 100644 > --- a/drivers/staging/typec/fusb302/fusb302.c > +++ b/drivers/staging/typec/fusb302/fusb302.c > @@ -1722,6 +1722,28 @@ static int fusb302_probe(struct i2c_client *client, > return -EPROBE_DEFER; > } > > + /* > + * Devicetree platforms should get vbus from their dt-node. > + * On ACPI platforms, we need to get the vbus by a system wide unique > + * name, which is set in a device prop by the platform code. > + */ > + if (device_property_read_string(dev, "fcs,vbus-regulator-name", > + &name) == 0) { Another property to be documented and approved. Also, isn't there a better way to get regulator names for dt- and non-dt systems ? This would apply to every driver supporting both and using regulators, which seems awkward. > + /* > + * Use regulator_get_optional so that we can detect if we need > + * to defer the probe rather then getting the dummy-regulator. > + */ Wouldn't this apply to dt systems as well ? > + chip->vbus = devm_regulator_get_optional(dev, name); > + if (IS_ERR(chip->vbus)) { > + ret = PTR_ERR(chip->vbus); > + return (ret == -ENODEV) ? -EPROBE_DEFER : ret; > + } > + } else { > + chip->vbus = devm_regulator_get(dev, "vbus"); > + if (IS_ERR(chip->vbus)) > + return PTR_ERR(chip->vbus); > + } > + You might also want to explain why you moved this code. > ret = tcpm_register_psy(chip->dev, &chip->tcpc_dev, > "fusb302-typec-source"); > if (ret < 0) > @@ -1739,12 +1761,6 @@ static int fusb302_probe(struct i2c_client *client, > INIT_DELAYED_WORK(&chip->bc_lvl_handler, fusb302_bc_lvl_handler_work); > init_tcpc_dev(&chip->tcpc_dev); > > - chip->vbus = devm_regulator_get(chip->dev, "vbus"); > - if (IS_ERR(chip->vbus)) { > - ret = PTR_ERR(chip->vbus); > - goto destroy_workqueue; > - } > - > if (client->irq) { > chip->gpio_int_n_irq = client->irq; > } else { >