diff options
Diffstat (limited to 'drivers/message/i2o/driver.c')
-rw-r--r-- | drivers/message/i2o/driver.c | 46 |
1 files changed, 24 insertions, 22 deletions
diff --git a/drivers/message/i2o/driver.c b/drivers/message/i2o/driver.c index c71e68f70e7d..bebdd509b5d8 100644 --- a/drivers/message/i2o/driver.c +++ b/drivers/message/i2o/driver.c | |||
@@ -18,7 +18,7 @@ | |||
18 | #include <linux/rwsem.h> | 18 | #include <linux/rwsem.h> |
19 | #include <linux/i2o.h> | 19 | #include <linux/i2o.h> |
20 | 20 | ||
21 | #define OSM_NAME "core" | 21 | #define OSM_NAME "i2o" |
22 | 22 | ||
23 | /* max_drivers - Maximum I2O drivers (OSMs) which could be registered */ | 23 | /* max_drivers - Maximum I2O drivers (OSMs) which could be registered */ |
24 | unsigned int i2o_max_drivers = I2O_MAX_DRIVERS; | 24 | unsigned int i2o_max_drivers = I2O_MAX_DRIVERS; |
@@ -78,17 +78,16 @@ int i2o_driver_register(struct i2o_driver *drv) | |||
78 | int rc = 0; | 78 | int rc = 0; |
79 | unsigned long flags; | 79 | unsigned long flags; |
80 | 80 | ||
81 | pr_debug("i2o: Register driver %s\n", drv->name); | 81 | osm_debug("Register driver %s\n", drv->name); |
82 | 82 | ||
83 | if (drv->event) { | 83 | if (drv->event) { |
84 | drv->event_queue = create_workqueue(drv->name); | 84 | drv->event_queue = create_workqueue(drv->name); |
85 | if (!drv->event_queue) { | 85 | if (!drv->event_queue) { |
86 | printk(KERN_ERR "i2o: Could not initialize event queue " | 86 | osm_err("Could not initialize event queue for driver " |
87 | "for driver %s\n", drv->name); | 87 | "%s\n", drv->name); |
88 | return -EFAULT; | 88 | return -EFAULT; |
89 | } | 89 | } |
90 | pr_debug("i2o: Event queue initialized for driver %s\n", | 90 | osm_debug("Event queue initialized for driver %s\n", drv->name); |
91 | drv->name); | ||
92 | } else | 91 | } else |
93 | drv->event_queue = NULL; | 92 | drv->event_queue = NULL; |
94 | 93 | ||
@@ -99,8 +98,8 @@ int i2o_driver_register(struct i2o_driver *drv) | |||
99 | 98 | ||
100 | for (i = 0; i2o_drivers[i]; i++) | 99 | for (i = 0; i2o_drivers[i]; i++) |
101 | if (i >= i2o_max_drivers) { | 100 | if (i >= i2o_max_drivers) { |
102 | printk(KERN_ERR "i2o: too many drivers registered, " | 101 | osm_err("too many drivers registered, increase " |
103 | "increase max_drivers\n"); | 102 | "max_drivers\n"); |
104 | spin_unlock_irqrestore(&i2o_drivers_lock, flags); | 103 | spin_unlock_irqrestore(&i2o_drivers_lock, flags); |
105 | return -EFAULT; | 104 | return -EFAULT; |
106 | } | 105 | } |
@@ -110,8 +109,7 @@ int i2o_driver_register(struct i2o_driver *drv) | |||
110 | 109 | ||
111 | spin_unlock_irqrestore(&i2o_drivers_lock, flags); | 110 | spin_unlock_irqrestore(&i2o_drivers_lock, flags); |
112 | 111 | ||
113 | pr_debug("i2o: driver %s gets context id %d\n", drv->name, | 112 | osm_debug("driver %s gets context id %d\n", drv->name, drv->context); |
114 | drv->context); | ||
115 | 113 | ||
116 | list_for_each_entry(c, &i2o_controllers, list) { | 114 | list_for_each_entry(c, &i2o_controllers, list) { |
117 | struct i2o_device *i2o_dev; | 115 | struct i2o_device *i2o_dev; |
@@ -141,7 +139,7 @@ void i2o_driver_unregister(struct i2o_driver *drv) | |||
141 | struct i2o_controller *c; | 139 | struct i2o_controller *c; |
142 | unsigned long flags; | 140 | unsigned long flags; |
143 | 141 | ||
144 | pr_debug("i2o: unregister driver %s\n", drv->name); | 142 | osm_debug("unregister driver %s\n", drv->name); |
145 | 143 | ||
146 | driver_unregister(&drv->driver); | 144 | driver_unregister(&drv->driver); |
147 | 145 | ||
@@ -161,7 +159,7 @@ void i2o_driver_unregister(struct i2o_driver *drv) | |||
161 | if (drv->event_queue) { | 159 | if (drv->event_queue) { |
162 | destroy_workqueue(drv->event_queue); | 160 | destroy_workqueue(drv->event_queue); |
163 | drv->event_queue = NULL; | 161 | drv->event_queue = NULL; |
164 | pr_debug("i2o: event queue removed for %s\n", drv->name); | 162 | osm_debug("event queue removed for %s\n", drv->name); |
165 | } | 163 | } |
166 | }; | 164 | }; |
167 | 165 | ||
@@ -178,15 +176,15 @@ void i2o_driver_unregister(struct i2o_driver *drv) | |||
178 | * on success and if the message should be flushed afterwords. Returns | 176 | * on success and if the message should be flushed afterwords. Returns |
179 | * negative error code on failure (the message will be flushed too). | 177 | * negative error code on failure (the message will be flushed too). |
180 | */ | 178 | */ |
181 | int i2o_driver_dispatch(struct i2o_controller *c, u32 m, | 179 | int i2o_driver_dispatch(struct i2o_controller *c, u32 m) |
182 | struct i2o_message __iomem *msg) | ||
183 | { | 180 | { |
184 | struct i2o_driver *drv; | 181 | struct i2o_driver *drv; |
182 | struct i2o_message __iomem *msg = i2o_msg_out_to_virt(c, m); | ||
185 | u32 context = readl(&msg->u.s.icntxt); | 183 | u32 context = readl(&msg->u.s.icntxt); |
186 | 184 | ||
187 | if (unlikely(context >= i2o_max_drivers)) { | 185 | if (unlikely(context >= i2o_max_drivers)) { |
188 | printk(KERN_WARNING "%s: Spurious reply to unknown driver " | 186 | osm_warn("%s: Spurious reply to unknown driver %d\n", c->name, |
189 | "%d\n", c->name, readl(&msg->u.s.icntxt)); | 187 | context); |
190 | return -EIO; | 188 | return -EIO; |
191 | } | 189 | } |
192 | 190 | ||
@@ -195,7 +193,8 @@ int i2o_driver_dispatch(struct i2o_controller *c, u32 m, | |||
195 | spin_unlock(&i2o_drivers_lock); | 193 | spin_unlock(&i2o_drivers_lock); |
196 | 194 | ||
197 | if (unlikely(!drv)) { | 195 | if (unlikely(!drv)) { |
198 | osm_warn("Spurious reply to unknown driver %d\n", context); | 196 | osm_warn("%s: Spurious reply to unknown driver %d\n", c->name, |
197 | context); | ||
199 | return -EIO; | 198 | return -EIO; |
200 | } | 199 | } |
201 | 200 | ||
@@ -207,6 +206,9 @@ int i2o_driver_dispatch(struct i2o_controller *c, u32 m, | |||
207 | 206 | ||
208 | osm_debug("event received from device %d\n", tid); | 207 | osm_debug("event received from device %d\n", tid); |
209 | 208 | ||
209 | if (!drv->event) | ||
210 | return -EIO; | ||
211 | |||
210 | /* cut of header from message size (in 32-bit words) */ | 212 | /* cut of header from message size (in 32-bit words) */ |
211 | size = (readl(&msg->u.head[0]) >> 16) - 5; | 213 | size = (readl(&msg->u.head[0]) >> 16) - 5; |
212 | 214 | ||
@@ -231,8 +233,8 @@ int i2o_driver_dispatch(struct i2o_controller *c, u32 m, | |||
231 | } | 233 | } |
232 | 234 | ||
233 | if (unlikely(!drv->reply)) { | 235 | if (unlikely(!drv->reply)) { |
234 | pr_debug("%s: Reply to driver %s, but no reply function" | 236 | osm_debug("%s: Reply to driver %s, but no reply function" |
235 | " defined!\n", c->name, drv->name); | 237 | " defined!\n", c->name, drv->name); |
236 | return -EIO; | 238 | return -EIO; |
237 | } | 239 | } |
238 | 240 | ||
@@ -333,11 +335,11 @@ int __init i2o_driver_init(void) | |||
333 | if ((i2o_max_drivers < 2) || (i2o_max_drivers > 64) || | 335 | if ((i2o_max_drivers < 2) || (i2o_max_drivers > 64) || |
334 | ((i2o_max_drivers ^ (i2o_max_drivers - 1)) != | 336 | ((i2o_max_drivers ^ (i2o_max_drivers - 1)) != |
335 | (2 * i2o_max_drivers - 1))) { | 337 | (2 * i2o_max_drivers - 1))) { |
336 | printk(KERN_WARNING "i2o: max_drivers set to %d, but must be " | 338 | osm_warn("max_drivers set to %d, but must be >=2 and <= 64 and " |
337 | ">=2 and <= 64 and a power of 2\n", i2o_max_drivers); | 339 | "a power of 2\n", i2o_max_drivers); |
338 | i2o_max_drivers = I2O_MAX_DRIVERS; | 340 | i2o_max_drivers = I2O_MAX_DRIVERS; |
339 | } | 341 | } |
340 | printk(KERN_INFO "i2o: max drivers = %d\n", i2o_max_drivers); | 342 | osm_info("max drivers = %d\n", i2o_max_drivers); |
341 | 343 | ||
342 | i2o_drivers = | 344 | i2o_drivers = |
343 | kmalloc(i2o_max_drivers * sizeof(*i2o_drivers), GFP_KERNEL); | 345 | kmalloc(i2o_max_drivers * sizeof(*i2o_drivers), GFP_KERNEL); |