mce_amd.c 24.5 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
static const char * const smca_pie_mce_desc[] = {
261 262 263 264 265 266
	"HW assert",
	"Internal PIE register security violation",
	"Error on GMI link",
	"Poison data written to internal PIE register",
};

267
static const char * const smca_umc_mce_desc[] = {
268 269 270 271 272 273 274 275
	"DRAM ECC error",
	"Data poison error on DRAM",
	"SDP parity error",
	"Advanced peripheral bus error",
	"Command/address parity error",
	"Write data CRC error",
};

276
static const char * const smca_pb_mce_desc[] = {
277 278 279
	"Parameter Block RAM ECC error",
};

280
static const char * const smca_psp_mce_desc[] = {
281 282 283
	"PSP RAM ECC or parity error",
};

284
static const char * const smca_smu_mce_desc[] = {
285 286 287
	"SMU RAM ECC or parity error",
};

288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308
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)	},
	[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)	},
	[SMCA_SMU]	= { smca_smu_mce_desc,	ARRAY_SIZE(smca_smu_mce_desc)	},
};

309
static bool f12h_mc0_mce(u16 ec, u8 xec)
310
{
311
	bool ret = false;
312

313
	if (MEM_ERROR(ec)) {
314
		u8 ll = LL(ec);
315
		ret = true;
316

317 318 319
		if (ll == LL_L2)
			pr_cont("during L1 linefill from L2.\n");
		else if (ll == LL_L1)
320
			pr_cont("Data/Tag %s error.\n", R4_MSG(ec));
321 322 323 324 325
		else
			ret = false;
	}
	return ret;
}
326

327
static bool f10h_mc0_mce(u16 ec, u8 xec)
328
{
329
	if (R4(ec) == R4_GEN && LL(ec) == LL_L1) {
330 331 332
		pr_cont("during data scrub.\n");
		return true;
	}
333
	return f12h_mc0_mce(ec, xec);
334 335
}

336
static bool k8_mc0_mce(u16 ec, u8 xec)
337 338 339 340 341
{
	if (BUS_ERROR(ec)) {
		pr_cont("during system linefill.\n");
		return true;
	}
342

343
	return f10h_mc0_mce(ec, xec);
344 345
}

346
static bool cat_mc0_mce(u16 ec, u8 xec)
347
{
348
	u8 r4	 = R4(ec);
349 350 351 352
	bool ret = true;

	if (MEM_ERROR(ec)) {

353
		if (TT(ec) != TT_DATA || LL(ec) != LL_L1)
354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372
			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)) {

373
		if ((II(ec) != II_MEM && II(ec) != II_IO) || LL(ec) != LL_LG)
374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397
			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;
}

398
static bool f15h_mc0_mce(u16 ec, u8 xec)
399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435
{
	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)
436
			pr_cont("System Read Data Error.\n");
437
		else
438
			pr_cont(" Internal error condition type %d.\n", xec);
439 440 441 442 443 444
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x1f)
			pr_cont("Hardware Assert.\n");
		else
			ret = false;

445 446 447 448 449 450
	} else
		ret = false;

	return ret;
}

451
static void decode_mc0_mce(struct mce *m)
452
{
453 454
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
455

456
	pr_emerg(HW_ERR "MC0 Error: ");
457 458 459

	/* TLB error signatures are the same across families */
	if (TLB_ERROR(ec)) {
460
		if (TT(ec) == TT_DATA) {
461
			pr_cont("%s TLB %s.\n", LL_MSG(ec),
462 463
				((xec == 2) ? "locked miss"
					    : (xec ? "multimatch" : "parity")));
464 465
			return;
		}
466
	} else if (fam_ops->mc0_mce(ec, xec))
467 468
		;
	else
469
		pr_emerg(HW_ERR "Corrupted MC0 MCE info?\n");
470 471
}

472
static bool k8_mc1_mce(u16 ec, u8 xec)
473
{
474
	u8 ll	 = LL(ec);
475
	bool ret = true;
476

477 478
	if (!MEM_ERROR(ec))
		return false;
479

480 481 482
	if (ll == 0x2)
		pr_cont("during a linefill from L2.\n");
	else if (ll == 0x1) {
483
		switch (R4(ec)) {
484 485 486
		case R4_IRD:
			pr_cont("Parity error during data load.\n");
			break;
487

488 489 490 491 492 493 494 495 496 497 498 499
		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;
		}
500
	} else
501
		ret = false;
502

503 504 505
	return ret;
}

