aboutsummaryrefslogtreecommitdiffstats
path: root/arch/ppc64/kernel/vio.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/ppc64/kernel/vio.c')
-rw-r--r--arch/ppc64/kernel/vio.c24
1 files changed, 8 insertions, 16 deletions
diff --git a/arch/ppc64/kernel/vio.c b/arch/ppc64/kernel/vio.c
index 3eab2290b12..93c437a0911 100644
--- a/arch/ppc64/kernel/vio.c
+++ b/arch/ppc64/kernel/vio.c
@@ -32,10 +32,7 @@ struct vio_dev vio_bus_device = { /* fake "parent" device */
32 .dev.bus = &vio_bus_type, 32 .dev.bus = &vio_bus_type,
33}; 33};
34 34
35static int (*is_match)(const struct vio_device_id *id, 35static struct vio_bus_ops vio_bus_ops;
36 const struct vio_dev *dev);
37static void (*unregister_device_callback)(struct vio_dev *dev);
38static void (*release_device_callback)(struct device *dev);
39 36
40/* 37/*
41 * Convert from struct device to struct vio_dev and pass to driver. 38 * Convert from struct device to struct vio_dev and pass to driver.
@@ -115,7 +112,7 @@ static const struct vio_device_id *vio_match_device(
115 const struct vio_device_id *ids, const struct vio_dev *dev) 112 const struct vio_device_id *ids, const struct vio_dev *dev)
116{ 113{
117 while (ids->type) { 114 while (ids->type) {
118 if (is_match(ids, dev)) 115 if (vio_bus_ops.match(ids, dev))
119 return ids; 116 return ids;
120 ids++; 117 ids++;
121 } 118 }
@@ -125,16 +122,11 @@ static const struct vio_device_id *vio_match_device(
125/** 122/**
126 * vio_bus_init: - Initialize the virtual IO bus 123 * vio_bus_init: - Initialize the virtual IO bus
127 */ 124 */
128int __init vio_bus_init(int (*match_func)(const struct vio_device_id *id, 125int __init vio_bus_init(struct vio_bus_ops *ops)
129 const struct vio_dev *dev),
130 void (*unregister_dev)(struct vio_dev *),
131 void (*release_dev)(struct device *))
132{ 126{
133 int err; 127 int err;
134 128
135 is_match = match_func; 129 vio_bus_ops = *ops;
136 unregister_device_callback = unregister_dev;
137 release_device_callback = release_dev;
138 130
139 err = bus_register(&vio_bus_type); 131 err = bus_register(&vio_bus_type);
140 if (err) { 132 if (err) {
@@ -159,8 +151,8 @@ int __init vio_bus_init(int (*match_func)(const struct vio_device_id *id,
159/* vio_dev refcount hit 0 */ 151/* vio_dev refcount hit 0 */
160static void __devinit vio_dev_release(struct device *dev) 152static void __devinit vio_dev_release(struct device *dev)
161{ 153{
162 if (release_device_callback) 154 if (vio_bus_ops.release_device)
163 release_device_callback(dev); 155 vio_bus_ops.release_device(dev);
164 kfree(to_vio_dev(dev)); 156 kfree(to_vio_dev(dev));
165} 157}
166 158
@@ -191,8 +183,8 @@ struct vio_dev * __devinit vio_register_device(struct vio_dev *viodev)
191 183
192void __devinit vio_unregister_device(struct vio_dev *viodev) 184void __devinit vio_unregister_device(struct vio_dev *viodev)
193{ 185{
194 if (unregister_device_callback) 186 if (vio_bus_ops.unregister_device)
195 unregister_device_callback(viodev); 187 vio_bus_ops.unregister_device(viodev);
196 device_remove_file(&viodev->dev, &dev_attr_name); 188 device_remove_file(&viodev->dev, &dev_attr_name);
197 device_unregister(&viodev->dev); 189 device_unregister(&viodev->dev);
198} 190}