mce_amd.c 27.6 KB
Newer Older
1
#include <linux/module.h>
2 3
#include <linux/slab.h>

4 5
#include <asm/cpu.h>

B
Borislav Petkov 已提交
6
#include "mce_amd.h"
D
Doug Thompson 已提交
7

8 9
static struct amd_decoder_ops *fam_ops;

10
static u8 xec_mask	 = 0xf;
11

12
static bool report_gart_errors;
13
static void (*decode_dram_ecc)(int node_id, struct mce *m);
14 15 16 17 18 19 20

void amd_report_gart_errors(bool v)
{
	report_gart_errors = v;
}
EXPORT_SYMBOL_GPL(amd_report_gart_errors);

21
void amd_register_ecc_decoder(void (*f)(int, struct mce *))
22
{
23
	decode_dram_ecc = f;
24 25 26
}
EXPORT_SYMBOL_GPL(amd_register_ecc_decoder);

27
void amd_unregister_ecc_decoder(void (*f)(int, struct mce *))
28
{
29 30
	if (decode_dram_ecc) {
		WARN_ON(decode_dram_ecc != f);
31

32
		decode_dram_ecc = NULL;
33 34 35 36
	}
}
EXPORT_SYMBOL_GPL(amd_unregister_ecc_decoder);

D
Doug Thompson 已提交
37 38 39 40
/*
 * string representation for the different MCA reported error types, see F3x48
 * or MSR0000_0411.
 */
B
Borislav Petkov 已提交
41 42

/* transaction type */
43
static const char * const tt_msgs[] = { "INSN", "DATA", "GEN", "RESV" };
D
Doug Thompson 已提交
44

B
Borislav Petkov 已提交
45
/* cache level */
46
static const char * const ll_msgs[] = { "RESV", "L1", "L2", "L3/GEN" };
D
Doug Thompson 已提交
47

B
Borislav Petkov 已提交
48
/* memory transaction type */
49
static const char * const rrrr_msgs[] = {
B
Borislav Petkov 已提交
50
       "GEN", "RD", "WR", "DRD", "DWR", "IRD", "PRF", "EV", "SNP"
D
Doug Thompson 已提交
51 52
};

B
Borislav Petkov 已提交
53
/* participating processor */
54
const char * const pp_msgs[] = { "SRC", "RES", "OBS", "GEN" };
55
EXPORT_SYMBOL_GPL(pp_msgs);
D
Doug Thompson 已提交
56

B
Borislav Petkov 已提交
57
/* request timeout */
58
static const char * const to_msgs[] = { "no timeout", "timed out" };
D
Doug Thompson 已提交
59

B
Borislav Petkov 已提交
60
/* memory or i/o */
61
static const char * const ii_msgs[] = { "MEM", "RESV", "IO", "GEN" };
D
Doug Thompson 已提交
62

63
/* internal error type */
64
static const char * const uu_msgs[] = { "RESV", "RESV", "HWA", "RESV" };
65

66
static const char * const f15h_mc1_mce_desc[] = {
67 68 69 70 71 72 73 74 75 76 77 78
	"UC during a demand linefill from L2",
	"Parity error during data load from IC",
	"Parity error for IC valid bit",
	"Main tag parity error",
	"Parity error in prediction queue",
	"PFB data/address parity error",
	"Parity error in the branch status reg",
	"PFB promotion address error",
	"Tag error during probe/victimization",
	"Parity error for IC probe tag valid bit",
	"PFB non-cacheable bit parity error",
	"PFB valid bit parity error",			/* xec = 0xd */
79
	"Microcode Patch Buffer",			/* xec = 010 */
80 81 82
	"uop queue",
	"insn buffer",
	"predecode buffer",
83 84
	"fetch address FIFO",
	"dispatch uop queue"
85 86
};

87
static const char * const f15h_mc2_mce_desc[] = {
88 89 90 91 92 93 94 95
	"Fill ECC error on data fills",			/* xec = 0x4 */
	"Fill parity error on insn fills",
	"Prefetcher request FIFO parity error",
	"PRQ address parity error",
	"PRQ data parity error",
	"WCC Tag ECC error",
	"WCC Data ECC error",
	"WCB Data parity error",
96
	"VB Data ECC or parity error",
97 98 99 100 101 102 103
	"L2 Tag ECC error",				/* xec = 0x10 */
	"Hard L2 Tag ECC error",
	"Multiple hits on L2 tag",
	"XAB parity error",
	"PRB address parity error"
};

104
static const char * const mc4_mce_desc[] = {
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
	"DRAM ECC error detected on the NB",
	"CRC error detected on HT link",
	"Link-defined sync error packets detected on HT link",
	"HT Master abort",
	"HT Target abort",
	"Invalid GART PTE entry during GART table walk",
	"Unsupported atomic RMW received from an IO link",
	"Watchdog timeout due to lack of progress",
	"DRAM ECC error detected on the NB",
	"SVM DMA Exclusion Vector error",
	"HT data error detected on link",
	"Protocol error (link, L3, probe filter)",
	"NB internal arrays parity error",
	"DRAM addr/ctl signals parity error",
	"IO link transmission error",
	"L3 data cache ECC error",			/* xec = 0x1c */
	"L3 cache tag error",
	"L3 LRU parity bits error",
	"ECC Error in the Probe Filter directory"
};

126
static const char * const mc5_mce_desc[] = {
127 128 129 130 131 132 133 134 135 136 137 138
	"CPU Watchdog timer expire",
	"Wakeup array dest tag",
	"AG payload array",
	"EX payload array",
	"IDRF array",
	"Retire dispatch queue",
	"Mapper checkpoint array",
	"Physical register file EX0 port",
	"Physical register file EX1 port",
	"Physical register file AG0 port",
	"Physical register file AG1 port",
	"Flag register file",
139 140
	"DE error occurred",
	"Retire status queue"
141 142
};