506
static bool cat_mc1_mce(u16 ec, u8 xec)
507
{
508
	u8 r4    = R4(ec);
509
	bool ret = true;
510

511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526
	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;
527 528 529 530

	return ret;
}

531
static bool f15h_mc1_mce(u16 ec, u8 xec)
532 533 534 535 536 537 538 539
{
	bool ret = true;

	if (!MEM_ERROR(ec))
		return false;

	switch (xec) {
	case 0x0 ... 0xa:
540
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec]);
541 542 543
		break;

	case 0xd:
544
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec-2]);
545 546
		break;

547
	case 0x10:
548
		pr_cont("%s.\n", f15h_mc1_mce_desc[xec-4]);
549 550
		break;

551
	case 0x11 ... 0x15:
552
		pr_cont("Decoder %s parity error.\n", f15h_mc1_mce_desc[xec-4]);
553 554 555 556 557 558 559 560
		break;

	default:
		ret = false;
	}
	return ret;
}

561
static void decode_mc1_mce(struct mce *m)
562
{
563 564
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
565

566
	pr_emerg(HW_ERR "MC1 Error: ");
567 568 569 570 571

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

		pr_cont("during %s.\n", (k8 ? "system linefill" : "NB data read"));
575 576 577 578 579
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x3f)
			pr_cont("Hardware Assert.\n");
		else
			goto wrong_mc1_mce;
580
	} else if (fam_ops->mc1_mce(ec, xec))
581 582
		;
	else
583 584 585 586 587 588
		goto wrong_mc1_mce;

	return;

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

591
static bool k8_mc2_mce(u16 ec, u8 xec)
592
{
593
	bool ret = true;
594 595 596 597 598 599

	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))
600
		pr_cont(": %s error in the L2 cache tags.\n", R4_MSG(ec));
601 602
	else if (xec == 0x0) {
		if (TLB_ERROR(ec))
603 604
			pr_cont("%s error in a Page Descriptor Cache or Guest TLB.\n",
				TT_MSG(ec));
605 606
		else if (BUS_ERROR(ec))
			pr_cont(": %s/ECC error in data read from NB: %s.\n",
607
				R4_MSG(ec), PP_MSG(ec));
608
		else if (MEM_ERROR(ec)) {
609
			u8 r4 = R4(ec);
610

611
			if (r4 >= 0x7)
612
				pr_cont(": %s error during data copyback.\n",
613 614
					R4_MSG(ec));
			else if (r4 <= 0x1)
615
				pr_cont(": %s parity/ECC error during data "
616
					"access from L2.\n", R4_MSG(ec));
617
			else
618
				ret = false;
619
		} else
620
			ret = false;
621
	} else
622
		ret = false;
623

624
	return ret;
625 626
}

627
static bool f15h_mc2_mce(u16 ec, u8 xec)
628
{
629
	bool ret = true;
630 631 632 633 634 635 636

	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
637
			ret = false;
638 639
	} else if (BUS_ERROR(ec)) {
		if (xec > 2)
640
			ret = false;
641 642 643 644 645

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

		case 0x10 ... 0x14:
650
			pr_cont("%s.\n", f15h_mc2_mce_desc[xec - 0x7]);
651 652 653
			break;

		default:
654
			ret = false;
655
		}
656 657 658 659 660
	} else if (INT_ERROR(ec)) {
		if (xec <= 0x3f)
			pr_cont("Hardware Assert.\n");
		else
			ret = false;
661 662
	}

663 664 665
	return ret;
}

666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706
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;
}

707 708 709 710
static void decode_mc2_mce(struct mce *m)
{
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
711

712 713 714 715
	pr_emerg(HW_ERR "MC2 Error: ");

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

718
static void decode_mc3_mce(struct mce *m)
719
{
720 721
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, xec_mask);
722

723
	if (boot_cpu_data.x86 >= 0x14) {
724
		pr_emerg("You shouldn't be seeing MC3 MCE on this cpu family,"
725 726 727
			 " please report on LKML.\n");
		return;
	}
728

729
	pr_emerg(HW_ERR "MC3 Error");
730 731

	if (xec == 0x0) {
732
		u8 r4 = R4(ec);
733

734
		if (!BUS_ERROR(ec) || (r4 != R4_DRD && r4 != R4_DWR))
735
			goto wrong_mc3_mce;
736

737
		pr_cont(" during %s.\n", R4_MSG(ec));
738
	} else
739
		goto wrong_mc3_mce;
740

741 742
	return;

743 744
 wrong_mc3_mce:
	pr_emerg(HW_ERR "Corrupted MC3 MCE info?\n");
745 746
}

