bob picco
4ccb927289
sparc64: sun4v TLB error power off events
...
We've witnessed a few TLB events causing the machine to power off because
of prom_halt. In one case it was some nfs related area during rmmod. Another
was an mmapper of /dev/mem. A more recent one is an ITLB issue with
a bad pagesize which could be a hardware bug. Bugs happen but we should
attempt to not power off the machine and/or hang it when possible.
This is a DTLB error from an mmapper of /dev/mem:
[root@sparcie ~]# SUN4V-DTLB: Error at TPC[fffff80100903e6c], tl 1
SUN4V-DTLB: TPC<0xfffff80100903e6c>
SUN4V-DTLB: O7[fffff801081979d0]
SUN4V-DTLB: O7<0xfffff801081979d0>
SUN4V-DTLB: vaddr[fffff80100000000] ctx[1250] pte[98000000000f0610] error[2]
.
This is recent mainline for ITLB:
[ 3708.179864] SUN4V-ITLB: TPC<0xfffffc010071cefc>
[ 3708.188866] SUN4V-ITLB: O7[fffffc010071cee8]
[ 3708.197377] SUN4V-ITLB: O7<0xfffffc010071cee8>
[ 3708.206539] SUN4V-ITLB: vaddr[e0003] ctx[1a3c] pte[2900000dcc800eeb] error[4]
.
Normally sun4v_itlb_error_report() and sun4v_dtlb_error_report() would call
prom_halt() and drop us to OF command prompt "ok". This isn't the case for
LDOMs and the machine powers off.
For the HV reported error of HV_ENORADDR for HV HV_MMU_MAP_ADDR_TRAP we cause
a SIGBUS error by qualifying it within do_sparc64_fault() for fault code mask
of FAULT_CODE_BAD_RA. This is done when trap level (%tl) is less or equal
one("1"). Otherwise, for %tl > 1, we proceed eventually to die_if_kernel().
The logic of this patch was partially inspired by David Miller's feedback.
Power off of large sparc64 machines is painful. Plus die_if_kernel provides
more context. A reset sequence isn't a brief period on large sparc64 but
better than power-off/power-on sequence.
Cc: sparclinux@vger.kernel.org
Signed-off-by: Bob Picco <bob.picco@oracle.com >
Signed-off-by: David S. Miller <davem@davemloft.net >
2014-09-16 17:46:44 -07:00
..
2009-08-03 09:05:00 +01:00
2008-07-27 23:00:59 +02:00
2009-12-12 13:08:14 +01:00
2008-12-09 00:50:13 -08:00
2012-05-27 23:52:43 -07:00
2014-06-19 07:50:07 -10:00
2014-06-19 07:50:07 -10:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2014-04-29 01:12:26 -04:00
2012-10-28 13:04:47 -07:00
2014-01-12 10:37:15 +01:00
2014-04-18 14:20:44 +02:00
2012-03-28 18:30:03 +01:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-06-19 07:50:07 -10:00
2014-06-19 07:50:07 -10:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-09-02 00:49:38 -07:00
2012-05-19 21:15:37 -07:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2012-05-20 13:33:36 -07:00
2012-05-13 20:49:31 -07:00
2008-07-27 23:00:59 +02:00
2014-06-19 07:50:07 -10:00
2014-06-19 07:50:07 -10:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2012-03-28 18:30:03 +01:00
2013-02-03 18:16:17 -05:00
2012-10-26 15:18:37 -07:00
2012-05-11 21:29:17 -07:00
2012-05-12 00:23:23 -07:00
2012-04-15 10:28:50 -07:00
2014-04-29 01:12:25 -04:00
2014-04-29 01:12:25 -04:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-09-09 16:42:17 -07:00
2012-05-13 13:57:05 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2013-02-26 02:46:08 -05:00
2012-08-18 23:02:36 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2010-08-16 12:26:09 -07:00
2012-10-09 09:47:43 +01:00
2008-08-31 20:56:15 -07:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:35 -07:00
2008-07-27 23:00:59 +02:00
2012-03-28 18:30:03 +01:00
2008-07-27 23:00:59 +02:00
2012-05-11 18:00:14 -06:00
2013-11-13 20:21:46 +01:00
2013-11-13 20:21:46 +01:00
2008-07-27 23:00:59 +02:00
2013-04-06 17:51:48 -04:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2013-03-20 11:06:54 -07:00
2014-05-18 19:01:29 -07:00
2013-04-29 15:54:33 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-07-21 21:43:19 -07:00
2014-05-18 19:01:26 -07:00
2011-05-12 13:44:29 -07:00
2012-10-09 09:47:43 +01:00
2014-05-18 19:01:26 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-06-23 16:47:44 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2011-07-06 08:00:29 -07:00
2008-07-27 23:00:59 +02:00
2013-10-11 07:39:14 +02:00
2014-08-08 15:57:26 -07:00
2008-11-01 21:44:01 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:34 -07:00
2009-06-16 19:47:51 -07:00
2014-05-18 19:01:34 -07:00
2014-05-18 19:01:29 -07:00
2013-06-19 02:10:29 -07:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2012-05-12 00:35:45 -07:00
2012-05-15 10:22:00 -07:00
2008-07-27 23:00:59 +02:00
2008-08-29 14:16:48 -07:00
2014-05-18 19:01:27 -07:00
2014-05-18 19:01:29 -07:00
2008-08-24 22:08:34 -07:00
2012-10-09 09:47:43 +01:00
2011-03-16 18:19:08 -07:00
2014-05-18 19:01:29 -07:00
2012-07-26 16:46:16 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2011-06-27 14:13:09 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2012-03-28 18:30:03 +01:00
2012-05-14 14:05:07 -07:00
2010-11-30 14:33:29 -08:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2012-07-26 16:46:16 -07:00
2014-05-18 19:01:29 -07:00
2014-05-02 01:30:20 -04:00
2013-01-03 15:57:04 -08:00
2008-07-27 23:00:59 +02:00
2014-05-27 16:23:58 -06:00
2014-06-19 07:50:07 -10:00
2010-03-12 15:52:42 -08:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2009-06-16 04:56:23 -07:00
2008-07-27 23:00:59 +02:00
2010-11-26 15:14:56 +01:00
2014-04-29 01:12:25 -04:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-06-19 07:50:07 -10:00
2008-07-27 23:00:59 +02:00
2012-05-27 23:52:51 -07:00
2009-03-18 23:51:57 -07:00
2014-07-17 12:32:47 +02:00
2014-07-17 12:32:47 +02:00
2012-03-28 18:30:03 +01:00
2014-05-18 19:01:29 -07:00
2012-10-09 09:47:43 +01:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2011-01-27 12:30:39 +01:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2009-03-02 15:41:30 -08:00
2012-05-27 23:52:43 -07:00
2014-05-18 19:01:34 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:28 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2012-05-12 00:23:23 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2012-10-09 09:47:43 +01:00
2012-10-09 09:47:43 +01:00
2013-02-03 15:09:22 -05:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:31 -07:00
2008-07-27 23:00:59 +02:00
2013-11-12 15:22:34 -08:00
2011-08-15 14:35:19 -07:00
2011-08-15 14:35:18 -07:00
2009-12-14 23:55:32 +01:00
2008-07-27 23:00:59 +02:00
2014-09-09 15:24:10 -07:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2012-03-28 18:30:03 +01:00
2010-02-17 13:07:21 +01:00
2014-05-18 19:01:29 -07:00
2012-10-09 09:47:43 +01:00
2012-10-09 09:47:43 +01:00
2013-11-13 20:21:47 +01:00
2014-09-16 17:46:44 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2012-04-15 10:28:50 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2012-05-13 20:49:31 -07:00
2014-08-04 20:16:00 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2012-10-09 09:47:43 +01:00
2014-05-03 22:31:52 -07:00
2008-07-27 23:00:59 +02:00
2012-10-26 15:18:37 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00
2014-06-04 16:54:14 -07:00
2008-07-27 23:00:59 +02:00
2008-07-27 23:00:59 +02:00
2012-07-26 16:46:16 -07:00
2012-03-04 17:54:34 -05:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2014-05-18 19:01:29 -07:00
2012-05-14 13:31:38 -07:00
2008-07-27 23:00:59 +02:00
2014-05-18 19:01:29 -07:00
2008-07-27 23:00:59 +02:00