summaryrefslogtreecommitdiffstats
path: root/drivers/firewire
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/firewire')
-rw-r--r--drivers/firewire/core-cdev.c18
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
465static int add_client_resource(struct client *client, 467static int add_client_resource(struct client *client,