aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/extcon/Kconfig4
-rw-r--r--drivers/extcon/Makefile2
-rw-r--r--drivers/extcon/extcon-class.c42
-rw-r--r--drivers/extcon/of_extcon.c56
-rw-r--r--drivers/usb/dwc3/dwc3-omap.c3
-rw-r--r--include/linux/extcon.h12
-rw-r--r--include/linux/extcon/of_extcon.h31
7 files changed, 55 insertions, 95 deletions
diff --git a/drivers/extcon/Kconfig b/drivers/extcon/Kconfig
index bdb5a00f1dfa..be56e8ac95e6 100644
--- a/drivers/extcon/Kconfig
+++ b/drivers/extcon/Kconfig
@@ -14,10 +14,6 @@ if EXTCON
14 14
15comment "Extcon Device Drivers" 15comment "Extcon Device Drivers"
16 16
17config OF_EXTCON
18 def_tristate y
19 depends on OF
20
21config EXTCON_GPIO 17config EXTCON_GPIO
22 tristate "GPIO extcon support" 18 tristate "GPIO extcon support"
23 depends on GPIOLIB 19 depends on GPIOLIB
diff --git a/drivers/extcon/Makefile b/drivers/extcon/Makefile
index 43eccc0e3448..bf7861ec0906 100644
--- a/drivers/extcon/Makefile
+++ b/drivers/extcon/Makefile
@@ -2,8 +2,6 @@
2# Makefile for external connector class (extcon) devices 2# Makefile for external connector class (extcon) devices
3# 3#
4 4
5obj-$(CONFIG_OF_EXTCON) += of_extcon.o
6
7obj-$(CONFIG_EXTCON) += extcon-class.o 5obj-$(CONFIG_EXTCON) += extcon-class.o
8obj-$(CONFIG_EXTCON_GPIO) += extcon-gpio.o 6obj-$(CONFIG_EXTCON_GPIO) += extcon-gpio.o
9obj-$(CONFIG_EXTCON_ADC_JACK) += extcon-adc-jack.o 7obj-$(CONFIG_EXTCON_ADC_JACK) += extcon-adc-jack.o
diff --git a/drivers/extcon/extcon-class.c b/drivers/extcon/extcon-class.c
index 76322330cbd7..7ab21aa6eaa1 100644
--- a/drivers/extcon/extcon-class.c
+++ b/drivers/extcon/extcon-class.c
@@ -31,6 +31,7 @@
31#include <linux/extcon.h> 31#include <linux/extcon.h>
32#include <linux/slab.h> 32#include <linux/slab.h>
33#include <linux/sysfs.h> 33#include <linux/sysfs.h>
34#include <linux/of.h>
34 35
35/* 36/*
36 * extcon_cable_name suggests the standard cable names for commonly used 37 * extcon_cable_name suggests the standard cable names for commonly used
@@ -818,6 +819,47 @@ void extcon_dev_unregister(struct extcon_dev *edev)
818} 819}
819EXPORT_SYMBOL_GPL(extcon_dev_unregister); 820EXPORT_SYMBOL_GPL(extcon_dev_unregister);
820 821
822#ifdef CONFIG_OF
823/*
824 * extcon_get_edev_by_phandle - Get the extcon device from devicetree
825 * @dev - instance to the given device
826 * @index - index into list of extcon_dev
827 *
828 * return the instance of extcon device
829 */
830struct extcon_dev *extcon_get_edev_by_phandle(struct device *dev, int index)
831{
832 struct device_node *node;
833 struct extcon_dev *edev;
834
835 if (!dev->of_node) {
836 dev_err(dev, "device does not have a device node entry\n");
837 return ERR_PTR(-EINVAL);
838 }
839
840 node = of_parse_phandle(dev->of_node, "extcon", index);
841 if (!node) {
842 dev_err(dev, "failed to get phandle in %s node\n",
843 dev->of_node->full_name);
844 return ERR_PTR(-ENODEV);
845 }
846
847 edev = extcon_get_extcon_dev(node->name);
848 if (!edev) {
849 dev_err(dev, "unable to get extcon device : %s\n", node->name);
850 return ERR_PTR(-ENODEV);
851 }
852
853 return edev;
854}
855#else
856struct extcon_dev *extcon_get_edev_by_phandle(struct device *dev, int index)
857{
858 return ERR_PTR(-ENOSYS);
859}
860#endif /* CONFIG_OF */
861EXPORT_SYMBOL_GPL(extcon_get_edev_by_phandle);
862
821static int __init extcon_class_init(void) 863static int __init extcon_class_init(void)
822{ 864{
823 return create_extcon_class(); 865 return create_extcon_class();
diff --git a/drivers/extcon/of_extcon.c b/drivers/extcon/of_extcon.c
deleted file mode 100644
index 0a29f822cf77..000000000000
--- a/drivers/extcon/of_extcon.c
+++ /dev/null
@@ -1,56 +0,0 @@
1/*
2 * OF helpers for External connector (extcon) framework
3 *
4 * Copyright (C) 2013 Texas Instruments, Inc.
5 * Kishon Vijay Abraham I <kishon@ti.com>
6 *
7 * Copyright (C) 2013 Samsung Electronics
8 * Chanwoo Choi <cw00.choi@samsung.com>
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 */
15
16#include <linux/module.h>
17#include <linux/slab.h>
18#include <linux/err.h>
19#include <linux/extcon.h>
20#include <linux/of.h>
21#include <linux/of_platform.h>
22#include <linux/extcon/of_extcon.h>
23
24/*
25 * of_extcon_get_extcon_dev - Get the name of extcon device from devicetree
26 * @dev - instance to the given device
27 * @index - index into list of extcon_dev
28 *
29 * return the instance of extcon device
30 */
31struct extcon_dev *of_extcon_get_extcon_dev(struct device *dev, int index)
32{
33 struct device_node *node;
34 struct extcon_dev *edev;
35
36 if (!dev->of_node) {
37 dev_dbg(dev, "device does not have a device node entry\n");
38 return ERR_PTR(-EINVAL);
39 }
40
41 node = of_parse_phandle(dev->of_node, "extcon", index);
42 if (!node) {
43 dev_dbg(dev, "failed to get phandle in %s node\n",
44 dev->of_node->full_name);
45 return ERR_PTR(-ENODEV);
46 }
47
48 edev = extcon_get_extcon_dev(node->name);
49 if (!edev) {
50 dev_dbg(dev, "unable to get extcon device : %s\n", node->name);
51 return ERR_PTR(-ENODEV);
52 }
53
54 return edev;
55}
56EXPORT_SYMBOL_GPL(of_extcon_get_extcon_dev);
diff --git a/drivers/usb/dwc3/dwc3-omap.c b/drivers/usb/dwc3/dwc3-omap.c
index b269dbd47fc4..b1d7ee6e40b7 100644
--- a/drivers/usb/dwc3/dwc3-omap.c
+++ b/drivers/usb/dwc3/dwc3-omap.c
@@ -29,7 +29,6 @@
29#include <linux/of.h> 29#include <linux/of.h>
30#include <linux/of_platform.h> 30#include <linux/of_platform.h>
31#include <linux/extcon.h> 31#include <linux/extcon.h>
32#include <linux/extcon/of_extcon.h>
33#include <linux/regulator/consumer.h> 32#include <linux/regulator/consumer.h>
34 33
35#include <linux/usb/otg.h> 34#include <linux/usb/otg.h>
@@ -522,7 +521,7 @@ static int dwc3_omap_probe(struct platform_device *pdev)
522 dwc3_omap_enable_irqs(omap); 521 dwc3_omap_enable_irqs(omap);
523 522
524 if (of_property_read_bool(node, "extcon")) { 523 if (of_property_read_bool(node, "extcon")) {
525 edev = of_extcon_get_extcon_dev(dev, 0); 524 edev = extcon_get_edev_by_phandle(dev, 0);
526 if (IS_ERR(edev)) { 525 if (IS_ERR(edev)) {
527 dev_vdbg(dev, "couldn't get extcon device\n"); 526 dev_vdbg(dev, "couldn't get extcon device\n");
528 ret = -EPROBE_DEFER; 527 ret = -EPROBE_DEFER;
diff --git a/include/linux/extcon.h b/include/linux/extcon.h
index 21c59af1150b..f488145bb2d4 100644
--- a/include/linux/extcon.h
+++ b/include/linux/extcon.h
@@ -240,6 +240,12 @@ extern int extcon_register_notifier(struct extcon_dev *edev,
240 struct notifier_block *nb); 240 struct notifier_block *nb);
241extern int extcon_unregister_notifier(struct extcon_dev *edev, 241extern int extcon_unregister_notifier(struct extcon_dev *edev,
242 struct notifier_block *nb); 242 struct notifier_block *nb);
243
244/*
245 * Following API get the extcon device from devicetree.
246 * This function use phandle of devicetree to get extcon device directly.
247 */
248extern struct extcon_dev *extcon_get_edev_by_phandle(struct device *dev, int index);
243#else /* CONFIG_EXTCON */ 249#else /* CONFIG_EXTCON */
244static inline int extcon_dev_register(struct extcon_dev *edev) 250static inline int extcon_dev_register(struct extcon_dev *edev)
245{ 251{
@@ -324,5 +330,11 @@ static inline int extcon_unregister_interest(struct extcon_specific_cable_nb
324{ 330{
325 return 0; 331 return 0;
326} 332}
333
334static inline struct extcon_dev *extcon_get_edev_by_phandle(struct device *dev,
335 int index)
336{
337 return ERR_PTR(-ENODEV);
338}
327#endif /* CONFIG_EXTCON */ 339#endif /* CONFIG_EXTCON */
328#endif /* __LINUX_EXTCON_H__ */ 340#endif /* __LINUX_EXTCON_H__ */
diff --git a/include/linux/extcon/of_extcon.h b/include/linux/extcon/of_extcon.h
deleted file mode 100644
index 0ebfeff1b55d..000000000000
--- a/include/linux/extcon/of_extcon.h
+++ /dev/null
@@ -1,31 +0,0 @@
1/*
2 * OF helpers for External connector (extcon) framework
3 *
4 * Copyright (C) 2013 Texas Instruments, Inc.
5 * Kishon Vijay Abraham I <kishon@ti.com>
6 *
7 * Copyright (C) 2013 Samsung Electronics
8 * Chanwoo Choi <cw00.choi@samsung.com>
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 */
15
16#ifndef __LINUX_OF_EXTCON_H
17#define __LINUX_OF_EXTCON_H
18
19#include <linux/err.h>
20
21#if IS_ENABLED(CONFIG_OF_EXTCON)
22extern struct extcon_dev
23 *of_extcon_get_extcon_dev(struct device *dev, int index);
24#else
25static inline struct extcon_dev
26 *of_extcon_get_extcon_dev(struct device *dev, int index)
27{
28 return ERR_PTR(-ENOSYS);
29}
30#endif /* CONFIG_OF_EXTCON */
31#endif /* __LINUX_OF_EXTCON_H */