mce_amd.c 28.0 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 error",
	"Store queue parity error",
	"Miss address buffer payload parity error",
	"Level 1 TLB parity error",
158
	"DC Tag error type 5",
159 160
	"DC Tag error type 6",
	"DC Tag error type 1",
161 162
	"Internal error type 1",
	"Internal error type 2",
163 164 165 166 167 168 169 170
	"System Read Data Error Thread 0",
	"System Read Data Error Thread 1",
	"DC Tag error type 2",
	"DC Data error type 1 and poison consumption",
	"DC Data error type 2",
	"DC Data error type 3",
	"DC Tag error type 4",
	"Level 2 TLB parity error",
171
	"PDC parity error",
172 173 174
	"DC Tag error type 3",
	"DC Tag error type 5",
	"L2 Fill Data error",
175 176
};

177
static const char * const smca_if_mce_desc[] = {
178 179 180 181 182 183 184 185 186 187 188 189 190 191
	"Op Cache Microtag Probe Port Parity Error",
	"IC Microtag or Full Tag Multi-hit Error",
	"IC Full Tag Parity Error",
	"IC Data Array Parity Error",
	"Decoupling Queue PhysAddr Parity Error",
	"L0 ITLB Parity Error",
	"L1 ITLB Parity Error",
	"L2 ITLB Parity Error",
	"BPQ Thread 0 Snoop Parity Error",
	"BPQ Thread 1 Snoop Parity Error",
	"L1 BTB Multi-Match Error",
	"L2 BTB Multi-Match Error",
	"L2 Cache Response Poison Error",
	"System Read Data Error",
192 193
};

194
static const char * const smca_l2_mce_desc[] = {
195 196 197 198
	"L2M Tag Multiple-Way-Hit error",
	"L2M Tag or State Array ECC Error",
	"L2M Data Array ECC Error",
	"Hardware Assert Error",
199 200
};

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

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

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

238
static const char * const smca_l3_mce_desc[] = {
239 240 241 242 243 244 245 246
	"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",
	"SDP Parity Error or SystemReadDataError from XI",
	"L3 Victim Queue Parity Error",
	"L3 Hardware Assertion",
247 248
};

249
static const char * const smca_cs_mce_desc[] = {
250 251 252 253 254 255 256 257 258
	"Illegal Request",
	"Address Violation",
	"Security Violation",
	"Illegal Response",
	"Unexpected Response",
	"Request or Probe Parity Error",
	"Read Response Parity Error",
	"Atomic Request Parity Error",
	"Probe Filter ECC Error",
259 260
};

261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277
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",
};

278
static const char * const smca_pie_mce_desc[] = {
279 280 281 282
	"Hardware Assert",
	"Register security violation",
	"Link Error",
	"Poison data consumption",
283
	"A deferred error was detected in the DF"
284 285
};

286
static const char * const smca_umc_mce_desc[] = {
287
	"DRAM ECC error",
288
	"Data poison error",
289 290
	"SDP parity error",
	"Advanced peripheral bus error",
291
	"Address/Command parity error",
292
	"Write data CRC error",
293 294
	"DCQ SRAM ECC error",
	"AES SRAM ECC error",
295 296
};

297
static const char * const smca_pb_mce_desc[] = {
298
	"An ECC error in the Parameter Block RAM array",
299 300
};

301
static const char * const smca_psp_mce_desc[] = {
302
	"An ECC or parity error in a PSP RAM instance",
303 304
};

305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325
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",
};

326
static const char * const smca_smu_mce_desc[] = {
327
	"An ECC or parity error in an SMU RAM instance",
328 329
};

330 331 332 333 334 335 336 337 338 339 340 341 342 343
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",
};

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 369 370 371 372
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",
};

373 374 375 376 377 378 379 380 381 382 383 384 385 386
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)	},
387
	[SMCA_CS_V2]	= { smca_cs2_mce_desc,	ARRAY_SIZE(smca_cs2_mce_desc)	},
388 389 390 391
	[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)	},
392
	[SMCA_PSP_V2]	= { smca_psp2_mce_desc,	ARRAY_SIZE(smca_psp2_mce_desc)	},