143 144 145 146 147 148 149 150 151
static const char * const mc6_mce_desc[] = {
	"Hardware Assertion",
	"Free List",
	"Physical Register File",
	"Retire Queue",
	"Scheduler table",
	"Status Register File",
};

152
/* Scalable MCA error strings */
153
static const char * const smca_ls_mce_desc[] = {
154 155 156 157
	"Load queue parity",
	"Store queue parity",
	"Miss address buffer payload parity",
	"L1 TLB parity",
158
	"Reserved",
159 160 161 162 163 164 165
	"DC tag error type 6",
	"DC tag error type 1",
	"Internal error type 1",
	"Internal error type 2",
	"Sys Read data error thread 0",
	"Sys read data error thread 1",
	"DC tag error type 2",
166
	"DC data error type 1 (poison consumption)",
167 168 169 170 171 172 173 174 175 176
	"DC data error type 2",
	"DC data error type 3",
	"DC tag error type 4",
	"L2 TLB parity",
	"PDC parity error",
	"DC tag error type 3",
	"DC tag error type 5",
	"L2 fill data error",
};

177
static const char * const smca_if_mce_desc[] = {
178 179 180 181 182 183 184 185 186 187 188 189
	"microtag probe port parity error",
	"IC microtag or full tag multi-hit error",
	"IC full tag parity",
	"IC data array parity",
	"Decoupling queue phys addr parity error",
	"L0 ITLB parity error",
	"L1 ITLB parity error",
	"L2 ITLB parity error",
	"BPQ snoop parity on Thread 0",
	"BPQ snoop parity on Thread 1",
	"L1 BTB multi-match error",
	"L2 BTB multi-match error",
190 191
	"L2 Cache Response Poison error",
	"System Read Data error",
192 193
};

194
static const char * const smca_l2_mce_desc[] = {
195 196 197 198 199 200
	"L2M tag multi-way-hit error",
	"L2M tag ECC error",
	"L2M data ECC error",
	"HW assert",
};

201
static const char * const smca_de_mce_desc[] = {
202 203 204
	"uop cache tag parity error",
	"uop cache data parity error",
	"Insn buffer parity error",
205
	"uop queue parity error",
206 207 208 209 210 211 212
	"Insn dispatch queue parity error",
	"Fetch address FIFO parity",
	"Patch RAM data parity",
	"Patch RAM sequencer parity",
	"uop buffer parity"
};

213
static const char * const smca_ex_mce_desc[] = {
214 215 216 217 218 219 220 221
	"Watchdog timeout error",
	"Phy register file parity",
	"Flag register file parity",
	"Immediate displacement register file parity",
	"Address generator payload parity",
	"EX payload parity",
	"Checkpoint queue parity",
	"Retire dispatch queue parity",
222 223 224
	"Retire status queue parity error",
	"Scheduling queue parity error",
	"Branch buffer queue parity error",
225 226
};

227
static const char * const smca_fp_mce_desc[] = {
228 229 230 231 232 233
	"Physical register file parity",
	"Freelist parity error",
	"Schedule queue parity",
	"NSQ parity error",
	"Retire queue parity",
	"Status register file parity",
234
	"Hardware assertion",
235 236
};

237
static const char * const smca_l3_mce_desc[] = {
238 239 240 241 242 243 244 245 246 247
	"Shadow tag macro ECC error",
	"Shadow tag macro multi-way-hit error",
	"L3M tag ECC error",
	"L3M tag multi-way-hit error",
	"L3M data ECC error",
	"XI parity, L3 fill done channel error",
	"L3 victim queue parity",
	"L3 HW assert",
};

248
static const char * const smca_cs_mce_desc[] = {
249 250 251 252 253 254 255 256 257 258 259
	"Illegal request from transport layer",
	"Address violation",
	"Security violation",
	"Illegal response from transport layer",
	"Unexpected response",
	"Parity error on incoming request or probe response data",
	"Parity error on incoming read response data",
	"Atomic request parity",
	"ECC error on probe filter access",
};

260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276
static const char * const smca_cs2_mce_desc[] = {
	"Illegal Request",
	"Address Violation",
	"Security Violation",
	"Illegal Response",
	"Unexpected Response",
	"Request or Probe Parity Error",
	"Read Response Parity Error",
	"Atomic Request Parity Error",
	"SDP read response had no match in the CS queue",
	"Probe Filter Protocol Error",
	"Probe Filter ECC Error",
	"SDP read response had an unexpected RETRY error",
	"Counter overflow error",
	"Counter underflow error",
};

277
static const char * const smca_pie_mce_desc[] = {
278 279 280 281 282 283
	"HW assert",
	"Internal PIE register security violation",
	"Error on GMI link",
	"Poison data written to internal PIE register",
};

284
static const char * const smca_umc_mce_desc[] = {
285 286 287 288 289 290 291 292
	"DRAM ECC error",
	"Data poison error on DRAM",
	"SDP parity error",
	"Advanced peripheral bus error",
	"Command/address parity error",
	"Write data CRC error",
};

293
static const char * const smca_pb_mce_desc[] = {
294 295 296
	"Parameter Block RAM ECC error",
};

297
static const char * const smca_psp_mce_desc[] = {
298 299 300
	"PSP RAM ECC or parity error",
};

