aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/input/gameport/gameport.c27
-rw-r--r--include/linux/gameport.h7
2 files changed, 18 insertions, 16 deletions
diff --git a/drivers/input/gameport/gameport.c b/drivers/input/gameport/gameport.c
index b765a155c008..9444702630c4 100644
--- a/drivers/input/gameport/gameport.c
+++ b/drivers/input/gameport/gameport.c
@@ -22,6 +22,7 @@
22#include <linux/delay.h> 22#include <linux/delay.h>
23#include <linux/kthread.h> 23#include <linux/kthread.h>
24#include <linux/sched.h> /* HZ */ 24#include <linux/sched.h> /* HZ */
25#include <linux/mutex.h>
25 26
26/*#include <asm/io.h>*/ 27/*#include <asm/io.h>*/
27 28
@@ -43,10 +44,10 @@ EXPORT_SYMBOL(gameport_start_polling);
43EXPORT_SYMBOL(gameport_stop_polling); 44EXPORT_SYMBOL(gameport_stop_polling);
44 45
45/* 46/*
46 * gameport_sem protects entire gameport subsystem and is taken 47 * gameport_mutex protects entire gameport subsystem and is taken
47 * every time gameport port or driver registrered or unregistered. 48 * every time gameport port or driver registrered or unregistered.
48 */ 49 */
49static DECLARE_MUTEX(gameport_sem); 50static DEFINE_MUTEX(gameport_mutex);
50 51
51static LIST_HEAD(gameport_list); 52static LIST_HEAD(gameport_list);
52 53
@@ -342,7 +343,7 @@ static void gameport_handle_event(void)
342 struct gameport_event *event; 343 struct gameport_event *event;
343 struct gameport_driver *gameport_drv; 344 struct gameport_driver *gameport_drv;
344 345
345 down(&gameport_sem); 346 mutex_lock(&gameport_mutex);
346 347
347 /* 348 /*
348 * Note that we handle only one event here to give swsusp 349 * Note that we handle only one event here to give swsusp
@@ -379,7 +380,7 @@ static void gameport_handle_event(void)
379 gameport_free_event(event); 380 gameport_free_event(event);
380 } 381 }
381 382
382 up(&gameport_sem); 383 mutex_unlock(&gameport_mutex);
383} 384}
384 385
385/* 386/*
@@ -464,7 +465,7 @@ static ssize_t gameport_rebind_driver(struct device *dev, struct device_attribut
464 struct device_driver *drv; 465 struct device_driver *drv;
465 int retval; 466 int retval;
466 467
467 retval = down_interruptible(&gameport_sem); 468 retval = mutex_lock_interruptible(&gameport_mutex);
468 if (retval) 469 if (retval)
469 return retval; 470 return retval;
470 471
@@ -484,7 +485,7 @@ static ssize_t gameport_rebind_driver(struct device *dev, struct device_attribut
484 retval = -EINVAL; 485 retval = -EINVAL;
485 } 486 }
486 487
487 up(&gameport_sem); 488 mutex_unlock(&gameport_mutex);
488 489
489 return retval; 490 return retval;
490} 491}
@@ -521,7 +522,7 @@ static void gameport_init_port(struct gameport *gameport)
521 522
522 __module_get(THIS_MODULE); 523 __module_get(THIS_MODULE);
523 524
524 init_MUTEX(&gameport->drv_sem); 525 mutex_init(&gameport->drv_mutex);
525 device_initialize(&gameport->dev); 526 device_initialize(&gameport->dev);
526 snprintf(gameport->dev.bus_id, sizeof(gameport->dev.bus_id), 527 snprintf(gameport->dev.bus_id, sizeof(gameport->dev.bus_id),
527 "gameport%lu", (unsigned long)atomic_inc_return(&gameport_no) - 1); 528 "gameport%lu", (unsigned long)atomic_inc_return(&gameport_no) - 1);
@@ -661,10 +662,10 @@ void __gameport_register_port(struct gameport *gameport, struct module *owner)
661 */ 662 */
662void gameport_unregister_port(struct gameport *gameport) 663void gameport_unregister_port(struct gameport *gameport)
663{ 664{
664 down(&gameport_sem); 665 mutex_lock(&gameport_mutex);
665 gameport_disconnect_port(gameport); 666 gameport_disconnect_port(gameport);
666 gameport_destroy_port(gameport); 667 gameport_destroy_port(gameport);
667 up(&gameport_sem); 668 mutex_unlock(&gameport_mutex);
668} 669}
669 670
670 671
@@ -717,7 +718,7 @@ void gameport_unregister_driver(struct gameport_driver *drv)
717{ 718{
718 struct gameport *gameport; 719 struct gameport *gameport;
719 720
720 down(&gameport_sem); 721 mutex_lock(&gameport_mutex);
721 drv->ignore = 1; /* so gameport_find_driver ignores it */ 722 drv->ignore = 1; /* so gameport_find_driver ignores it */
722 723
723start_over: 724start_over:
@@ -731,7 +732,7 @@ start_over:
731 } 732 }
732 733
733 driver_unregister(&drv->driver); 734 driver_unregister(&drv->driver);
734 up(&gameport_sem); 735 mutex_unlock(&gameport_mutex);
735} 736}
736 737
737static int gameport_bus_match(struct device *dev, struct device_driver *drv) 738static int gameport_bus_match(struct device *dev, struct device_driver *drv)
@@ -743,9 +744,9 @@ static int gameport_bus_match(struct device *dev, struct device_driver *drv)
743 744
744static void gameport_set_drv(struct gameport *gameport, struct gameport_driver *drv) 745static void gameport_set_drv(struct gameport *gameport, struct gameport_driver *drv)
745{ 746{
746 down(&gameport->drv_sem); 747 mutex_lock(&gameport->drv_mutex);
747 gameport->drv = drv; 748 gameport->drv = drv;
748 up(&gameport->drv_sem); 749 mutex_unlock(&gameport->drv_mutex);
749} 750}
750 751
751int gameport_open(struct gameport *gameport, struct gameport_driver *drv, int mode) 752int gameport_open(struct gameport *gameport, struct gameport_driver *drv, int mode)
diff --git a/include/linux/gameport.h b/include/linux/gameport.h
index 2401dea2b867..3e1b9b285258 100644
--- a/include/linux/gameport.h
+++ b/include/linux/gameport.h
@@ -11,6 +11,7 @@
11 11
12#include <asm/io.h> 12#include <asm/io.h>
13#include <linux/list.h> 13#include <linux/list.h>
14#include <linux/mutex.h>
14#include <linux/device.h> 15#include <linux/device.h>
15#include <linux/timer.h> 16#include <linux/timer.h>
16 17
@@ -40,7 +41,7 @@ struct gameport {
40 struct gameport *parent, *child; 41 struct gameport *parent, *child;
41 42
42 struct gameport_driver *drv; 43 struct gameport_driver *drv;
43 struct semaphore drv_sem; /* protects serio->drv so attributes can pin driver */ 44 struct mutex drv_mutex; /* protects serio->drv so attributes can pin driver */
44 45
45 struct device dev; 46 struct device dev;
46 unsigned int registered; /* port has been fully registered with driver core */ 47 unsigned int registered; /* port has been fully registered with driver core */
@@ -137,12 +138,12 @@ static inline void gameport_set_drvdata(struct gameport *gameport, void *data)
137 */ 138 */
138static inline int gameport_pin_driver(struct gameport *gameport) 139static inline int gameport_pin_driver(struct gameport *gameport)
139{ 140{
140 return down_interruptible(&gameport->drv_sem); 141 return mutex_lock_interruptible(&gameport->drv_mutex);
141} 142}
142 143
143static inline void gameport_unpin_driver(struct gameport *gameport) 144static inline void gameport_unpin_driver(struct gameport *gameport)
144{ 145{
145 up(&gameport->drv_sem); 146 mutex_unlock(&gameport->drv_mutex);
146} 147}
147 148
148void __gameport_register_driver(struct gameport_driver *drv, struct module *owner); 149void __gameport_register_driver(struct gameport_driver *drv, struct module *owner);