393
	[SMCA_SMU]	= { smca_smu_mce_desc,	ARRAY_SIZE(smca_smu_mce_desc)	},
394
	[SMCA_SMU_V2]	= { smca_smu2_mce_desc,	ARRAY_SIZE(smca_smu2_mce_desc)	},
395 396 397
	[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)	},
398 399
};

400
static bool f12h_mc0_mce(u16 ec, u8 xec)
401
{
402
	bool ret = false;
403

404
	if (MEM_ERROR(ec)) {
405
		u8 ll = LL(ec);
406
		ret = true;
407

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

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

427
static bool k8_mc0_mce(u16 ec, u8 xec)
428 429 430 431 432
{
	if (BUS_ERROR(ec)) {
		pr_cont("during system linefill.\n");
		return true;
	}
433

434
	return f10h_mc0_mce(ec, xec);
435 436
}

437
static bool cat_mc0_mce(u16 ec, u8 xec)
438
{
439
	u8 r4	 = R4(ec);
440 441 442 443
	bool ret = true;

	if (MEM_ERROR(ec)) {

444
		if (TT(ec) != TT_DATA || LL(ec) != LL_L1)
445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463
			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)) {

464
		if ((II(ec) != II_MEM && II(ec) != II_IO) || LL(ec) != LL_LG)
465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488
			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;
}

489
static bool f15h_mc0_mce(u16 ec, u8 xec)
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 523 524 525 526
{
	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)
527
			pr_cont("System Read Data Error.\n");
528
		else
529
			pr_cont(" Internal error condition type %d.\n", xec);
530 531 532 533 534 535
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x1f)
			pr_cont("Hardware Assert.\n");
		else
			ret = false;

536 537 538 539 540 541
	} else
		ret = false;

	return ret;
}

542
static void decode_mc0_mce(struct mce *m)
543
{
544 545
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
546

547
	pr_emerg(HW_ERR "MC0 Error: ");
548 549 550

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

563
static bool k8_mc1_mce(u16 ec, u8 xec)
564
{
565
	u8 ll	 = LL(ec);
566
	bool ret = true;
567

568 569
	if (!MEM_ERROR(ec))
		return false;
570

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

579 580 581 582 583 584 585 586 587 588 589 590
		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;
		}
591
	} else
592
		ret = false;
593

594 595 596
	return ret;
}

597
static bool cat_mc1_mce(u16 ec, u8 xec)
598
{
599
	u8 r4    = R4(ec);
600
	bool ret = true;
601

602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617
	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;
618 619 620 621

	return ret;
}

622
static bool f15h_mc1_mce(u16 ec, u8 xec)
623 624 625 626 627 628 629 630
{
	bool ret = true;

	if (!MEM_ERROR(ec))
		return false;

	switch (xec) {
	case 0x0 ... 0xa:
631
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec]);
632 633 634
		break;

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

638
	case 0x10:
639
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec-4]);
640 641
		break;

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

	default:
		ret = false;
	}
	return ret;
}

652
static void decode_mc1_mce(struct mce *m)
653
{
654 655
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
656

657
	pr_emerg(HW_ERR "MC1 Error: ");
658 659 660 661 662

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

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

	return;

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

682
static bool k8_mc2_mce(u16 ec, u8 xec)
683
{
684
	bool ret = true;
685 686 687 688 689 690

	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))
691
		pr_cont(": %s error in the L2 cache tags.\n", R4_MSG(ec));
