Hans Rosenfeld
f994d99cf1
x86-32, fpu: Fix FPU exception handling on non-SSE systems
...
On 32bit systems without SSE (that is, they use FSAVE/FRSTOR for FPU
context switches), FPU exceptions in user mode cause Oopses, BUGs,
recursive faults and other nasty things:
fpu exception: 0000 [#1 ]
last sysfs file: /sys/power/state
Modules linked in: psmouse evdev pcspkr serio_raw [last unloaded: scsi_wait_scan]
Pid: 1638, comm: fxsave-32-excep Not tainted 2.6.35-07798-g58a992b-dirty #633 VP3-596B-DD/VT82C597
EIP: 0060:[<c1003527>] EFLAGS: 00010202 CPU: 0
EIP is at math_error+0x1b4/0x1c8
EAX: 00000003 EBX: cf9be7e0 ECX: 00000000 EDX: cf9c5c00
ESI: cf9d9fb4 EDI: c1372db3 EBP: 00000010 ESP: cf9d9f1c
DS: 007b ES: 007b FS: 0000 GS: 00e0 SS: 0068
Process fxsave-32-excep (pid: 1638, ti=cf9d8000 task=cf9be7e0 task.ti=cf9d8000)
Stack:
00000000 00000301 00000004 00000000 00000000 cf9d3000 cf9da8f0 00000001
<0> 00000004 cf9b6b60 c1019a6b c1019a79 00000020 00000242 000001b6 cf9c5380
<0> cf806b40 cf791880 00000000 00000282 00000282 c108a213 00000020 cf9c5380
Call Trace:
[<c1019a6b>] ? need_resched+0x11/0x1a
[<c1019a79>] ? should_resched+0x5/0x1f
[<c108a213>] ? do_sys_open+0xbd/0xc7
[<c108a213>] ? do_sys_open+0xbd/0xc7
[<c100353b>] ? do_coprocessor_error+0x0/0x11
[<c12d5965>] ? error_code+0x65/0x70
Code: a8 20 74 30 c7 44 24 0c 06 00 03 00 8d 54 24 04 89 d9 b8 08 00 00 00 e8 9b 6d 02 00 eb 16 8b 93 5c 02 00 00 eb 05 e9 04 ff ff ff <9b> dd 32 9b e9 16 ff ff ff 81 c4 84 00 00 00 5b 5e 5f 5d c3 c6
EIP: [<c1003527>] math_error+0x1b4/0x1c8 SS:ESP 0068:cf9d9f1c
This usually continues in slight variations until the system is reset.
This bug was introduced by commit 58a992b9cbaf449aeebd3575c3695a9eb5d95b5e:
x86-32, fpu: Rewrite fpu_save_init()
Signed-off-by: Hans Rosenfeld <hans.rosenfeld@amd.com>
Link: http://lkml.kernel.org/r/1302106003-366952-1-git-send-email-hans.rosenfeld@amd.com
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
2011-04-06 16:53:01 -07:00
..
2011-03-09 16:36:16 +01:00
2010-02-19 16:12:29 -08:00
2011-03-18 10:39:30 +01:00
2009-11-10 11:23:05 +01:00
2011-03-23 02:34:54 -04:00
2009-02-18 16:48:05 +08:00
2009-08-03 09:05:00 +01:00
2010-04-28 17:15:47 -07:00
2011-01-06 11:11:50 -08:00
2010-10-13 11:13:21 +02:00
2010-10-13 11:13:21 +02:00
2010-10-21 14:23:48 -07:00
2011-03-18 10:39:00 +01:00
2010-08-12 14:01:38 -07:00
2011-03-29 09:37:42 +02:00
2011-02-23 11:38:44 +01:00
2009-01-29 14:16:51 +01:00
2010-05-17 15:17:16 -07:00
2009-12-12 13:08:14 +01:00
2009-08-31 15:14:30 -07:00
2010-02-25 20:47:30 -08:00
2010-05-18 08:40:05 -07:00
2010-05-18 08:40:05 -07:00
2011-03-23 19:46:22 -07:00
2009-06-11 21:02:14 +02:00
2011-01-13 08:03:25 -08:00
2011-02-23 22:27:52 +01:00
2009-12-05 09:10:12 -08:00
2009-01-14 19:56:50 -08:00
2010-03-03 11:26:00 +01:00
2011-03-18 10:39:30 +01:00
2010-08-26 15:13:13 -07:00
2010-10-19 14:28:02 -07:00
2011-03-14 15:13:23 +01:00
2009-10-01 16:11:12 -07:00
2010-07-28 17:05:11 -07:00
2010-07-28 15:24:09 -07:00
2010-09-14 16:08:45 -07:00
2011-02-14 12:08:28 +01:00
2011-02-16 13:30:53 +01:00
2009-03-13 14:49:54 +10:30
2009-08-04 01:28:52 +09:00
2010-12-30 12:20:28 +01:00
2009-12-04 15:39:55 +01:00
2009-11-05 13:22:18 -08:00
2009-11-27 14:20:32 +01:00
2010-08-11 08:59:21 -07:00
2011-03-29 09:37:42 +02:00
2009-03-23 17:20:50 +01:00
2010-09-03 08:14:11 +02:00
2011-02-23 22:27:52 +01:00
2010-08-27 11:13:47 -07:00
2010-02-16 08:51:49 -08:00
2011-02-14 13:03:08 +01:00
2010-02-16 21:22:26 -08:00
2011-01-11 12:46:16 +01:00
2011-02-28 18:06:22 +01:00
2009-08-26 21:30:39 +02:00
2011-03-11 12:23:31 +01:00
2010-10-21 14:23:48 -07:00
2009-02-17 17:52:43 +01:00
2009-12-15 08:53:28 -08:00
2011-01-11 12:46:15 +01:00
2010-10-18 19:58:50 +02:00
2010-10-26 16:52:08 -07:00
2010-10-12 16:53:37 +02:00
2010-09-17 03:24:13 +02:00
2011-02-14 13:03:08 +01:00
2010-05-07 17:13:04 -07:00
2011-01-07 10:03:50 -05:00
2011-04-06 16:53:01 -07:00
2010-03-02 10:28:38 +01:00
2010-10-12 16:53:36 +02:00
2009-03-27 14:43:57 -04:00
2009-08-27 00:35:56 +02:00
2009-10-29 08:47:46 +01:00
2011-02-24 14:52:18 +01:00
2010-03-10 13:23:34 +01:00
2010-03-24 21:37:57 +08:00
2010-08-03 09:50:30 -04:00
2011-02-23 19:58:09 +01:00
2010-10-28 17:11:17 -07:00
2009-06-18 14:40:03 -07:00
2010-10-26 16:52:08 -07:00
2010-10-08 13:11:21 -07:00
2009-11-15 09:03:10 +01:00
2009-06-18 14:40:03 -07:00
2011-01-28 14:54:05 +01:00
2011-02-23 22:27:53 +01:00
2009-01-21 17:26:06 +09:00
2010-10-12 16:53:42 +02:00
2011-03-03 12:47:08 +01:00
2011-02-23 22:27:52 +01:00
2010-10-07 14:08:55 +01:00
2011-01-23 16:12:45 +01:00
2010-08-14 22:26:51 +02:00
2011-03-18 10:51:42 +01:00
2009-03-10 18:13:25 -07:00
2010-08-05 09:22:20 -05:00
2009-06-16 19:47:51 -07:00
2009-06-13 15:37:30 +02:00
2010-03-10 13:23:34 +01:00
2011-03-17 13:08:33 -03:00
2011-03-17 13:08:35 -03:00
2011-01-12 11:23:27 +02:00
2010-08-01 10:46:37 +03:00
2010-04-14 21:43:56 +09:30
2009-08-25 15:40:29 -07:00
2009-03-11 12:39:28 +01:00
2010-06-09 11:12:36 +02:00
2010-01-05 15:34:49 +09:00
2009-01-29 14:16:51 +01:00
2011-01-07 15:08:51 +01:00
2009-02-10 00:39:14 +01:00
2011-01-03 08:30:30 -08:00
2010-10-05 21:44:35 -07:00
2010-11-10 14:54:54 +01:00
2009-06-18 14:40:03 -07:00
2011-02-03 13:32:39 -08:00
2011-03-23 16:36:52 -04:00
2009-12-04 15:39:55 +01:00
2010-02-15 14:34:10 -08:00
2010-06-29 12:12:59 +02:00
2011-01-05 14:09:23 +01:00
2011-01-28 14:54:09 +01:00
2010-11-11 11:34:27 +01:00
2010-11-11 11:34:27 +01:00
2009-06-18 14:40:03 -07:00
2010-05-07 17:13:04 -07:00
2009-03-17 15:38:59 -07:00
2011-03-17 13:08:27 -03:00
2010-07-20 15:38:18 -07:00
2009-08-21 17:00:02 -07:00
2010-09-17 15:36:40 -07:00
2011-03-18 10:39:30 +01:00
2011-03-18 10:39:30 +01:00
2011-01-31 18:22:25 +01:00
2011-02-16 17:11:10 +01:00
2011-02-16 17:11:07 +01:00
2010-03-07 15:59:39 -08:00
2011-02-23 11:54:02 +01:00
2011-03-18 10:39:30 +01:00
2010-06-29 12:12:59 +02:00
2009-02-13 13:36:47 +01:00
2009-06-20 15:40:00 -07:00
2009-02-11 14:54:09 -08:00
2011-03-04 10:26:36 +01:00
2010-08-11 08:43:49 +02:00
2009-06-18 14:40:03 -07:00
2011-01-13 17:32:39 -08:00
2011-01-26 10:49:57 +10:00
2009-11-23 17:09:59 -08:00
2010-02-10 17:47:18 -08:00
2010-10-18 10:49:30 -04:00
2009-01-29 14:16:51 +01:00
2010-11-18 12:52:04 +01:00
2011-03-27 19:25:36 -07:00
2011-03-18 10:39:30 +01:00
2010-11-26 15:14:56 +01:00
2010-11-01 15:38:34 -04:00
2010-06-07 17:27:11 -07:00
2010-10-26 16:52:08 -07:00
2009-05-05 19:10:18 -07:00
2011-01-13 17:32:44 -08:00
2011-01-13 17:32:44 -08:00
2009-02-13 11:35:01 -08:00
2011-01-13 17:32:44 -08:00
2009-02-13 11:35:01 -08:00
2011-03-18 11:44:01 +01:00
2011-01-13 17:32:45 -08:00
2009-02-02 23:27:09 +05:30
2011-03-18 10:39:30 +01:00
2011-01-26 08:44:49 +01:00
2011-02-25 16:18:52 +01:00
2010-02-12 09:42:39 -08:00
2011-03-18 10:39:30 +01:00
2011-03-18 10:39:30 +01:00
2010-05-19 11:41:05 +03:00
2010-11-28 09:33:20 +01:00
2011-02-17 21:05:34 -08:00
2010-07-07 17:29:18 -07:00
2011-01-27 12:30:39 +01:00
2010-08-07 18:15:50 +02:00
2009-03-02 15:41:30 -08:00
2009-03-02 15:41:30 -08:00
2009-10-20 14:46:00 +09:00
2011-02-17 21:05:13 -08:00
2009-01-29 14:16:51 +01:00
2010-11-12 00:45:41 +01:00
2009-06-18 14:40:03 -07:00
2009-01-31 00:18:58 +05:30
2009-12-04 23:41:47 +01:00
2009-06-11 21:01:52 +02:00
2011-03-15 19:49:10 -07:00
2011-02-28 16:22:18 +01:00
2009-06-18 14:40:03 -07:00
2009-06-18 14:40:03 -07:00
2009-05-05 19:10:18 -07:00
2009-12-14 23:55:32 +01:00
2009-12-14 23:55:32 +01:00
2009-09-03 21:30:51 +02:00
2011-03-18 10:51:42 +01:00
2009-09-28 16:43:15 -07:00
2009-06-15 12:40:02 +02:00
2010-06-08 00:32:49 +02:00
2010-06-08 00:32:49 +02:00
2011-01-12 11:31:07 +02:00
2009-01-31 00:19:32 +05:30
2010-08-26 15:13:29 -07:00
2010-08-13 16:53:13 -07:00
2010-02-17 13:07:21 +01:00
2010-08-17 18:07:43 -07:00
2011-02-20 13:38:47 +01:00
2009-06-18 14:40:03 -07:00
2009-06-18 14:40:03 -07:00
2011-03-22 17:44:01 -07:00
2009-09-16 14:34:50 +02:00
2010-11-18 09:08:23 +01:00
2009-06-16 19:47:27 -07:00
2010-10-20 14:23:55 -07:00
2011-02-16 17:11:09 +01:00
2011-02-17 21:05:06 -08:00
2011-01-12 11:23:16 +02:00
2011-03-18 10:39:30 +01:00
2011-03-23 19:47:18 -07:00
2010-01-05 13:45:06 -08:00
2010-02-28 10:35:09 -08:00
2009-10-12 18:29:46 +02:00
2009-06-18 14:40:03 -07:00
2011-03-21 00:40:29 -04:00
2011-03-21 00:40:29 -04:00
2010-02-11 15:08:17 -08:00
2009-08-21 21:43:46 +02:00
2009-03-24 11:02:46 +02:00
2011-01-12 11:31:08 +02:00
2011-02-14 18:20:43 +01:00
2009-06-15 12:40:02 +02:00
2010-08-06 16:25:13 -07:00