747
static void decode_mc4_mce(struct mce *m)
748
{
749
	unsigned int fam = x86_family(m->cpuid);
750 751 752 753
	int node_id = amd_get_nb_id(m->extcpu);
	u16 ec = EC(m->status);
	u8 xec = XEC(m->status, 0x1f);
	u8 offset = 0;
754

755
	pr_emerg(HW_ERR "MC4 Error (node %d): ", node_id);
756

757 758
	switch (xec) {
	case 0x0 ... 0xe:
759

760 761 762
		/* special handling for DRAM ECCs */
		if (xec == 0x0 || xec == 0x8) {
			/* no ECCs on F11h */
763
			if (fam == 0x11)
764
				goto wrong_mc4_mce;
765

766
			pr_cont("%s.\n", mc4_mce_desc[xec]);
767

768 769
			if (decode_dram_ecc)
				decode_dram_ecc(node_id, m);
770 771
			return;
		}
772 773 774 775 776 777 778 779
		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
780
			goto wrong_mc4_mce;
781
		return;
782

783
	case 0x19:
784
		if (fam == 0x15 || fam == 0x16)
785 786
			pr_cont("Compute Unit Data Error.\n");
		else
787
			goto wrong_mc4_mce;
788
		return;
789

790
	case 0x1c ... 0x1f:
791
		offset = 13;
792 793 794
		break;

	default:
795
		goto wrong_mc4_mce;
796
	}
797

798
	pr_cont("%s.\n", mc4_mce_desc[xec - offset]);
799 800
	return;

801 802
 wrong_mc4_mce:
	pr_emerg(HW_ERR "Corrupted MC4 MCE info?\n");
803 804
}

805
static void decode_mc5_mce(struct mce *m)
B
Borislav Petkov 已提交
806
{
807
	unsigned int fam = x86_family(m->cpuid);
808
	u16 ec = EC(m->status);
809
	u8 xec = XEC(m->status, xec_mask);
810

811
	if (fam == 0xf || fam == 0x11)
812
		goto wrong_mc5_mce;
B
Borislav Petkov 已提交
813

814
	pr_emerg(HW_ERR "MC5 Error: ");
815

816 817 818 819 820 821 822 823
	if (INT_ERROR(ec)) {
		if (xec <= 0x1f) {
			pr_cont("Hardware Assert.\n");
			return;
		} else
			goto wrong_mc5_mce;
	}

824
	if (xec == 0x0 || xec == 0xc)
825
		pr_cont("%s.\n", mc5_mce_desc[xec]);
826
	else if (xec <= 0xd)
827
		pr_cont("%s parity error.\n", mc5_mce_desc[xec]);
828
	else
829
		goto wrong_mc5_mce;
830 831

	return;
B
Borislav Petkov 已提交
832

833 834
 wrong_mc5_mce:
	pr_emerg(HW_ERR "Corrupted MC5 MCE info?\n");
B
Borislav Petkov 已提交
835 836
}

837
static void decode_mc6_mce(struct mce *m)
838
{
839
	u8 xec = XEC(m->status, xec_mask);
840

841
	pr_emerg(HW_ERR "MC6 Error: ");
842

843
	if (xec > 0x5)
844
		goto wrong_mc6_mce;
845

846
	pr_cont("%s parity error.\n", mc6_mce_desc[xec]);
847 848
	return;

849 850
 wrong_mc6_mce:
	pr_emerg(HW_ERR "Corrupted MC6 MCE info?\n");
851 852
}

