.. | .. |
---|
2267 | 2267 | atomic_set(&port->state, RIO_DEVICE_RUNNING); |
---|
2268 | 2268 | |
---|
2269 | 2269 | res = device_register(&port->dev); |
---|
2270 | | - if (res) |
---|
| 2270 | + if (res) { |
---|
2271 | 2271 | dev_err(&port->dev, "RIO: mport%d registration failed ERR=%d\n", |
---|
2272 | 2272 | port->id, res); |
---|
2273 | | - else |
---|
| 2273 | + mutex_lock(&rio_mport_list_lock); |
---|
| 2274 | + list_del(&port->node); |
---|
| 2275 | + mutex_unlock(&rio_mport_list_lock); |
---|
| 2276 | + put_device(&port->dev); |
---|
| 2277 | + } else { |
---|
2274 | 2278 | dev_dbg(&port->dev, "RIO: registered mport%d\n", port->id); |
---|
| 2279 | + } |
---|
2275 | 2280 | |
---|
2276 | 2281 | return res; |
---|
2277 | 2282 | } |
---|