301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321
static const char * const smca_psp2_mce_desc[] = {
	"High SRAM ECC or parity error",
	"Low SRAM ECC or parity error",
	"Instruction Cache Bank 0 ECC or parity error",
	"Instruction Cache Bank 1 ECC or parity error",
	"Instruction Tag Ram 0 parity error",
	"Instruction Tag Ram 1 parity error",
	"Data Cache Bank 0 ECC or parity error",
	"Data Cache Bank 1 ECC or parity error",
	"Data Cache Bank 2 ECC or parity error",
	"Data Cache Bank 3 ECC or parity error",
	"Data Tag Bank 0 parity error",
	"Data Tag Bank 1 parity error",
	"Data Tag Bank 2 parity error",
	"Data Tag Bank 3 parity error",
	"Dirty Data Ram parity error",
	"TLB Bank 0 parity error",
	"TLB Bank 1 parity error",
	"System Hub Read Buffer ECC or parity error",
};

322
static const char * const smca_smu_mce_desc[] = {
323 324 325
	"SMU RAM ECC or parity error",
};

326 327 328 329 330 331 332 333 334 335 336 337 338 339
static const char * const smca_smu2_mce_desc[] = {
	"High SRAM ECC or parity error",
	"Low SRAM ECC or parity error",
	"Data Cache Bank A ECC or parity error",
	"Data Cache Bank B ECC or parity error",
	"Data Tag Cache Bank A ECC or parity error",
	"Data Tag Cache Bank B ECC or parity error",
	"Instruction Cache Bank A ECC or parity error",
	"Instruction Cache Bank B ECC or parity error",
	"Instruction Tag Cache Bank A ECC or parity error",
	"Instruction Tag Cache Bank B ECC or parity error",
	"System Hub Read Buffer ECC or parity error",
};

340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368
static const char * const smca_mp5_mce_desc[] = {
	"High SRAM ECC or parity error",
	"Low SRAM ECC or parity error",
	"Data Cache Bank A ECC or parity error",
	"Data Cache Bank B ECC or parity error",
	"Data Tag Cache Bank A ECC or parity error",
	"Data Tag Cache Bank B ECC or parity error",
	"Instruction Cache Bank A ECC or parity error",
	"Instruction Cache Bank B ECC or parity error",
	"Instruction Tag Cache Bank A ECC or parity error",
	"Instruction Tag Cache Bank B ECC or parity error",
};

static const char * const smca_nbio_mce_desc[] = {
	"ECC or Parity error",
	"PCIE error",
	"SDP ErrEvent error",
	"SDP Egress Poison Error",
	"IOHC Internal Poison Error",
};

static const char * const smca_pcie_mce_desc[] = {
	"CCIX PER Message logging",
	"CCIX Read Response with Status: Non-Data Error",
	"CCIX Write Response with Status: Non-Data Error",
	"CCIX Read Response with Status: Data Error",
	"CCIX Non-okay write response with data error",
};

369 370 371 372 373 374 375 376 377 378 379 380 381 382
struct smca_mce_desc {
	const char * const *descs;
	unsigned int num_descs;
};

static struct smca_mce_desc smca_mce_descs[] = {
	[SMCA_LS]	= { smca_ls_mce_desc,	ARRAY_SIZE(smca_ls_mce_desc)	},
	[SMCA_IF]	= { smca_if_mce_desc,	ARRAY_SIZE(smca_if_mce_desc)	},
	[SMCA_L2_CACHE]	= { smca_l2_mce_desc,	ARRAY_SIZE(smca_l2_mce_desc)	},
	[SMCA_DE]	= { smca_de_mce_desc,	ARRAY_SIZE(smca_de_mce_desc)	},
	[SMCA_EX]	= { smca_ex_mce_desc,	ARRAY_SIZE(smca_ex_mce_desc)	},
	[SMCA_FP]	= { smca_fp_mce_desc,	ARRAY_SIZE(smca_fp_mce_desc)	},
	[SMCA_L3_CACHE]	= { smca_l3_mce_desc,	ARRAY_SIZE(smca_l3_mce_desc)	},
	[SMCA_CS]	= { smca_cs_mce_desc,	ARRAY_SIZE(smca_cs_mce_desc)	},
383
	[SMCA_CS_V2]	= { smca_cs2_mce_desc,	ARRAY_SIZE(smca_cs2_mce_desc)	},
384 385 386 387
	[SMCA_PIE]	= { smca_pie_mce_desc,	ARRAY_SIZE(smca_pie_mce_desc)	},
	[SMCA_UMC]	= { smca_umc_mce_desc,	ARRAY_SIZE(smca_umc_mce_desc)	},
	[SMCA_PB]	= { smca_pb_mce_desc,	ARRAY_SIZE(smca_pb_mce_desc)	},
	[SMCA_PSP]	= { smca_psp_mce_desc,	ARRAY_SIZE(smca_psp_mce_desc)	},
388
	[SMCA_PSP_V2]	= { smca_psp2_mce_desc,	ARRAY_SIZE(smca_psp2_mce_desc)	},
389
	[SMCA_SMU]	= { smca_smu_mce_desc,	ARRAY_SIZE(smca_smu_mce_desc)	},
390
	[SMCA_SMU_V2]	= { smca_smu2_mce_desc,	ARRAY_SIZE(smca_smu2_mce_desc)	},
391 392 393
	[SMCA_MP5]	= { smca_mp5_mce_desc,	ARRAY_SIZE(smca_mp5_mce_desc)	},
	[SMCA_NBIO]	= { smca_nbio_mce_desc,	ARRAY_SIZE(smca_nbio_mce_desc)	},
	[SMCA_PCIE]	= { smca_pcie_mce_desc,	ARRAY_SIZE(smca_pcie_mce_desc)	},
394 395
};