853
/* Decode errors according to Scalable MCA specification */
854
static void decode_smca_error(struct mce *m)
855
{
856
	struct smca_hwid *hwid;
857
	unsigned int bank_type;
858
	const char *ip_name;
859
	u8 xec = XEC(m->status, xec_mask);
860

861
	if (m->bank >= ARRAY_SIZE(smca_banks))
862 863
		return;

864
	if (x86_family(m->cpuid) >= 0x17 && m->bank == 4)
865 866
		pr_emerg(HW_ERR "Bank 4 is reserved on Fam17h.\n");

867 868
	hwid = smca_banks[m->bank].hwid;
	if (!hwid)
869 870
		return;

871
	bank_type = hwid->bank_type;
B
Borislav Petkov 已提交
872
	ip_name = smca_get_long_name(bank_type);
873

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

876 877
	/* Only print the decode of valid error codes */
	if (xec < smca_mce_descs[bank_type].num_descs &&
878
			(hwid->xec_bitmap & BIT_ULL(xec))) {
879 880 881
		pr_emerg(HW_ERR "%s Error: ", ip_name);
		pr_cont("%s.\n", smca_mce_descs[bank_type].descs[xec]);
	}
882 883

	if (bank_type == SMCA_UMC && xec == 0 && decode_dram_ecc)
884
		decode_dram_ecc(cpu_to_node(m->extcpu), m);
885 886
}

B
Borislav Petkov 已提交
887
static inline void amd_decode_err_code(u16 ec)
888
{
889 890 891 892
	if (INT_ERROR(ec)) {
		pr_emerg(HW_ERR "internal: %s\n", UU_MSG(ec));
		return;
	}
893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908

	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");
909 910
}

911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926
/*
 * Filter out unwanted MCE signatures here.
 */
static bool amd_filter_mce(struct mce *m)
{
	u8 xec = (m->status >> 16) & 0x1f;

	/*
	 * NB GART TLB error reporting is disabled by default.
	 */
	if (m->bank == 4 && xec == 0x5 && !report_gart_errors)
		return true;

	return false;
}

B
Borislav Petkov 已提交
927 928 929 930 931 932 933 934 935 936 937
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)
938
		return "Deferred error, no action required.";
B
Borislav Petkov 已提交
939 940 941 942

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

943 944
static int
amd_decode_mce(struct notifier_block *nb, unsigned long val, void *data)
945
{
946
	struct mce *m = (struct mce *)data;
947
	unsigned int fam = x86_family(m->cpuid);
948
	int ecc;
949

950 951 952
	if (amd_filter_mce(m))
		return NOTIFY_STOP;

953 954 955 956
	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,
957
		fam, x86_model(m->cpuid), x86_stepping(m->cpuid),
958 959
		m->bank,
		((m->status & MCI_STATUS_OVER)	? "Over"  : "-"),
960 961
		((m->status & MCI_STATUS_UC)	? "UE"	  :
		 (m->status & MCI_STATUS_DEFERRED) ? "-"  : "CE"),
962 963 964 965
		((m->status & MCI_STATUS_MISCV)	? "MiscV" : "-"),
		((m->status & MCI_STATUS_PCC)	? "PCC"	  : "-"),
		((m->status & MCI_STATUS_ADDRV)	? "AddrV" : "-"));