692 693
	else if (xec == 0x0) {
		if (TLB_ERROR(ec))
694 695
			pr_cont("%s error in a Page Descriptor Cache or Guest TLB.\n",
				TT_MSG(ec));
696 697
		else if (BUS_ERROR(ec))
			pr_cont(": %s/ECC error in data read from NB: %s.\n",
698
				R4_MSG(ec), PP_MSG(ec));
699
		else if (MEM_ERROR(ec)) {
700
			u8 r4 = R4(ec);
701

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

715
	return ret;
716 717
}

718
static bool f15h_mc2_mce(u16 ec, u8 xec)
719
{
720
	bool ret = true;
721 722 723 724 725 726 727

	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
728
			ret = false;
729 730
	} else if (BUS_ERROR(ec)) {
		if (xec > 2)
731
			ret = false;
732 733 734 735 736

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

		case 0x10 ... 0x14:
741
			pr_cont("%s.\n", f15h_mc2_mce_desc[xec - 0x7]);
742 743 744
			break;

		default:
745
			ret = false;
746
		}
747 748 749 750 751
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x3f)
			pr_cont("Hardware Assert.\n");
		else
			ret = false;
752 753
	}

754 755 756
	return ret;
}

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 794 795 796 797
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;
}

798 799 800 801
static void decode_mc2_mce(struct mce *m)
{
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
802

803 804 805 806
	pr_emerg(HW_ERR "MC2 Error: ");

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

809
static void decode_mc3_mce(struct mce *m)
810
{
811 812
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
813

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

820
	pr_emerg(HW_ERR "MC3 Error");
821 822

	if (xec == 0x0) {
823
		u8 r4 = R4(ec);
824

825
		if (!BUS_ERROR(ec) || (r4 != R4_DRD && r4 != R4_DWR))
826
			goto wrong_mc3_mce;
827

828
		pr_cont(" during %s.\n", R4_MSG(ec));
829
	} else
830
		goto wrong_mc3_mce;
831

832 833
	return;

834 835
 wrong_mc3_mce:
	pr_emerg(HW_ERR "Corrupted MC3 MCE info?\n");
836 837
}

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

846
	pr_emerg(HW_ERR "MC4 Error (node %d): ", node_id);
847

848 849
	switch (xec) {
	case 0x0 ... 0xe:
850

851 852 853
		/* special handling for DRAM ECCs */
		if (xec == 0x0 || xec == 0x8) {
			/* no ECCs on F11h */
854
			if (fam == 0x11)
855
				goto wrong_mc4_mce;
856

857
			pr_cont("%s.\n", mc4_mce_desc[xec]);
858

859 860
			if (decode_dram_ecc)
				decode_dram_ecc(node_id, m);
861 862
			return;
		}
863 864 865 866 867 868 869 870
		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
871
			goto wrong_mc4_mce;
872
		return;
873

874
	case 0x19:
875
		if (fam == 0x15 || fam == 0x16)
876 877
			pr_cont("Compute Unit Data Error.\n");
		else
878
			goto wrong_mc4_mce;
879
		return;
880

881
	case 0x1c ... 0x1f:
882
		offset = 13;
883 884 885
		break;

	default:
886
		goto wrong_mc4_mce;
887
	}
888

889
	pr_cont("%s.\n", mc4_mce_desc[xec - offset]);
890 891
	return;

892 893
 wrong_mc4_mce:
	pr_emerg(HW_ERR "Corrupted MC4 MCE info?\n");
894 895
}

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

902
	if (fam == 0xf || fam == 0x11)
903
		goto wrong_mc5_mce;
B
Borislav Petkov 已提交
904

905
	pr_emerg(HW_ERR "MC5 Error: ");
906

907 908 909 910 911 912 913 914
	if (INT_ERROR(ec)) {
		if (xec <= 0x1f) {
			pr_cont("Hardware Assert.\n");
			return;
		} else
			goto wrong_mc5_mce;
	}

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

	return;
B
Borislav Petkov 已提交
923

924 925
 wrong_mc5_mce:
	pr_emerg(HW_ERR "Corrupted MC5 MCE info?\n");
B
Borislav Petkov 已提交
926 927
}

928
static void decode_mc6_mce(struct mce *m)
929
{
930
	u8 xec = XEC(m->status, xec_mask);
931

932
	pr_emerg(HW_ERR "MC6 Error: ");
933

934
	if (xec > 0x5)
935
		goto wrong_mc6_mce;
936

937
	pr_cont("%s parity error.\n", mc6_mce_desc[xec]);
938 939
	return;

940 941
 wrong_mc6_mce:
	pr_emerg(HW_ERR "Corrupted MC6 MCE info?\n");
942 943
}

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