396
static bool f12h_mc0_mce(u16 ec, u8 xec)
397
{
398
	bool ret = false;
399

400
	if (MEM_ERROR(ec)) {
401
		u8 ll = LL(ec);
402
		ret = true;
403

404 405 406
		if (ll == LL_L2)
			pr_cont("during L1 linefill from L2.\n");
		else if (ll == LL_L1)
407
			pr_cont("Data/Tag %s error.\n", R4_MSG(ec));
408 409 410 411 412
		else
			ret = false;
	}
	return ret;
}
413

414
static bool f10h_mc0_mce(u16 ec, u8 xec)
415
{
416
	if (R4(ec) == R4_GEN && LL(ec) == LL_L1) {
417 418 419
		pr_cont("during data scrub.\n");
		return true;
	}
420
	return f12h_mc0_mce(ec, xec);
421 422
}

423
static bool k8_mc0_mce(u16 ec, u8 xec)
424 425 426 427 428
{
	if (BUS_ERROR(ec)) {
		pr_cont("during system linefill.\n");
		return true;
	}
429

430
	return f10h_mc0_mce(ec, xec);
431 432
}

433
static bool cat_mc0_mce(u16 ec, u8 xec)
434
{
435
	u8 r4	 = R4(ec);
436 437 438 439
	bool ret = true;

	if (MEM_ERROR(ec)) {

440
		if (TT(ec) != TT_DATA || LL(ec) != LL_L1)
441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459
			return false;

		switch (r4) {
		case R4_DRD:
		case R4_DWR:
			pr_cont("Data/Tag parity error due to %s.\n",
				(r4 == R4_DRD ? "load/hw prf" : "store"));
			break;
		case R4_EVICT:
			pr_cont("Copyback parity error on a tag miss.\n");
			break;
		case R4_SNOOP:
			pr_cont("Tag parity error during snoop.\n");
			break;
		default:
			ret = false;
		}
	} else if (BUS_ERROR(ec)) {

460
		if ((II(ec) != II_MEM && II(ec) != II_IO) || LL(ec) != LL_LG)
461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484
			return false;

		pr_cont("System read data error on a ");

		switch (r4) {
		case R4_RD:
			pr_cont("TLB reload.\n");
			break;
		case R4_DWR:
			pr_cont("store.\n");
			break;
		case R4_DRD:
			pr_cont("load.\n");
			break;
		default:
			ret = false;
		}
	} else {
		ret = false;
	}

	return ret;
}

485
static bool f15h_mc0_mce(u16 ec, u8 xec)
486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522
{
	bool ret = true;

	if (MEM_ERROR(ec)) {

		switch (xec) {
		case 0x0:
			pr_cont("Data Array access error.\n");
			break;

		case 0x1:
			pr_cont("UC error during a linefill from L2/NB.\n");
			break;

		case 0x2:
		case 0x11:
			pr_cont("STQ access error.\n");
			break;

		case 0x3:
			pr_cont("SCB access error.\n");
			break;

		case 0x10:
			pr_cont("Tag error.\n");
			break;

		case 0x12:
			pr_cont("LDQ access error.\n");
			break;

		default:
			ret = false;
		}
	} else if (BUS_ERROR(ec)) {

		if (!xec)
523
			pr_cont("System Read Data Error.\n");
524
		else
525
			pr_cont(" Internal error condition type %d.\n", xec);
526 527 528 529 530 531
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x1f)
			pr_cont("Hardware Assert.\n");
		else
			ret = false;

532 533 534 535 536 537
	} else
		ret = false;

	return ret;
}

538
static void decode_mc0_mce(struct mce *m)
539
{
540 541
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
542

543
	pr_emerg(HW_ERR "MC0 Error: ");
544 545 546

	/* TLB error signatures are the same across families */
	if (TLB_ERROR(ec)) {
547
		if (TT(ec) == TT_DATA) {
548
			pr_cont("%s TLB %s.\n", LL_MSG(ec),
549 550
				((xec == 2) ? "locked miss"
					    : (xec ? "multimatch" : "parity")));
551 552
			return;
		}
553
	} else if (fam_ops->mc0_mce(ec, xec))
554 555
		;
	else
556
		pr_emerg(HW_ERR "Corrupted MC0 MCE info?\n");
557 558
}

559
static bool k8_mc1_mce(u16 ec, u8 xec)
560
{
561
	u8 ll	 = LL(ec);
562
	bool ret = true;
563

564 565
	if (!MEM_ERROR(ec))
		return false;
566

567 568 569
	if (ll == 0x2)
		pr_cont("during a linefill from L2.\n");
	else if (ll == 0x1) {
570
		switch (R4(ec)) {
571 572 573
		case R4_IRD:
			pr_cont("Parity error during data load.\n");
			break;
574

575 576 577 578 579 580 581 582 583 584 585 586
		case R4_EVICT:
			pr_cont("Copyback Parity/Victim error.\n");
			break;

		case R4_SNOOP:
			pr_cont("Tag Snoop error.\n");
			break;

		default:
			ret = false;
			break;
		}
587
	} else
588
		ret = false;
589

590 591 592
	return ret;
}

593
static bool cat_mc1_mce(u16 ec, u8 xec)
594
{
595
	u8 r4    = R4(ec);
596
	bool ret = true;
597

598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613
	if (!MEM_ERROR(ec))
		return false;

	if (TT(ec) != TT_INSTR)
		return false;

	if (r4 == R4_IRD)
		pr_cont("Data/tag array parity error for a tag hit.\n");
	else if (r4 == R4_SNOOP)
		pr_cont("Tag error during snoop/victimization.\n");
	else if (xec == 0x0)
		pr_cont("Tag parity error from victim castout.\n");
	else if (xec == 0x2)
		pr_cont("Microcode patch RAM parity error.\n");
	else
		ret = false;
614 615 616 617

	return ret;
}

