aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>2019-06-25 01:38:57 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-06-25 22:33:09 -0400
commit426d3ff2f5ab7207aea0c1769d74b25a7b51b4dd (patch)
treeb3cc19b77c4206ec4221a60a668e2f39be39f4d2
parent76eff170bb05e59218008a21df670cb7177110e4 (diff)
usb: renesas_usbhs: Use struct platform_callback pointer
Now the driver fixes the issue of the commit 482982062f1b ("usb: gadget: renesas_usbhs: bugfix: don't modify platform data") by using usbhs_mod_info.get_vbus, this patches uses the pointer instead of copied value to avoid redundancy. Note that struct renesas_usbhs_driver_param has to use copied value because the driver has to set some members (e.g. buswait_bwait). Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/usb/renesas_usbhs/common.c8
-rw-r--r--drivers/usb/renesas_usbhs/common.h2
-rw-r--r--drivers/usb/renesas_usbhs/mod.c2
3 files changed, 6 insertions, 6 deletions
diff --git a/drivers/usb/renesas_usbhs/common.c b/drivers/usb/renesas_usbhs/common.c
index fe7dc91fef98..4c3de777ef6c 100644
--- a/drivers/usb/renesas_usbhs/common.c
+++ b/drivers/usb/renesas_usbhs/common.c
@@ -53,8 +53,8 @@
53 */ 53 */
54#define usbhs_platform_call(priv, func, args...)\ 54#define usbhs_platform_call(priv, func, args...)\
55 (!(priv) ? -ENODEV : \ 55 (!(priv) ? -ENODEV : \
56 !((priv)->pfunc.func) ? 0 : \ 56 !((priv)->pfunc->func) ? 0 : \
57 (priv)->pfunc.func(args)) 57 (priv)->pfunc->func(args))
58 58
59/* 59/*
60 * common functions 60 * common functions
@@ -644,7 +644,7 @@ static int usbhs_probe(struct platform_device *pdev)
644 dev_err(dev, "no platform callbacks\n"); 644 dev_err(dev, "no platform callbacks\n");
645 return -EINVAL; 645 return -EINVAL;
646 } 646 }
647 priv->pfunc = info->platform_callback; 647 priv->pfunc = &info->platform_callback;
648 648
649 /* set default param if platform doesn't have */ 649 /* set default param if platform doesn't have */
650 if (usbhs_get_dparam(priv, has_new_pipe_configs)) { 650 if (usbhs_get_dparam(priv, has_new_pipe_configs)) {
@@ -665,7 +665,7 @@ static int usbhs_probe(struct platform_device *pdev)
665 665
666 /* FIXME */ 666 /* FIXME */
667 /* runtime power control ? */ 667 /* runtime power control ? */
668 if (priv->pfunc.get_vbus) 668 if (priv->pfunc->get_vbus)
669 usbhs_get_dparam(priv, runtime_pwctrl) = 1; 669 usbhs_get_dparam(priv, runtime_pwctrl) = 1;
670 670
671 /* 671 /*
diff --git a/drivers/usb/renesas_usbhs/common.h b/drivers/usb/renesas_usbhs/common.h
index f6ffdb2c1174..d1a0a35ecfff 100644
--- a/drivers/usb/renesas_usbhs/common.h
+++ b/drivers/usb/renesas_usbhs/common.h
@@ -252,7 +252,7 @@ struct usbhs_priv {
252 unsigned int irq; 252 unsigned int irq;
253 unsigned long irqflags; 253 unsigned long irqflags;
254 254
255 struct renesas_usbhs_platform_callback pfunc; 255 const struct renesas_usbhs_platform_callback *pfunc;
256 struct renesas_usbhs_driver_param dparam; 256 struct renesas_usbhs_driver_param dparam;
257 257
258 struct delayed_work notify_hotplug_work; 258 struct delayed_work notify_hotplug_work;
diff --git a/drivers/usb/renesas_usbhs/mod.c b/drivers/usb/renesas_usbhs/mod.c
index ddf0153dcf16..10fc65596014 100644
--- a/drivers/usb/renesas_usbhs/mod.c
+++ b/drivers/usb/renesas_usbhs/mod.c
@@ -52,7 +52,7 @@ void usbhs_mod_non_autonomy_mode(struct usbhs_priv *priv)
52{ 52{
53 struct usbhs_mod_info *info = usbhs_priv_to_modinfo(priv); 53 struct usbhs_mod_info *info = usbhs_priv_to_modinfo(priv);
54 54
55 info->get_vbus = priv->pfunc.get_vbus; 55 info->get_vbus = priv->pfunc->get_vbus;
56} 56}
57 57
58/* 58/*