952
	if (m->bank >= ARRAY_SIZE(smca_banks))
953 954
		return;

955 956
	hwid = smca_banks[m->bank].hwid;
	if (!hwid)
957 958
		return;

959
	bank_type = hwid->bank_type;
960 961 962 963 964 965

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

B
Borislav Petkov 已提交
966
	ip_name = smca_get_long_name(bank_type);
967

968
	pr_emerg(HW_ERR "%s Ext. Error Code: %d", ip_name, xec);
969

970 971
	/* Only print the decode of valid error codes */
	if (xec < smca_mce_descs[bank_type].num_descs &&
972
			(hwid->xec_bitmap & BIT_ULL(xec))) {
973
		pr_cont(", %s.\n", smca_mce_descs[bank_type].descs[xec]);
974
	}
975 976

	if (bank_type == SMCA_UMC && xec == 0 && decode_dram_ecc)
977
		decode_dram_ecc(cpu_to_node(m->extcpu), m);
978 979
}

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

	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");
1002 1003
}

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

	return false;
}

B
Borislav Petkov 已提交
1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028
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)
1029
		return "Deferred error, no action required.";
B
Borislav Petkov 已提交
1030 1031 1032 1033

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

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

1041
	if (ignore_mce(m))
1042 1043
		return NOTIFY_STOP;

1044 1045 1046 1047
	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,
1048
		fam, x86_model(m->cpuid), x86_stepping(m->cpuid),
1049 1050
		m->bank,
		((m->status & MCI_STATUS_OVER)	? "Over"  : "-"),
1051 1052
		((m->status & MCI_STATUS_UC)	? "UE"	  :
		 (m->status & MCI_STATUS_DEFERRED) ? "-"  : "CE"),
1053
		((m->status & MCI_STATUS_MISCV)	? "MiscV" : "-"),
1054 1055
		((m->status & MCI_STATUS_ADDRV)	? "AddrV" : "-"),
		((m->status & MCI_STATUS_PCC)	? "PCC"	  : "-"));
1056