618
static bool f15h_mc1_mce(u16 ec, u8 xec)
619 620 621 622 623 624 625 626
{
	bool ret = true;

	if (!MEM_ERROR(ec))
		return false;

	switch (xec) {
	case 0x0 ... 0xa:
627
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec]);
628 629 630
		break;

	case 0xd:
631
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec-2]);
632 633
		break;

634
	case 0x10:
635
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec-4]);
636 637
		break;

638
	case 0x11 ... 0x15:
639
		pr_cont("Decoder %s parity error.\n", f15h_mc1_mce_desc[xec-4]);
640 641 642 643 644 645 646 647
		break;

	default:
		ret = false;
	}
	return ret;
}

648
static void decode_mc1_mce(struct mce *m)
649
{
650 651
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
652

653
	pr_emerg(HW_ERR "MC1 Error: ");
654 655 656 657 658

	if (TLB_ERROR(ec))
		pr_cont("%s TLB %s.\n", LL_MSG(ec),
			(xec ? "multimatch" : "parity error"));
	else if (BUS_ERROR(ec)) {
659
		bool k8 = (boot_cpu_data.x86 == 0xf && (m->status & BIT_64(58)));
660 661

		pr_cont("during %s.\n", (k8 ? "system linefill" : "NB data read"));
662 663 664 665 666
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x3f)
			pr_cont("Hardware Assert.\n");
		else
			goto wrong_mc1_mce;
667
	} else if (fam_ops->mc1_mce(ec, xec))
668 669
		;
	else
670 671 672 673 674 675
		goto wrong_mc1_mce;

	return;

wrong_mc1_mce:
	pr_emerg(HW_ERR "Corrupted MC1 MCE info?\n");
676 677
}

678
static bool k8_mc2_mce(u16 ec, u8 xec)
679
{
680
	bool ret = true;
681 682 683 684 685 686

	if (xec == 0x1)
		pr_cont(" in the write data buffers.\n");
	else if (xec == 0x3)
		pr_cont(" in the victim data buffers.\n");
	else if (xec == 0x2 && MEM_ERROR(ec))
687
		pr_cont(": %s error in the L2 cache tags.\n", R4_MSG(ec));
688 689
	else if (xec == 0x0) {
		if (TLB_ERROR(ec))
690 691
			pr_cont("%s error in a Page Descriptor Cache or Guest TLB.\n",
				TT_MSG(ec));
692 693
		else if (BUS_ERROR(ec))
			pr_cont(": %s/ECC error in data read from NB: %s.\n",
694
				R4_MSG(ec), PP_MSG(ec));
695
		else if (MEM_ERROR(ec)) {
696
			u8 r4 = R4(ec);
697

698
			if (r4 >= 0x7)
699
				pr_cont(": %s error during data copyback.\n",
700 701
					R4_MSG(ec));
			else if (r4 <= 0x1)
702
				pr_cont(": %s parity/ECC error during data "
703
					"access from L2.\n", R4_MSG(ec));
704
			else
705
				ret = false;
706
		} else
707
			ret = false;
708
	} else
709
		ret = false;
710

711
	return ret;
712 713
}

714
static bool f15h_mc2_mce(u16 ec, u8 xec)
715
{
716
	bool ret = true;
717 718 719 720 721 722 723

	if (TLB_ERROR(ec)) {
		if (xec == 0x0)
			pr_cont("Data parity TLB read error.\n");
		else if (xec == 0x1)
			pr_cont("Poison data provided for TLB fill.\n");
		else
724
			ret = false;
725 726
	} else if (BUS_ERROR(ec)) {
		if (xec > 2)
727
			ret = false;
728 729 730 731 732

		pr_cont("Error during attempted NB data read.\n");
	} else if (MEM_ERROR(ec)) {
		switch (xec) {
		case 0x4 ... 0xc:
733
			pr_cont("%s.\n", f15h_mc2_mce_desc[xec - 0x4]);
734 735 736
			break;

		case 0x10 ... 0x14:
737
			pr_cont("%s.\n", f15h_mc2_mce_desc[xec - 0x7]);
738 739 740
			break;

		default:
741
			ret = false;
742
		}
743 744 745 746 747
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x3f)
			pr_cont("Hardware Assert.\n");
		else
			ret = false;
748 749
	}

750 751 752
	return ret;
}

753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793
static bool f16h_mc2_mce(u16 ec, u8 xec)
{
	u8 r4 = R4(ec);

	if (!MEM_ERROR(ec))
		return false;

	switch (xec) {
	case 0x04 ... 0x05:
		pr_cont("%cBUFF parity error.\n", (r4 == R4_RD) ? 'I' : 'O');
		break;

	case 0x09 ... 0x0b:
	case 0x0d ... 0x0f:
		pr_cont("ECC error in L2 tag (%s).\n",
			((r4 == R4_GEN)   ? "BankReq" :
			((r4 == R4_SNOOP) ? "Prb"     : "Fill")));
		break;

	case 0x10 ... 0x19:
	case 0x1b:
		pr_cont("ECC error in L2 data array (%s).\n",
			(((r4 == R4_RD) && !(xec & 0x3)) ? "Hit"  :
			((r4 == R4_GEN)   ? "Attr" :
			((r4 == R4_EVICT) ? "Vict" : "Fill"))));
		break;

	case 0x1c ... 0x1d:
	case 0x1f:
		pr_cont("Parity error in L2 attribute bits (%s).\n",
			((r4 == R4_RD)  ? "Hit"  :
			((r4 == R4_GEN) ? "Attr" : "Fill")));
		break;

	default:
		return false;
	}

	return true;
}

