diff options
Diffstat (limited to 'drivers/firewire')
-rw-r--r-- | drivers/firewire/core-cdev.c | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/drivers/firewire/core-cdev.c b/drivers/firewire/core-cdev.c index 9b5915ebeb35..e6ad3bb6c1a6 100644 --- a/drivers/firewire/core-cdev.c +++ b/drivers/firewire/core-cdev.c | |||
@@ -253,14 +253,11 @@ static int fw_device_op_open(struct inode *inode, struct file *file) | |||
253 | init_waitqueue_head(&client->wait); | 253 | init_waitqueue_head(&client->wait); |
254 | init_waitqueue_head(&client->tx_flush_wait); | 254 | init_waitqueue_head(&client->tx_flush_wait); |
255 | INIT_LIST_HEAD(&client->phy_receiver_link); | 255 | INIT_LIST_HEAD(&client->phy_receiver_link); |
256 | INIT_LIST_HEAD(&client->link); | ||
256 | kref_init(&client->kref); | 257 | kref_init(&client->kref); |
257 | 258 | ||
258 | file->private_data = client; | 259 | file->private_data = client; |
259 | 260 | ||
260 | mutex_lock(&device->client_list_mutex); | ||
261 | list_add_tail(&client->link, &device->client_list); | ||
262 | mutex_unlock(&device->client_list_mutex); | ||
263 | |||
264 | return nonseekable_open(inode, file); | 261 | return nonseekable_open(inode, file); |
265 | } | 262 | } |
266 | 263 | ||
@@ -451,15 +448,20 @@ static int ioctl_get_info(struct client *client, union ioctl_arg *arg) | |||
451 | if (ret != 0) | 448 | if (ret != 0) |
452 | return -EFAULT; | 449 | return -EFAULT; |
453 | 450 | ||
451 | mutex_lock(&client->device->client_list_mutex); | ||
452 | |||
454 | client->bus_reset_closure = a->bus_reset_closure; | 453 | client->bus_reset_closure = a->bus_reset_closure; |
455 | if (a->bus_reset != 0) { | 454 | if (a->bus_reset != 0) { |
456 | fill_bus_reset_event(&bus_reset, client); | 455 | fill_bus_reset_event(&bus_reset, client); |
457 | if (copy_to_user(u64_to_uptr(a->bus_reset), | 456 | ret = copy_to_user(u64_to_uptr(a->bus_reset), |
458 | &bus_reset, sizeof(bus_reset))) | 457 | &bus_reset, sizeof(bus_reset)); |
459 | return -EFAULT; | ||
460 | } | 458 | } |
459 | if (ret == 0 && list_empty(&client->link)) | ||
460 | list_add_tail(&client->link, &client->device->client_list); | ||
461 | 461 | ||
462 | return 0; | 462 | mutex_unlock(&client->device->client_list_mutex); |
463 | |||
464 | return ret ? -EFAULT : 0; | ||
463 | } | 465 | } |
464 | 466 | ||
465 | static int add_client_resource(struct client *client, | 467 | static int add_client_resource(struct client *client, |