aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/input/ff-core.c
diff options
context:
space:
mode:
authorJ. Bruce Fields <bfields@citi.umich.edu>2008-07-03 16:24:06 -0400
committerJ. Bruce Fields <bfields@citi.umich.edu>2008-07-03 16:24:06 -0400
commite86322f611eef95aafaf726fd3965e5b211f1985 (patch)
tree28547e26df4fc6ae671dc8cc6912a53717e4db08 /drivers/input/ff-core.c
parentb001a1b6aa960949a24c2cdc28257dfcc9428d74 (diff)
parent8948896c9e098c6fd31a6a698a598a7cbd7fa40e (diff)
Merge branch 'for-bfields' of git://linux-nfs.org/~tomtucker/xprt-switch-2.6 into for-2.6.27
Diffstat (limited to 'drivers/input/ff-core.c')
-rw-r--r--drivers/input/ff-core.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/drivers/input/ff-core.c b/drivers/input/ff-core.c
index eebc72465fc9..4c01464ec8f3 100644
--- a/drivers/input/ff-core.c
+++ b/drivers/input/ff-core.c
@@ -166,8 +166,10 @@ int input_ff_upload(struct input_dev *dev, struct ff_effect *effect,
166 if (ret) 166 if (ret)
167 goto out; 167 goto out;
168 168
169 spin_lock_irq(&dev->event_lock);
169 ff->effects[id] = *effect; 170 ff->effects[id] = *effect;
170 ff->effect_owners[id] = file; 171 ff->effect_owners[id] = file;
172 spin_unlock_irq(&dev->event_lock);
171 173
172 out: 174 out:
173 mutex_unlock(&ff->mutex); 175 mutex_unlock(&ff->mutex);
@@ -189,16 +191,22 @@ static int erase_effect(struct input_dev *dev, int effect_id,
189 if (error) 191 if (error)
190 return error; 192 return error;
191 193
194 spin_lock_irq(&dev->event_lock);
192 ff->playback(dev, effect_id, 0); 195 ff->playback(dev, effect_id, 0);
196 ff->effect_owners[effect_id] = NULL;
197 spin_unlock_irq(&dev->event_lock);
193 198
194 if (ff->erase) { 199 if (ff->erase) {
195 error = ff->erase(dev, effect_id); 200 error = ff->erase(dev, effect_id);
196 if (error) 201 if (error) {
202 spin_lock_irq(&dev->event_lock);
203 ff->effect_owners[effect_id] = file;
204 spin_unlock_irq(&dev->event_lock);
205
197 return error; 206 return error;
207 }
198 } 208 }
199 209
200 ff->effect_owners[effect_id] = NULL;
201
202 return 0; 210 return 0;
203} 211}
204 212
@@ -263,8 +271,6 @@ int input_ff_event(struct input_dev *dev, unsigned int type,
263 if (type != EV_FF) 271 if (type != EV_FF)
264 return 0; 272 return 0;
265 273
266 mutex_lock(&ff->mutex);
267
268 switch (code) { 274 switch (code) {
269 case FF_GAIN: 275 case FF_GAIN:
270 if (!test_bit(FF_GAIN, dev->ffbit) || value > 0xffff) 276 if (!test_bit(FF_GAIN, dev->ffbit) || value > 0xffff)
@@ -286,7 +292,6 @@ int input_ff_event(struct input_dev *dev, unsigned int type,
286 break; 292 break;
287 } 293 }
288 294
289 mutex_unlock(&ff->mutex);
290 return 0; 295 return 0;
291} 296}
292EXPORT_SYMBOL_GPL(input_ff_event); 297EXPORT_SYMBOL_GPL(input_ff_event);