794 795 796 797
static void decode_mc2_mce(struct mce *m)
{
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
798

799 800 801 802
	pr_emerg(HW_ERR "MC2 Error: ");

	if (!fam_ops->mc2_mce(ec, xec))
		pr_cont(HW_ERR "Corrupted MC2 MCE info?\n");
803 804
}

805
static void decode_mc3_mce(struct mce *m)
806
{
807 808
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
809

810
	if (boot_cpu_data.x86 >= 0x14) {
811
		pr_emerg("You shouldn't be seeing MC3 MCE on this cpu family,"
812 813 814
			 " please report on LKML.\n");
		return;
	}
815

816
	pr_emerg(HW_ERR "MC3 Error");
817 818

	if (xec == 0x0) {
819
		u8 r4 = R4(ec);
820

821
		if (!BUS_ERROR(ec) || (r4 != R4_DRD && r4 != R4_DWR))
822
			goto wrong_mc3_mce;
823

824
		pr_cont(" during %s.\n", R4_MSG(ec));
825
	} else
826
		goto wrong_mc3_mce;
827

828 829
	return;

830 831
 wrong_mc3_mce:
	pr_emerg(HW_ERR "Corrupted MC3 MCE info?\n");
832 833
}

834
static void decode_mc4_mce(struct mce *m)
835
{
836
	unsigned int fam = x86_family(m->cpuid);
837 838 839 840
	int node_id = amd_get_nb_id(m->extcpu);
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, 0x1f);
	u8 offset = 0;
841

842
	pr_emerg(HW_ERR "MC4 Error (node %d): ", node_id);
843

844 845
	switch (xec) {
	case 0x0 ... 0xe:
846

847 848 849
		/* special handling for DRAM ECCs */
		if (xec == 0x0 || xec == 0x8) {
			/* no ECCs on F11h */
850
			if (fam == 0x11)
851
				goto wrong_mc4_mce;
852

853
			pr_cont("%s.\n", mc4_mce_desc[xec]);
854

855 856
			if (decode_dram_ecc)
				decode_dram_ecc(node_id, m);
857 858
			return;
		}
859 860 861 862 863 864 865 866
		break;

	case 0xf:
		if (TLB_ERROR(ec))
			pr_cont("GART Table Walk data error.\n");
		else if (BUS_ERROR(ec))
			pr_cont("DMA Exclusion Vector Table Walk error.\n");
		else
867
			goto wrong_mc4_mce;
868
		return;
869

870
	case 0x19:
871
		if (fam == 0x15 || fam == 0x16)
872 873
			pr_cont("Compute Unit Data Error.\n");
		else
874
			goto wrong_mc4_mce;
875
		return;
876

877
	case 0x1c ... 0x1f:
878
		offset = 13;
879 880 881
		break;

	default:
882
		goto wrong_mc4_mce;
883
	}
884

885
	pr_cont("%s.\n", mc4_mce_desc[xec - offset]);
886 887
	return;

888 889
 wrong_mc4_mce:
	pr_emerg(HW_ERR "Corrupted MC4 MCE info?\n");
890 891
}

892
static void decode_mc5_mce(struct mce *m)
B
Borislav Petkov 已提交
893
{
894
	unsigned int fam = x86_family(m->cpuid);
895
	u16 ec = EC(m->status);
896
	u8 xec = XEC(m->status, xec_mask);
897

898
	if (fam == 0xf || fam == 0x11)
899
		goto wrong_mc5_mce;
B
Borislav Petkov 已提交
900

901
	pr_emerg(HW_ERR "MC5 Error: ");
902

903 904 905 906 907 908 909 910
	if (INT_ERROR(ec)) {
		if (xec <= 0x1f) {
			pr_cont("Hardware Assert.\n");
			return;
		} else
			goto wrong_mc5_mce;
	}

911
	if (xec == 0x0 || xec == 0xc)
912
		pr_cont("%s.\n", mc5_mce_desc[xec]);
913
	else if (xec <= 0xd)
914
		pr_cont("%s parity error.\n", mc5_mce_desc[xec]);
915
	else
916
		goto wrong_mc5_mce;
917 918

	return;
B
Borislav Petkov 已提交
919

920 921
 wrong_mc5_mce:
	pr_emerg(HW_ERR "Corrupted MC5 MCE info?\n");
B
Borislav Petkov 已提交
922 923
}

924
static void decode_mc6_mce(struct mce *m)
925
{
926
	u8 xec = XEC(m->status, xec_mask);
927

928
	pr_emerg(HW_ERR "MC6 Error: ");
929

930
	if (xec > 0x5)
931
		goto wrong_mc6_mce;
932

933
	pr_cont("%s parity error.\n", mc6_mce_desc[xec]);
934 935
	return;

936 937
 wrong_mc6_mce:
	pr_emerg(HW_ERR "Corrupted MC6 MCE info?\n");
938 939
}

