diff options
author | Stephen Rothwell <sfr@canb.auug.org.au> | 2007-05-01 02:40:36 -0400 |
---|---|---|
committer | Stephen Rothwell <sfr@canb.auug.org.au> | 2007-07-19 23:39:59 -0400 |
commit | f85ff3056cefdf4635ebf98b30e9a7d86521567f (patch) | |
tree | f08bc591d6219b287261452a3f5dde58d6b5dd79 /arch/sparc/kernel/of_device.c | |
parent | 1ef4d4242d9c494c49ae1ae66dc938fce0272816 (diff) |
Begin to consolidate of_device.c
This moves all the common parts for the Sparc, Sparc64 and PowerPC
of_device.c files into drivers/of/device.c.
Apart from the simple move, Sparc gains of_match_node() and a call to
of_node_put in of_release_dev(). PowerPC gains better recovery if
device_create_file() fails in of_device_register().
Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au>
Acked-by: Paul Mackerras <paulus@samba.org>
Acked-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc/kernel/of_device.c')
-rw-r--r-- | arch/sparc/kernel/of_device.c | 109 |
1 files changed, 1 insertions, 108 deletions
diff --git a/arch/sparc/kernel/of_device.c b/arch/sparc/kernel/of_device.c index fd7f8cb668a3..0760b8157847 100644 --- a/arch/sparc/kernel/of_device.c +++ b/arch/sparc/kernel/of_device.c | |||
@@ -1,5 +1,6 @@ | |||
1 | #include <linux/string.h> | 1 | #include <linux/string.h> |
2 | #include <linux/kernel.h> | 2 | #include <linux/kernel.h> |
3 | #include <linux/of.h> | ||
3 | #include <linux/init.h> | 4 | #include <linux/init.h> |
4 | #include <linux/module.h> | 5 | #include <linux/module.h> |
5 | #include <linux/mod_devicetable.h> | 6 | #include <linux/mod_devicetable.h> |
@@ -8,38 +9,6 @@ | |||
8 | #include <asm/errno.h> | 9 | #include <asm/errno.h> |
9 | #include <asm/of_device.h> | 10 | #include <asm/of_device.h> |
10 | 11 | ||
11 | /** | ||
12 | * of_match_device - Tell if an of_device structure has a matching | ||
13 | * of_match structure | ||
14 | * @ids: array of of device match structures to search in | ||
15 | * @dev: the of device structure to match against | ||
16 | * | ||
17 | * Used by a driver to check whether an of_device present in the | ||
18 | * system is in its list of supported devices. | ||
19 | */ | ||
20 | const struct of_device_id *of_match_device(const struct of_device_id *matches, | ||
21 | const struct of_device *dev) | ||
22 | { | ||
23 | if (!dev->node) | ||
24 | return NULL; | ||
25 | while (matches->name[0] || matches->type[0] || matches->compatible[0]) { | ||
26 | int match = 1; | ||
27 | if (matches->name[0]) | ||
28 | match &= dev->node->name | ||
29 | && !strcmp(matches->name, dev->node->name); | ||
30 | if (matches->type[0]) | ||
31 | match &= dev->node->type | ||
32 | && !strcmp(matches->type, dev->node->type); | ||
33 | if (matches->compatible[0]) | ||
34 | match &= of_device_is_compatible(dev->node, | ||
35 | matches->compatible); | ||
36 | if (match) | ||
37 | return matches; | ||
38 | matches++; | ||
39 | } | ||
40 | return NULL; | ||
41 | } | ||
42 | |||
43 | static int of_platform_bus_match(struct device *dev, struct device_driver *drv) | 12 | static int of_platform_bus_match(struct device *dev, struct device_driver *drv) |
44 | { | 13 | { |
45 | struct of_device * of_dev = to_of_device(dev); | 14 | struct of_device * of_dev = to_of_device(dev); |
@@ -52,26 +21,6 @@ static int of_platform_bus_match(struct device *dev, struct device_driver *drv) | |||
52 | return of_match_device(matches, of_dev) != NULL; | 21 | return of_match_device(matches, of_dev) != NULL; |
53 | } | 22 | } |
54 | 23 | ||
55 | struct of_device *of_dev_get(struct of_device *dev) | ||
56 | { | ||
57 | struct device *tmp; | ||
58 | |||
59 | if (!dev) | ||
60 | return NULL; | ||
61 | tmp = get_device(&dev->dev); | ||
62 | if (tmp) | ||
63 | return to_of_device(tmp); | ||
64 | else | ||
65 | return NULL; | ||
66 | } | ||
67 | |||
68 | void of_dev_put(struct of_device *dev) | ||
69 | { | ||
70 | if (dev) | ||
71 | put_device(&dev->dev); | ||
72 | } | ||
73 | |||
74 | |||
75 | static int of_device_probe(struct device *dev) | 24 | static int of_device_probe(struct device *dev) |
76 | { | 25 | { |
77 | int error = -ENODEV; | 26 | int error = -ENODEV; |
@@ -735,56 +684,6 @@ void of_unregister_driver(struct of_platform_driver *drv) | |||
735 | driver_unregister(&drv->driver); | 684 | driver_unregister(&drv->driver); |
736 | } | 685 | } |
737 | 686 | ||
738 | |||
739 | static ssize_t dev_show_devspec(struct device *dev, struct device_attribute *attr, char *buf) | ||
740 | { | ||
741 | struct of_device *ofdev; | ||
742 | |||
743 | ofdev = to_of_device(dev); | ||
744 | return sprintf(buf, "%s", ofdev->node->full_name); | ||
745 | } | ||
746 | |||
747 | static DEVICE_ATTR(devspec, S_IRUGO, dev_show_devspec, NULL); | ||
748 | |||
749 | /** | ||
750 | * of_release_dev - free an of device structure when all users of it are finished. | ||
751 | * @dev: device that's been disconnected | ||
752 | * | ||
753 | * Will be called only by the device core when all users of this of device are | ||
754 | * done. | ||
755 | */ | ||
756 | void of_release_dev(struct device *dev) | ||
757 | { | ||
758 | struct of_device *ofdev; | ||
759 | |||
760 | ofdev = to_of_device(dev); | ||
761 | |||
762 | kfree(ofdev); | ||
763 | } | ||
764 | |||
765 | int of_device_register(struct of_device *ofdev) | ||
766 | { | ||
767 | int rc; | ||
768 | |||
769 | BUG_ON(ofdev->node == NULL); | ||
770 | |||
771 | rc = device_register(&ofdev->dev); | ||
772 | if (rc) | ||
773 | return rc; | ||
774 | |||
775 | rc = device_create_file(&ofdev->dev, &dev_attr_devspec); | ||
776 | if (rc) | ||
777 | device_unregister(&ofdev->dev); | ||
778 | |||
779 | return rc; | ||
780 | } | ||
781 | |||
782 | void of_device_unregister(struct of_device *ofdev) | ||
783 | { | ||
784 | device_remove_file(&ofdev->dev, &dev_attr_devspec); | ||
785 | device_unregister(&ofdev->dev); | ||
786 | } | ||
787 | |||
788 | struct of_device* of_platform_device_create(struct device_node *np, | 687 | struct of_device* of_platform_device_create(struct device_node *np, |
789 | const char *bus_id, | 688 | const char *bus_id, |
790 | struct device *parent, | 689 | struct device *parent, |
@@ -810,12 +709,6 @@ struct of_device* of_platform_device_create(struct device_node *np, | |||
810 | return dev; | 709 | return dev; |
811 | } | 710 | } |
812 | 711 | ||
813 | EXPORT_SYMBOL(of_match_device); | ||
814 | EXPORT_SYMBOL(of_register_driver); | 712 | EXPORT_SYMBOL(of_register_driver); |
815 | EXPORT_SYMBOL(of_unregister_driver); | 713 | EXPORT_SYMBOL(of_unregister_driver); |
816 | EXPORT_SYMBOL(of_device_register); | ||
817 | EXPORT_SYMBOL(of_device_unregister); | ||
818 | EXPORT_SYMBOL(of_dev_get); | ||
819 | EXPORT_SYMBOL(of_dev_put); | ||
820 | EXPORT_SYMBOL(of_platform_device_create); | 714 | EXPORT_SYMBOL(of_platform_device_create); |
821 | EXPORT_SYMBOL(of_release_dev); | ||