aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/acpi/video.c21
1 files changed, 11 insertions, 10 deletions
diff --git a/drivers/acpi/video.c b/drivers/acpi/video.c
index 36b64a751676..d54c83d70532 100644
--- a/drivers/acpi/video.c
+++ b/drivers/acpi/video.c
@@ -29,6 +29,7 @@
29#include <linux/init.h> 29#include <linux/init.h>
30#include <linux/types.h> 30#include <linux/types.h>
31#include <linux/list.h> 31#include <linux/list.h>
32#include <linux/mutex.h>
32#include <linux/proc_fs.h> 33#include <linux/proc_fs.h>
33#include <linux/seq_file.h> 34#include <linux/seq_file.h>
34#include <linux/input.h> 35#include <linux/input.h>
@@ -135,8 +136,8 @@ struct acpi_video_bus {
135 u8 attached_count; 136 u8 attached_count;
136 struct acpi_video_bus_cap cap; 137 struct acpi_video_bus_cap cap;
137 struct acpi_video_bus_flags flags; 138 struct acpi_video_bus_flags flags;
138 struct semaphore sem;
139 struct list_head video_device_list; 139 struct list_head video_device_list;
140 struct mutex device_list_lock; /* protects video_device_list */
140 struct proc_dir_entry *dir; 141 struct proc_dir_entry *dir;
141 struct input_dev *input; 142 struct input_dev *input;
142 char phys[32]; /* for input device */ 143 char phys[32]; /* for input device */
@@ -1436,9 +1437,9 @@ acpi_video_bus_get_one_device(struct acpi_device *device,
1436 return -ENODEV; 1437 return -ENODEV;
1437 } 1438 }
1438 1439
1439 down(&video->sem); 1440 mutex_lock(&video->device_list_lock);
1440 list_add_tail(&data->entry, &video->video_device_list); 1441 list_add_tail(&data->entry, &video->video_device_list);
1441 up(&video->sem); 1442 mutex_unlock(&video->device_list_lock);
1442 1443
1443 acpi_video_device_add_fs(device); 1444 acpi_video_device_add_fs(device);
1444 1445
@@ -1464,12 +1465,12 @@ static void acpi_video_device_rebind(struct acpi_video_bus *video)
1464{ 1465{
1465 struct acpi_video_device *dev; 1466 struct acpi_video_device *dev;
1466 1467
1467 down(&video->sem); 1468 mutex_lock(&video->device_list_lock);
1468 1469
1469 list_for_each_entry(dev, &video->video_device_list, entry) 1470 list_for_each_entry(dev, &video->video_device_list, entry)
1470 acpi_video_device_bind(video, dev); 1471 acpi_video_device_bind(video, dev);
1471 1472
1472 up(&video->sem); 1473 mutex_unlock(&video->device_list_lock);
1473} 1474}
1474 1475
1475/* 1476/*
@@ -1601,7 +1602,7 @@ static int acpi_video_switch_output(struct acpi_video_bus *video, int event)
1601 unsigned long state; 1602 unsigned long state;
1602 int status = 0; 1603 int status = 0;
1603 1604
1604 down(&video->sem); 1605 mutex_lock(&video->device_list_lock);
1605 1606
1606 list_for_each(node, &video->video_device_list) { 1607 list_for_each(node, &video->video_device_list) {
1607 dev = container_of(node, struct acpi_video_device, entry); 1608 dev = container_of(node, struct acpi_video_device, entry);
@@ -1619,7 +1620,7 @@ static int acpi_video_switch_output(struct acpi_video_bus *video, int event)
1619 dev_prev = container_of(node->prev, struct acpi_video_device, entry); 1620 dev_prev = container_of(node->prev, struct acpi_video_device, entry);
1620 1621
1621 out: 1622 out:
1622 up(&video->sem); 1623 mutex_unlock(&video->device_list_lock);
1623 1624
1624 switch (event) { 1625 switch (event) {
1625 case ACPI_VIDEO_NOTIFY_CYCLE: 1626 case ACPI_VIDEO_NOTIFY_CYCLE:
@@ -1738,7 +1739,7 @@ static int acpi_video_bus_put_devices(struct acpi_video_bus *video)
1738 int status; 1739 int status;
1739 struct acpi_video_device *dev, *next; 1740 struct acpi_video_device *dev, *next;
1740 1741
1741 down(&video->sem); 1742 mutex_lock(&video->device_list_lock);
1742 1743
1743 list_for_each_entry_safe(dev, next, &video->video_device_list, entry) { 1744 list_for_each_entry_safe(dev, next, &video->video_device_list, entry) {
1744 1745
@@ -1755,7 +1756,7 @@ static int acpi_video_bus_put_devices(struct acpi_video_bus *video)
1755 kfree(dev); 1756 kfree(dev);
1756 } 1757 }
1757 1758
1758 up(&video->sem); 1759 mutex_unlock(&video->device_list_lock);
1759 1760
1760 return 0; 1761 return 0;
1761} 1762}
@@ -1924,7 +1925,7 @@ static int acpi_video_bus_add(struct acpi_device *device)
1924 if (error) 1925 if (error)
1925 goto err_free_video; 1926 goto err_free_video;
1926 1927
1927 init_MUTEX(&video->sem); 1928 mutex_init(&video->device_list_lock);
1928 INIT_LIST_HEAD(&video->video_device_list); 1929 INIT_LIST_HEAD(&video->video_device_list);
1929 1930
1930 acpi_video_bus_get_devices(video, device); 1931 acpi_video_bus_get_devices(video, device);