940
/* Decode errors according to Scalable MCA specification */
941
static void decode_smca_error(struct mce *m)
942
{
943
	struct smca_hwid *hwid;
944
	enum smca_bank_types bank_type;
945
	const char *ip_name;
946
	u8 xec = XEC(m->status, xec_mask);
947

948
	if (m->bank >= ARRAY_SIZE(smca_banks))
949 950
		return;

951 952
	hwid = smca_banks[m->bank].hwid;
	if (!hwid)
953 954
		return;

955
	bank_type = hwid->bank_type;
956 957 958 959 960 961

	if (bank_type == SMCA_RESERVED) {
		pr_emerg(HW_ERR "Bank %d is reserved.\n", m->bank);
		return;
	}

B
Borislav Petkov 已提交
962
	ip_name = smca_get_long_name(bank_type);
963

964
	pr_emerg(HW_ERR "%s Extended Error Code: %d\n", ip_name, xec);
965

966 967
	/* Only print the decode of valid error codes */
	if (xec < smca_mce_descs[bank_type].num_descs &&
968
			(hwid->xec_bitmap & BIT_ULL(xec))) {
969 970 971
		pr_emerg(HW_ERR "%s Error: ", ip_name);
		pr_cont("%s.\n", smca_mce_descs[bank_type].descs[xec]);
	}
972 973

	if (bank_type == SMCA_UMC && xec == 0 && decode_dram_ecc)
974
		decode_dram_ecc(cpu_to_node(m->extcpu), m);
975 976
}

B
Borislav Petkov 已提交
977
static inline void amd_decode_err_code(u16 ec)
978
{
979 980 981 982
	if (INT_ERROR(ec)) {
		pr_emerg(HW_ERR "internal: %s\n", UU_MSG(ec));
		return;
	}
983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998

	pr_emerg(HW_ERR "cache level: %s", LL_MSG(ec));

	if (BUS_ERROR(ec))
		pr_cont(", mem/io: %s", II_MSG(ec));
	else
		pr_cont(", tx: %s", TT_MSG(ec));

	if (MEM_ERROR(ec) || BUS_ERROR(ec)) {
		pr_cont(", mem-tx: %s", R4_MSG(ec));

		if (BUS_ERROR(ec))
			pr_cont(", part-proc: %s (%s)", PP_MSG(ec), TO_MSG(ec));
	}

	pr_cont("\n");
999 1000
}

1001 1002 1003 1004 1005 1006 1007 1008
/*
 * Filter out unwanted MCE signatures here.
 */
static bool amd_filter_mce(struct mce *m)
{
	/*
	 * NB GART TLB error reporting is disabled by default.
	 */
1009
	if (m->bank == 4 && XEC(m->status, 0x1f) == 0x5 && !report_gart_errors)
1010 1011 1012 1013 1014
		return true;

	return false;
}

B
Borislav Petkov 已提交
1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025
static const char *decode_error_status(struct mce *m)
{
	if (m->status & MCI_STATUS_UC) {
		if (m->status & MCI_STATUS_PCC)
			return "System Fatal error.";
		if (m->mcgstatus & MCG_STATUS_RIPV)
			return "Uncorrected, software restartable error.";
		return "Uncorrected, software containable error.";
	}

	if (m->status & MCI_STATUS_DEFERRED)
1026
		return "Deferred error, no action required.";
B
Borislav Petkov 已提交
1027 1028 1029 1030

	return "Corrected error, no action required.";
}

1031 1032
static int
amd_decode_mce(struct notifier_block *nb, unsigned long val, void *data)
1033
{
1034
	struct mce *m = (struct mce *)data;
1035
	unsigned int fam = x86_family(m->cpuid);
1036
	int ecc;
1037

1038 1039 1040
	if (amd_filter_mce(m))
		return NOTIFY_STOP;

1041 1042 1043 1044
	pr_emerg(HW_ERR "%s\n", decode_error_status(m));

	pr_emerg(HW_ERR "CPU:%d (%x:%x:%x) MC%d_STATUS[%s|%s|%s|%s|%s",
		m->extcpu,
1045
		fam, x86_model(m->cpuid), x86_stepping(m->cpuid),
1046 1047
		m->bank,
		((m->status & MCI_STATUS_OVER)	? "Over"  : "-"),
1048 1049
		((m->status & MCI_STATUS_UC)	? "UE"	  :
		 (m->status & MCI_STATUS_DEFERRED) ? "-"  : "CE"),
1050 1051 1052 1053
		((m->status & MCI_STATUS_MISCV)	? "MiscV" : "-"),
		((m->status & MCI_STATUS_PCC)	? "PCC"	  : "-"),
		((m->status & MCI_STATUS_ADDRV)	? "AddrV" : "-"));

1054
	if (fam >= 0x15) {
1055 1056 1057
		pr_cont("|%s", (m->status & MCI_STATUS_DEFERRED ? "Deferred" : "-"));

		/* F15h, bank4, bit 43 is part of McaStatSubCache. */
1058
		if (fam != 0x15 || m->bank != 4)
1059 1060
			pr_cont("|%s", (m->status & MCI_STATUS_POISON ? "Poison" : "-"));
	}
1061

1062
	if (boot_cpu_has(X86_FEATURE_SMCA)) {
1063 1064 1065
		u32 low, high;
		u32 addr = MSR_AMD64_SMCA_MCx_CONFIG(m->bank);

1066 1067
		pr_cont("|%s", ((m->status & MCI_STATUS_SYNDV) ? "SyndV" : "-"));

1068 1069 1070 1071 1072
		if (!rdmsr_safe(addr, &low, &high) &&
		    (low & MCI_CONFIG_MCAX))
			pr_cont("|%s", ((m->status & MCI_STATUS_TCC) ? "TCC" : "-"));
	}

1073 1074 1075 1076 1077 1078 1079 1080
	/* do the two bits[14:13] together */
	ecc = (m->status >> 45) & 0x3;
	if (ecc)
		pr_cont("|%sECC", ((ecc == 2) ? "C" : "U"));

	pr_cont("]: 0x%016llx\n", m->status);

	if (m->status & MCI_STATUS_ADDRV)
1081
		pr_emerg(HW_ERR "Error Addr: 0x%016llx\n", m->addr);
1082

1083
	if (boot_cpu_has(X86_FEATURE_SMCA)) {
1084 1085
		pr_emerg(HW_ERR "IPID: 0x%016llx", m->ipid);

1086 1087 1088 1089 1090
		if (m->status & MCI_STATUS_SYNDV)
			pr_cont(", Syndrome: 0x%016llx", m->synd);

		pr_cont("\n");

1091
		decode_smca_error(m);
1092
		goto err_code;
1093
	}
1094

B
Borislav Petkov 已提交
1095 1096 1097
	if (m->tsc)
		pr_emerg(HW_ERR "TSC: %llu\n", m->tsc);

1098 1099 1100
	if (!fam_ops)
		goto err_code;

1101 1102
	switch (m->bank) {
	case 0:
1103
		decode_mc0_mce(m);
1104
		break;
1105

1106
	case 1:
1107
		decode_mc1_mce(m);
1108 1109
		break;

1110
	case 2:
1111
		decode_mc2_mce(m);
1112 1113
		break;

1114
	case 3:
1115
		decode_mc3_mce(m);
1116 1117
		break;

1118
	case 4:
1119
		decode_mc4_mce(m);
1120 1121
		break;

B
Borislav Petkov 已提交
1122
	case 5:
1123
		decode_mc5_mce(m);
B
Borislav Petkov 已提交
1124 1125
		break;

1126
	case 6:
1127
		decode_mc6_mce(m);
1128 1129
		break;

1130 1131
	default:
		break;
1132
	}
1133

1134
 err_code:
1135
	amd_decode_err_code(m->status & 0xffff);
1136 1137

	return NOTIFY_STOP;
1138
}
1139

