diff options
Diffstat (limited to 'arch/m68k/atari/stdma.c')
-rw-r--r-- | arch/m68k/atari/stdma.c | 61 |
1 files changed, 40 insertions, 21 deletions
diff --git a/arch/m68k/atari/stdma.c b/arch/m68k/atari/stdma.c index ddbf43ca8858..e5a66596b116 100644 --- a/arch/m68k/atari/stdma.c +++ b/arch/m68k/atari/stdma.c | |||
@@ -59,6 +59,31 @@ static irqreturn_t stdma_int (int irq, void *dummy); | |||
59 | /************************* End of Prototypes **************************/ | 59 | /************************* End of Prototypes **************************/ |
60 | 60 | ||
61 | 61 | ||
62 | /** | ||
63 | * stdma_try_lock - attempt to acquire ST DMA interrupt "lock" | ||
64 | * @handler: interrupt handler to use after acquisition | ||
65 | * | ||
66 | * Returns !0 if lock was acquired; otherwise 0. | ||
67 | */ | ||
68 | |||
69 | int stdma_try_lock(irq_handler_t handler, void *data) | ||
70 | { | ||
71 | unsigned long flags; | ||
72 | |||
73 | local_irq_save(flags); | ||
74 | if (stdma_locked) { | ||
75 | local_irq_restore(flags); | ||
76 | return 0; | ||
77 | } | ||
78 | |||
79 | stdma_locked = 1; | ||
80 | stdma_isr = handler; | ||
81 | stdma_isr_data = data; | ||
82 | local_irq_restore(flags); | ||
83 | return 1; | ||
84 | } | ||
85 | EXPORT_SYMBOL(stdma_try_lock); | ||
86 | |||
62 | 87 | ||
63 | /* | 88 | /* |
64 | * Function: void stdma_lock( isrfunc isr, void *data ) | 89 | * Function: void stdma_lock( isrfunc isr, void *data ) |
@@ -78,19 +103,10 @@ static irqreturn_t stdma_int (int irq, void *dummy); | |||
78 | 103 | ||
79 | void stdma_lock(irq_handler_t handler, void *data) | 104 | void stdma_lock(irq_handler_t handler, void *data) |
80 | { | 105 | { |
81 | unsigned long flags; | ||
82 | |||
83 | local_irq_save(flags); /* protect lock */ | ||
84 | |||
85 | /* Since the DMA is used for file system purposes, we | 106 | /* Since the DMA is used for file system purposes, we |
86 | have to sleep uninterruptible (there may be locked | 107 | have to sleep uninterruptible (there may be locked |
87 | buffers) */ | 108 | buffers) */ |
88 | wait_event(stdma_wait, !stdma_locked); | 109 | wait_event(stdma_wait, stdma_try_lock(handler, data)); |
89 | |||
90 | stdma_locked = 1; | ||
91 | stdma_isr = handler; | ||
92 | stdma_isr_data = data; | ||
93 | local_irq_restore(flags); | ||
94 | } | 110 | } |
95 | EXPORT_SYMBOL(stdma_lock); | 111 | EXPORT_SYMBOL(stdma_lock); |
96 | 112 | ||
@@ -122,22 +138,25 @@ void stdma_release(void) | |||
122 | EXPORT_SYMBOL(stdma_release); | 138 | EXPORT_SYMBOL(stdma_release); |
123 | 139 | ||
124 | 140 | ||
125 | /* | 141 | /** |
126 | * Function: int stdma_others_waiting( void ) | 142 | * stdma_is_locked_by - allow lock holder to check whether it needs to release. |
127 | * | 143 | * @handler: interrupt handler previously used to acquire lock. |
128 | * Purpose: Check if someone waits for the ST-DMA lock. | ||
129 | * | ||
130 | * Inputs: none | ||
131 | * | ||
132 | * Returns: 0 if no one is waiting, != 0 otherwise | ||
133 | * | 144 | * |
145 | * Returns !0 if locked for the given handler; 0 otherwise. | ||
134 | */ | 146 | */ |
135 | 147 | ||
136 | int stdma_others_waiting(void) | 148 | int stdma_is_locked_by(irq_handler_t handler) |
137 | { | 149 | { |
138 | return waitqueue_active(&stdma_wait); | 150 | unsigned long flags; |
151 | int result; | ||
152 | |||
153 | local_irq_save(flags); | ||
154 | result = stdma_locked && (stdma_isr == handler); | ||
155 | local_irq_restore(flags); | ||
156 | |||
157 | return result; | ||
139 | } | 158 | } |
140 | EXPORT_SYMBOL(stdma_others_waiting); | 159 | EXPORT_SYMBOL(stdma_is_locked_by); |
141 | 160 | ||
142 | 161 | ||
143 | /* | 162 | /* |