From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752869AbbCaJaX (ORCPT ); Tue, 31 Mar 2015 05:30:23 -0400 Received: from devils.ext.ti.com ([198.47.26.153]:49146 "EHLO devils.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751542AbbCaJaT (ORCPT ); Tue, 31 Mar 2015 05:30:19 -0400 Message-ID: <551A6926.8030101@ti.com> Date: Tue, 31 Mar 2015 12:30:14 +0300 From: Roger Quadros User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.5.0 MIME-Version: 1.0 To: Robert Baldyga , CC: , , , Subject: Re: [PATCH 3/4] extcon: usb-gpio: make debounce value configurable in devicetree References: <1427787963-23562-1-git-send-email-r.baldyga@samsung.com> <1427787963-23562-4-git-send-email-r.baldyga@samsung.com> In-Reply-To: <1427787963-23562-4-git-send-email-r.baldyga@samsung.com> Content-Type: text/plain; charset="windows-1252" Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 31/03/15 10:46, Robert Baldyga wrote: > This patch adds devicetree property for setting debounce value. It allows > to set debounce time shorter or longer depending on the needs of given > platform. > > Signed-off-by: Robert Baldyga > --- > drivers/extcon/extcon-usb-gpio.c | 14 +++++++++----- > 1 file changed, 9 insertions(+), 5 deletions(-) > > diff --git a/drivers/extcon/extcon-usb-gpio.c b/drivers/extcon/extcon-usb-gpio.c > index 02ff40e..86e3ece 100644 > --- a/drivers/extcon/extcon-usb-gpio.c > +++ b/drivers/extcon/extcon-usb-gpio.c > @@ -130,6 +130,7 @@ static int usb_extcon_probe(struct platform_device *pdev) > struct device *dev = &pdev->dev; > struct device_node *np = dev->of_node; > struct usb_extcon_info *info; > + u32 debounce; > int ret; > > if (!np) > @@ -140,6 +141,11 @@ static int usb_extcon_probe(struct platform_device *pdev) > return -ENOMEM; > > info->dev = dev; > + > + ret = of_property_read_u32(np, "debounce", &debounce); > + if (ret < 0) > + debounce = USB_GPIO_DEBOUNCE_MS; > + Should we sanity check debounce value provided by device tree? e.g. if it is greater than USB_GPIO_DEBOUNCE_MAX then we error out. MAX could be 100 or 250ms. > info->id_gpiod = devm_gpiod_get_optional(&pdev->dev, "id"); > info->vbus_gpiod = devm_gpiod_get_optional(&pdev->dev, "vbus"); > > @@ -161,16 +167,14 @@ static int usb_extcon_probe(struct platform_device *pdev) > } > > if (info->id_gpiod) > - ret = gpiod_set_debounce(info->id_gpiod, > - USB_GPIO_DEBOUNCE_MS * 1000); > + ret = gpiod_set_debounce(info->id_gpiod, debounce * 1000); > if (!ret && info->vbus_gpiod) { > - ret = gpiod_set_debounce(info->vbus_gpiod, > - USB_GPIO_DEBOUNCE_MS * 1000); > + ret = gpiod_set_debounce(info->vbus_gpiod, debounce * 1000); > if (ret < 0 && info->id_gpiod) > gpiod_set_debounce(info->vbus_gpiod, 0); > } > if (ret < 0) > - info->debounce_jiffies = msecs_to_jiffies(USB_GPIO_DEBOUNCE_MS); > + info->debounce_jiffies = msecs_to_jiffies(debounce); > > INIT_DELAYED_WORK(&info->wq_detcable, usb_extcon_detect_cable); > > cheers, -roger