diff options
author | Henrique de Moraes Holschuh <hmh@hmh.eng.br> | 2007-10-30 15:46:24 -0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2007-11-05 13:07:11 -0500 |
commit | fc589a3ce5f38db6239c147da4f9172a25575ecc (patch) | |
tree | 3732f557e21ef93787a0ebfcad4323ec00165dea | |
parent | b856f5b8c022b75bb0504a8c1ce16a5f1656e08b (diff) |
ACPI: thinkpad-acpi: allow for syscall restart in sysfs handlers
Map an mutex_lock_interruptible() error return into ERESTARTSYS, as the
only possible error from mutex_lock_interruptible is EINTR, and that will
only happen if signal_pending() causes the mutex lock attempt to abort.
This still allows signals to be delivered ASAP, which is much nicer than
just doing mutex_lock, and still shadows userspace from EINTR when
SA_RESTART is active.
Problem reported by Peter Jordan.
Signed-off-by: Henrique de Moraes Holschuh <hmh@hmh.eng.br>
Cc: Jean Delvare <khali@linux-fr.org>
Cc: Peter Jordan <usernetwork@gmx.info>
Cc: Richard Neill <rn214@hermes.cam.ac.uk>
Signed-off-by: Len Brown <len.brown@intel.com>
-rw-r--r-- | drivers/misc/thinkpad_acpi.c | 40 |
1 files changed, 16 insertions, 24 deletions
diff --git a/drivers/misc/thinkpad_acpi.c b/drivers/misc/thinkpad_acpi.c index 251110d0ec80..306daa524c03 100644 --- a/drivers/misc/thinkpad_acpi.c +++ b/drivers/misc/thinkpad_acpi.c | |||
@@ -1342,9 +1342,8 @@ static int hotkey_read(char *p) | |||
1342 | return len; | 1342 | return len; |
1343 | } | 1343 | } |
1344 | 1344 | ||
1345 | res = mutex_lock_interruptible(&hotkey_mutex); | 1345 | if (mutex_lock_interruptible(&hotkey_mutex)) |
1346 | if (res < 0) | 1346 | return -ERESTARTSYS; |
1347 | return res; | ||
1348 | res = hotkey_get(&status, &mask); | 1347 | res = hotkey_get(&status, &mask); |
1349 | mutex_unlock(&hotkey_mutex); | 1348 | mutex_unlock(&hotkey_mutex); |
1350 | if (res) | 1349 | if (res) |
@@ -1373,9 +1372,8 @@ static int hotkey_write(char *buf) | |||
1373 | if (!tp_features.hotkey) | 1372 | if (!tp_features.hotkey) |
1374 | return -ENODEV; | 1373 | return -ENODEV; |
1375 | 1374 | ||
1376 | res = mutex_lock_interruptible(&hotkey_mutex); | 1375 | if (mutex_lock_interruptible(&hotkey_mutex)) |
1377 | if (res < 0) | 1376 | return -ERESTARTSYS; |
1378 | return res; | ||
1379 | 1377 | ||
1380 | res = hotkey_get(&status, &mask); | 1378 | res = hotkey_get(&status, &mask); |
1381 | if (res) | 1379 | if (res) |
@@ -3768,9 +3766,8 @@ static ssize_t fan_pwm1_store(struct device *dev, | |||
3768 | /* scale down from 0-255 to 0-7 */ | 3766 | /* scale down from 0-255 to 0-7 */ |
3769 | newlevel = (s >> 5) & 0x07; | 3767 | newlevel = (s >> 5) & 0x07; |
3770 | 3768 | ||
3771 | rc = mutex_lock_interruptible(&fan_mutex); | 3769 | if (mutex_lock_interruptible(&fan_mutex)) |
3772 | if (rc < 0) | 3770 | return -ERESTARTSYS; |
3773 | return rc; | ||
3774 | 3771 | ||
3775 | rc = fan_get_status(&status); | 3772 | rc = fan_get_status(&status); |
3776 | if (!rc && (status & | 3773 | if (!rc && (status & |
@@ -4020,9 +4017,8 @@ static int fan_get_status_safe(u8 *status) | |||
4020 | int rc; | 4017 | int rc; |
4021 | u8 s; | 4018 | u8 s; |
4022 | 4019 | ||
4023 | rc = mutex_lock_interruptible(&fan_mutex); | 4020 | if (mutex_lock_interruptible(&fan_mutex)) |
4024 | if (rc < 0) | 4021 | return -ERESTARTSYS; |
4025 | return rc; | ||
4026 | rc = fan_get_status(&s); | 4022 | rc = fan_get_status(&s); |
4027 | if (!rc) | 4023 | if (!rc) |
4028 | fan_update_desired_level(s); | 4024 | fan_update_desired_level(s); |
@@ -4156,9 +4152,8 @@ static int fan_set_level_safe(int level) | |||
4156 | if (!fan_control_allowed) | 4152 | if (!fan_control_allowed) |
4157 | return -EPERM; | 4153 | return -EPERM; |
4158 | 4154 | ||
4159 | rc = mutex_lock_interruptible(&fan_mutex); | 4155 | if (mutex_lock_interruptible(&fan_mutex)) |
4160 | if (rc < 0) | 4156 | return -ERESTARTSYS; |
4161 | return rc; | ||
4162 | 4157 | ||
4163 | if (level == TPACPI_FAN_LAST_LEVEL) | 4158 | if (level == TPACPI_FAN_LAST_LEVEL) |
4164 | level = fan_control_desired_level; | 4159 | level = fan_control_desired_level; |
@@ -4179,9 +4174,8 @@ static int fan_set_enable(void) | |||
4179 | if (!fan_control_allowed) | 4174 | if (!fan_control_allowed) |
4180 | return -EPERM; | 4175 | return -EPERM; |
4181 | 4176 | ||
4182 | rc = mutex_lock_interruptible(&fan_mutex); | 4177 | if (mutex_lock_interruptible(&fan_mutex)) |
4183 | if (rc < 0) | 4178 | return -ERESTARTSYS; |
4184 | return rc; | ||
4185 | 4179 | ||
4186 | switch (fan_control_access_mode) { | 4180 | switch (fan_control_access_mode) { |
4187 | case TPACPI_FAN_WR_ACPI_FANS: | 4181 | case TPACPI_FAN_WR_ACPI_FANS: |
@@ -4235,9 +4229,8 @@ static int fan_set_disable(void) | |||
4235 | if (!fan_control_allowed) | 4229 | if (!fan_control_allowed) |
4236 | return -EPERM; | 4230 | return -EPERM; |
4237 | 4231 | ||
4238 | rc = mutex_lock_interruptible(&fan_mutex); | 4232 | if (mutex_lock_interruptible(&fan_mutex)) |
4239 | if (rc < 0) | 4233 | return -ERESTARTSYS; |
4240 | return rc; | ||
4241 | 4234 | ||
4242 | rc = 0; | 4235 | rc = 0; |
4243 | switch (fan_control_access_mode) { | 4236 | switch (fan_control_access_mode) { |
@@ -4274,9 +4267,8 @@ static int fan_set_speed(int speed) | |||
4274 | if (!fan_control_allowed) | 4267 | if (!fan_control_allowed) |
4275 | return -EPERM; | 4268 | return -EPERM; |
4276 | 4269 | ||
4277 | rc = mutex_lock_interruptible(&fan_mutex); | 4270 | if (mutex_lock_interruptible(&fan_mutex)) |
4278 | if (rc < 0) | 4271 | return -ERESTARTSYS; |
4279 | return rc; | ||
4280 | 4272 | ||
4281 | rc = 0; | 4273 | rc = 0; |
4282 | switch (fan_control_access_mode) { | 4274 | switch (fan_control_access_mode) { |