966
	if (fam >= 0x15) {
967 968 969
		pr_cont("|%s", (m->status & MCI_STATUS_DEFERRED ? "Deferred" : "-"));

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

974
	if (boot_cpu_has(X86_FEATURE_SMCA)) {
975 976 977
		u32 low, high;
		u32 addr = MSR_AMD64_SMCA_MCx_CONFIG(m->bank);

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

980 981 982 983 984
		if (!rdmsr_safe(addr, &low, &high) &&
		    (low & MCI_CONFIG_MCAX))
			pr_cont("|%s", ((m->status & MCI_STATUS_TCC) ? "TCC" : "-"));
	}

985 986 987 988 989 990 991 992
	/* 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)
993
		pr_emerg(HW_ERR "Error Addr: 0x%016llx\n", m->addr);
994

995
	if (boot_cpu_has(X86_FEATURE_SMCA)) {
996 997
		pr_emerg(HW_ERR "IPID: 0x%016llx", m->ipid);

998 999 1000 1001 1002
		if (m->status & MCI_STATUS_SYNDV)
			pr_cont(", Syndrome: 0x%016llx", m->synd);

		pr_cont("\n");

1003
		decode_smca_error(m);
1004
		goto err_code;
1005
	}
1006

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

1010 1011 1012
	if (!fam_ops)
		goto err_code;

1013 1014
	switch (m->bank) {
	case 0:
1015
		decode_mc0_mce(m);
1016
		break;
1017

1018
	case 1:
1019
		decode_mc1_mce(m);
1020 1021
		break;

1022
	case 2:
1023
		decode_mc2_mce(m);
1024 1025
		break;

1026
	case 3:
1027
		decode_mc3_mce(m);
1028 1029
		break;

1030
	case 4:
1031
		decode_mc4_mce(m);
1032 1033
		break;

B
Borislav Petkov 已提交
1034
	case 5:
1035
		decode_mc5_mce(m);
B
Borislav Petkov 已提交
1036 1037
		break;

1038
	case 6:
1039
		decode_mc6_mce(m);
1040 1041
		break;

1042 1043
	default:
		break;
1044
	}
1045

1046
 err_code:
1047
	amd_decode_err_code(m->status & 0xffff);
1048 1049

	return NOTIFY_STOP;
1050
}
1051

1052 1053
static struct notifier_block amd_mce_dec_nb = {
	.notifier_call	= amd_decode_mce,
1054
	.priority	= MCE_PRIO_EDAC,
1055 1056
};

1057 1058
static int __init mce_amd_init(void)
{
1059 1060 1061
	struct cpuinfo_x86 *c = &boot_cpu_data;

	if (c->x86_vendor != X86_VENDOR_AMD)
1062
		return -ENODEV;
1063

1064 1065 1066 1067
	fam_ops = kzalloc(sizeof(struct amd_decoder_ops), GFP_KERNEL);
	if (!fam_ops)
		return -ENOMEM;

1068
	switch (c->x86) {
1069
	case 0xf:
1070 1071
		fam_ops->mc0_mce = k8_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1072
		fam_ops->mc2_mce = k8_mc2_mce;
1073 1074 1075
		break;

	case 0x10:
1076 1077
		fam_ops->mc0_mce = f10h_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1078
		fam_ops->mc2_mce = k8_mc2_mce;
1079 1080
		break;

1081
	case 0x11:
1082 1083
		fam_ops->mc0_mce = k8_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1084
		fam_ops->mc2_mce = k8_mc2_mce;
1085 1086
		break;

1087
	case 0x12:
1088 1089
		fam_ops->mc0_mce = f12h_mc0_mce;
		fam_ops->mc1_mce = k8_mc1_mce;
1090
		fam_ops->mc2_mce = k8_mc2_mce;
1091 1092
		break;

1093
	case 0x14:
1094 1095
		fam_ops->mc0_mce = cat_mc0_mce;
		fam_ops->mc1_mce = cat_mc1_mce;
1096
		fam_ops->mc2_mce = k8_mc2_mce;
1097 1098
		break;

1099
	case 0x15:
1100 1101
		xec_mask = c->x86_model == 0x60 ? 0x3f : 0x1f;

1102 1103
		fam_ops->mc0_mce = f15h_mc0_mce;
		fam_ops->mc1_mce = f15h_mc1_mce;
1104
		fam_ops->mc2_mce = f15h_mc2_mce;
1105 1106
		break;

1107 1108 1109 1110 1111 1112 1113
	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;

1114 1115
	case 0x17:
		xec_mask = 0x3f;
1116
		if (!boot_cpu_has(X86_FEATURE_SMCA)) {
1117 1118 1119 1120 1121
			printk(KERN_WARNING "Decoding supported only on Scalable MCA processors.\n");
			goto err_out;
		}
		break;

1122
	default:
1123
		printk(KERN_WARNING "Huh? What family is it: 0x%x?!\n", c->x86);
1124
		goto err_out;
1125 1126
	}

1127 1128
	pr_info("MCE: In-kernel MCE decoding enabled.\n");

1129
	mce_register_decode_chain(&amd_mce_dec_nb);
1130 1131

	return 0;
1132 1133 1134 1135 1136

err_out:
	kfree(fam_ops);
	fam_ops = NULL;
	return -EINVAL;
1137 1138
}
early_initcall(mce_amd_init);
1139 1140 1141 1142

#ifdef MODULE
static void __exit mce_amd_exit(void)
{
1143
	mce_unregister_decode_chain(&amd_mce_dec_nb);
1144
	kfree(fam_ops);
1145 1146 1147 1148 1149 1150 1151
}

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