1140 1141
static struct notifier_block amd_mce_dec_nb = {
	.notifier_call	= amd_decode_mce,
1142
	.priority	= MCE_PRIO_EDAC,
1143 1144
};

1145 1146
static int __init mce_amd_init(void)
{
1147 1148 1149
	struct cpuinfo_x86 *c = &boot_cpu_data;

	if (c->x86_vendor != X86_VENDOR_AMD)
1150
		return -ENODEV;
1151

1152 1153 1154 1155
	fam_ops = kzalloc(sizeof(struct amd_decoder_ops), GFP_KERNEL);
	if (!fam_ops)
		return -ENOMEM;

1156
	switch (c->x86) {
1157
	case 0xf:
1158 1159
		fam_ops->mc0_mce = k8_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1160
		fam_ops->mc2_mce = k8_mc2_mce;
1161 1162 1163
		break;

	case 0x10:
1164 1165
		fam_ops->mc0_mce = f10h_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1166
		fam_ops->mc2_mce = k8_mc2_mce;
1167 1168
		break;

1169
	case 0x11:
1170 1171
		fam_ops->mc0_mce = k8_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1172
		fam_ops->mc2_mce = k8_mc2_mce;
1173 1174
		break;

1175
	case 0x12:
1176 1177
		fam_ops->mc0_mce = f12h_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1178
		fam_ops->mc2_mce = k8_mc2_mce;
1179 1180
		break;

1181
	case 0x14:
1182 1183
		fam_ops->mc0_mce = cat_mc0_mce;
		fam_ops->mc1_mce = cat_mc1_mce;
1184
		fam_ops->mc2_mce = k8_mc2_mce;
1185 1186
		break;

1187
	case 0x15:
1188 1189
		xec_mask = c->x86_model == 0x60 ? 0x3f : 0x1f;

1190 1191
		fam_ops->mc0_mce = f15h_mc0_mce;
		fam_ops->mc1_mce = f15h_mc1_mce;
1192
		fam_ops->mc2_mce = f15h_mc2_mce;
1193 1194
		break;

1195 1196 1197 1198 1199 1200 1201
	case 0x16:
		xec_mask = 0x1f;
		fam_ops->mc0_mce = cat_mc0_mce;
		fam_ops->mc1_mce = cat_mc1_mce;
		fam_ops->mc2_mce = f16h_mc2_mce;
		break;

1202 1203
	case 0x17:
		xec_mask = 0x3f;
1204
		if (!boot_cpu_has(X86_FEATURE_SMCA)) {
1205 1206 1207 1208 1209
			printk(KERN_WARNING "Decoding supported only on Scalable MCA processors.\n");
			goto err_out;
		}
		break;

1210
	default:
1211
		printk(KERN_WARNING "Huh? What family is it: 0x%x?!\n", c->x86);
1212
		goto err_out;
1213 1214
	}

1215 1216
	pr_info("MCE: In-kernel MCE decoding enabled.\n");

1217
	mce_register_decode_chain(&amd_mce_dec_nb);
1218 1219

	return 0;
1220 1221 1222 1223 1224

err_out:
	kfree(fam_ops);
	fam_ops = NULL;
	return -EINVAL;
1225 1226
}
early_initcall(mce_amd_init);
1227 1228 1229 1230

#ifdef MODULE
static void __exit mce_amd_exit(void)
{
1231
	mce_unregister_decode_chain(&amd_mce_dec_nb);
1232
	kfree(fam_ops);
1233 1234 1235 1236 1237 1238 1239
}

MODULE_DESCRIPTION("AMD MCE decoder");
MODULE_ALIAS("edac-mce-amd");
MODULE_LICENSE("GPL");
module_exit(mce_amd_exit);
#endif