1057
	if (boot_cpu_has(X86_FEATURE_SMCA)) {
1058 1059 1060 1061 1062 1063
		u32 low, high;
		u32 addr = MSR_AMD64_SMCA_MCx_CONFIG(m->bank);

		if (!rdmsr_safe(addr, &low, &high) &&
		    (low & MCI_CONFIG_MCAX))
			pr_cont("|%s", ((m->status & MCI_STATUS_TCC) ? "TCC" : "-"));
1064 1065

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

1068 1069 1070 1071 1072
	/* do the two bits[14:13] together */
	ecc = (m->status >> 45) & 0x3;
	if (ecc)
		pr_cont("|%sECC", ((ecc == 2) ? "C" : "U"));

1073 1074 1075 1076 1077 1078 1079 1080
	if (fam >= 0x15) {
		pr_cont("|%s", (m->status & MCI_STATUS_DEFERRED ? "Deferred" : "-"));

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

1081 1082 1083
	if (fam >= 0x17)
		pr_cont("|%s", (m->status & MCI_STATUS_SCRUB ? "Scrub" : "-"));

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

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

1089
	if (boot_cpu_has(X86_FEATURE_SMCA)) {
1090 1091
		pr_emerg(HW_ERR "IPID: 0x%016llx", m->ipid);

1092 1093 1094 1095 1096
		if (m->status & MCI_STATUS_SYNDV)
			pr_cont(", Syndrome: 0x%016llx", m->synd);

		pr_cont("\n");

1097
		decode_smca_error(m);
1098
		goto err_code;
1099
	}
1100

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

1104 1105 1106
	if (!fam_ops)
		goto err_code;

1107 1108
	switch (m->bank) {
	case 0:
1109
		decode_mc0_mce(m);
1110
		break;
1111

1112
	case 1:
1113
		decode_mc1_mce(m);
1114 1115
		break;

1116
	case 2:
1117
		decode_mc2_mce(m);
1118 1119
		break;

1120
	case 3:
1121
		decode_mc3_mce(m);
1122 1123
		break;

1124
	case 4:
1125
		decode_mc4_mce(m);
1126 1127
		break;

B
Borislav Petkov 已提交
1128
	case 5:
1129
		decode_mc5_mce(m);
B
Borislav Petkov 已提交
1130 1131
		break;

1132
	case 6:
1133
		decode_mc6_mce(m);
1134 1135
		break;

1136 1137
	default:
		break;
1138
	}
1139

1140
 err_code:
1141
	amd_decode_err_code(m->status & 0xffff);
1142 1143

	return NOTIFY_STOP;
1144
}
1145

1146 1147
static struct notifier_block amd_mce_dec_nb = {
	.notifier_call	= amd_decode_mce,
1148
	.priority	= MCE_PRIO_EDAC,
1149 1150
};

1151 1152
static int __init mce_amd_init(void)
{
1153 1154
	struct cpuinfo_x86 *c = &boot_cpu_data;

P
Pu Wen 已提交
1155 1156
	if (c->x86_vendor != X86_VENDOR_AMD &&
	    c->x86_vendor != X86_VENDOR_HYGON)
1157
		return -ENODEV;
1158

1159 1160 1161 1162
	fam_ops = kzalloc(sizeof(struct amd_decoder_ops), GFP_KERNEL);
	if (!fam_ops)
		return -ENOMEM;

1163
	switch (c->x86) {
1164
	case 0xf:
1165 1166
		fam_ops->mc0_mce = k8_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1167
		fam_ops->mc2_mce = k8_mc2_mce;
1168 1169 1170
		break;

	case 0x10:
1171 1172
		fam_ops->mc0_mce = f10h_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1173
		fam_ops->mc2_mce = k8_mc2_mce;
1174 1175
		break;

1176
	case 0x11:
1177 1178
		fam_ops->mc0_mce = k8_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1179
		fam_ops->mc2_mce = k8_mc2_mce;
1180 1181
		break;

1182
	case 0x12:
1183 1184
		fam_ops->mc0_mce = f12h_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1185
		fam_ops->mc2_mce = k8_mc2_mce;
1186 1187
		break;

1188
	case 0x14:
1189 1190
		fam_ops->mc0_mce = cat_mc0_mce;
		fam_ops->mc1_mce = cat_mc1_mce;
1191
		fam_ops->mc2_mce = k8_mc2_mce;
1192 1193
		break;

1194
	case 0x15:
1195 1196
		xec_mask = c->x86_model == 0x60 ? 0x3f : 0x1f;

1197 1198
		fam_ops->mc0_mce = f15h_mc0_mce;
		fam_ops->mc1_mce = f15h_mc1_mce;
1199
		fam_ops->mc2_mce = f15h_mc2_mce;
1200 1201
		break;

1202 1203 1204 1205 1206 1207 1208
	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;

1209
	case 0x17:
P
Pu Wen 已提交
1210
	case 0x18:
1211
		xec_mask = 0x3f;
1212
		if (!boot_cpu_has(X86_FEATURE_SMCA)) {
1213 1214 1215 1216 1217
			printk(KERN_WARNING "Decoding supported only on Scalable MCA processors.\n");
			goto err_out;
		}
		break;

1218
	default:
1219
		printk(KERN_WARNING "Huh? What family is it: 0x%x?!\n", c->x86);
1220
		goto err_out;
1221 1222
	}

1223 1224
	pr_info("MCE: In-kernel MCE decoding enabled.\n");

1225
	mce_register_decode_chain(&amd_mce_dec_nb);
1226 1227

	return 0;
1228 1229 1230 1231 1232

err_out:
	kfree(fam_ops);
	fam_ops = NULL;
	return -EINVAL;
1233 1234
}
early_initcall(mce_amd_init);
1235 1236 1237 1238

#ifdef MODULE
static void __exit mce_amd_exit(void)
{
1239
	mce_unregister_decode_chain(&amd_mce_dec_nb);
1240
	kfree(fam_ops);
1241 1242 1243 1244 1245 1246 1247
}

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