Angel Pons | ae59387 | 2020-04-04 18:50:57 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Martin Roth | 5c354b9 | 2019-04-22 14:55:16 -0600 | [diff] [blame] | 2 | |
Felix Held | f1093af | 2021-07-13 23:00:26 +0200 | [diff] [blame] | 3 | #include <amdblocks/mca.h> |
Martin Roth | 5c354b9 | 2019-04-22 14:55:16 -0600 | [diff] [blame] | 4 | #include <cpu/x86/msr.h> |
Felix Held | e0d9bf7 | 2021-07-14 00:20:46 +0200 | [diff] [blame] | 5 | #include <types.h> |
Martin Roth | 5c354b9 | 2019-04-22 14:55:16 -0600 | [diff] [blame] | 6 | |
Martin Roth | 5c354b9 | 2019-04-22 14:55:16 -0600 | [diff] [blame] | 7 | static const char *const mca_bank_name[] = { |
Felix Held | 799742a | 2021-07-13 20:54:01 +0200 | [diff] [blame] | 8 | [0] = "Load-store unit", |
| 9 | [1] = "Instruction fetch unit", |
| 10 | [2] = "L2 cache unit", |
| 11 | [3] = "Decode unit", |
| 12 | [4] = "", |
| 13 | [5] = "Execution unit", |
| 14 | [6] = "Floating point unit", |
| 15 | [7] = "L3 cache unit", |
| 16 | [8] = "L3 cache unit", |
| 17 | [9] = "L3 cache unit", |
| 18 | [10] = "L3 cache unit", |
| 19 | [11] = "L3 cache unit", |
| 20 | [12] = "L3 cache unit", |
| 21 | [13] = "L3 cache unit", |
| 22 | [14] = "L3 cache unit", |
| 23 | [15] = "UMC", |
| 24 | [16] = "UMC", |
| 25 | [17] = "SMU", |
| 26 | [18] = "PSP", |
| 27 | [19] = "PB", |
| 28 | [20] = "CS", |
| 29 | [21] = "CS", |
| 30 | [22] = "PIE", |
Martin Roth | 5c354b9 | 2019-04-22 14:55:16 -0600 | [diff] [blame] | 31 | }; |
| 32 | |
Felix Held | e84c3f1 | 2021-07-14 01:16:30 +0200 | [diff] [blame] | 33 | bool mca_has_expected_bank_count(void) |
Felix Held | 64077de | 2021-07-14 01:34:59 +0200 | [diff] [blame] | 34 | { |
| 35 | return ARRAY_SIZE(mca_bank_name) == mca_get_bank_count(); |
| 36 | } |
| 37 | |
Felix Held | e84c3f1 | 2021-07-14 01:16:30 +0200 | [diff] [blame] | 38 | bool mca_is_valid_bank(unsigned int bank) |
Felix Held | 040d764 | 2021-07-13 22:29:12 +0200 | [diff] [blame] | 39 | { |
| 40 | return (bank < ARRAY_SIZE(mca_bank_name) && mca_bank_name[bank] != NULL); |
| 41 | } |
| 42 | |
Felix Held | e84c3f1 | 2021-07-14 01:16:30 +0200 | [diff] [blame] | 43 | const char *mca_get_bank_name(unsigned int bank) |
Felix Held | b04148a | 2021-07-13 22:30:16 +0200 | [diff] [blame] | 44 | { |
| 45 | if (mca_is_valid_bank(bank)) |
| 46 | return mca_bank_name[bank]; |
| 47 | else |
| 48 | return ""; |
| 49 | } |