提交 6144c0f5 编写于 作者: Y Yazen Ghannam 提交者: Caspar Zhang

EDAC/amd64: Use a macro for iterating over Unified Memory Controllers

commit 4d30d2bc3c23e63c2608bc5b03b0960490d5b740 upstream.

Define and use a macro for looping over the number of Unified Memory
Controllers.

No functional change.
Signed-off-by: NYazen Ghannam <yazen.ghannam@amd.com>
Signed-off-by: NBorislav Petkov <bp@suse.de>
Tested-by: NKim Phillips <kim.phillips@amd.com>
Cc: James Morse <james.morse@arm.com>
Cc: Mauro Carvalho Chehab <mchehab@kernel.org>
Cc: linux-edac <linux-edac@vger.kernel.org>
Link: https://lkml.kernel.org/r/20190228153558.127292-2-Yazen.Ghannam@amd.comSigned-off-by: NWANG Siyuan <Siyuan.Wang@amd.com>
Acked-by: NCaspar Zhang <caspar@linux.alibaba.com>
上级 efff4c14
...@@ -448,6 +448,9 @@ static void get_cs_base_and_mask(struct amd64_pvt *pvt, int csrow, u8 dct, ...@@ -448,6 +448,9 @@ static void get_cs_base_and_mask(struct amd64_pvt *pvt, int csrow, u8 dct,
#define for_each_chip_select_mask(i, dct, pvt) \ #define for_each_chip_select_mask(i, dct, pvt) \
for (i = 0; i < pvt->csels[dct].m_cnt; i++) for (i = 0; i < pvt->csels[dct].m_cnt; i++)
#define for_each_umc(i) \
for (i = 0; i < NUM_UMCS; i++)
/* /*
* @input_addr is an InputAddr associated with the node given by mci. Return the * @input_addr is an InputAddr associated with the node given by mci. Return the
* csrow that input_addr maps to, or -1 on failure (no csrow claims input_addr). * csrow that input_addr maps to, or -1 on failure (no csrow claims input_addr).
...@@ -721,7 +724,7 @@ static unsigned long determine_edac_cap(struct amd64_pvt *pvt) ...@@ -721,7 +724,7 @@ static unsigned long determine_edac_cap(struct amd64_pvt *pvt)
if (pvt->umc) { if (pvt->umc) {
u8 i, umc_en_mask = 0, dimm_ecc_en_mask = 0; u8 i, umc_en_mask = 0, dimm_ecc_en_mask = 0;
for (i = 0; i < NUM_UMCS; i++) { for_each_umc(i) {
if (!(pvt->umc[i].sdp_ctrl & UMC_SDP_INIT)) if (!(pvt->umc[i].sdp_ctrl & UMC_SDP_INIT))
continue; continue;
...@@ -810,7 +813,7 @@ static void __dump_misc_regs_df(struct amd64_pvt *pvt) ...@@ -810,7 +813,7 @@ static void __dump_misc_regs_df(struct amd64_pvt *pvt)
struct amd64_umc *umc; struct amd64_umc *umc;
u32 i, tmp, umc_base; u32 i, tmp, umc_base;
for (i = 0; i < NUM_UMCS; i++) { for_each_umc(i) {
umc_base = get_umc_base(i); umc_base = get_umc_base(i);
umc = &pvt->umc[i]; umc = &pvt->umc[i];
...@@ -1386,7 +1389,7 @@ static int f17_early_channel_count(struct amd64_pvt *pvt) ...@@ -1386,7 +1389,7 @@ static int f17_early_channel_count(struct amd64_pvt *pvt)
int i, channels = 0; int i, channels = 0;
/* SDP Control bit 31 (SdpInit) is clear for unused UMC channels */ /* SDP Control bit 31 (SdpInit) is clear for unused UMC channels */
for (i = 0; i < NUM_UMCS; i++) for_each_umc(i)
channels += !!(pvt->umc[i].sdp_ctrl & UMC_SDP_INIT); channels += !!(pvt->umc[i].sdp_ctrl & UMC_SDP_INIT);
amd64_info("MCT channel count: %d\n", channels); amd64_info("MCT channel count: %d\n", channels);
...@@ -2610,7 +2613,7 @@ static void determine_ecc_sym_sz(struct amd64_pvt *pvt) ...@@ -2610,7 +2613,7 @@ static void determine_ecc_sym_sz(struct amd64_pvt *pvt)
if (pvt->umc) { if (pvt->umc) {
u8 i; u8 i;
for (i = 0; i < NUM_UMCS; i++) { for_each_umc(i) {
/* Check enabled channels only: */ /* Check enabled channels only: */
if ((pvt->umc[i].sdp_ctrl & UMC_SDP_INIT) && if ((pvt->umc[i].sdp_ctrl & UMC_SDP_INIT) &&
(pvt->umc[i].ecc_ctrl & BIT(7))) { (pvt->umc[i].ecc_ctrl & BIT(7))) {
...@@ -2646,7 +2649,7 @@ static void __read_mc_regs_df(struct amd64_pvt *pvt) ...@@ -2646,7 +2649,7 @@ static void __read_mc_regs_df(struct amd64_pvt *pvt)
u32 i, umc_base; u32 i, umc_base;
/* Read registers from each UMC */ /* Read registers from each UMC */
for (i = 0; i < NUM_UMCS; i++) { for_each_umc(i) {
umc_base = get_umc_base(i); umc_base = get_umc_base(i);
umc = &pvt->umc[i]; umc = &pvt->umc[i];
...@@ -3059,7 +3062,7 @@ static bool ecc_enabled(struct pci_dev *F3, u16 nid) ...@@ -3059,7 +3062,7 @@ static bool ecc_enabled(struct pci_dev *F3, u16 nid)
if (boot_cpu_data.x86 >= 0x17) { if (boot_cpu_data.x86 >= 0x17) {
u8 umc_en_mask = 0, ecc_en_mask = 0; u8 umc_en_mask = 0, ecc_en_mask = 0;
for (i = 0; i < NUM_UMCS; i++) { for_each_umc(i) {
u32 base = get_umc_base(i); u32 base = get_umc_base(i);
/* Only check enabled UMCs. */ /* Only check enabled UMCs. */
...@@ -3112,7 +3115,7 @@ f17h_determine_edac_ctl_cap(struct mem_ctl_info *mci, struct amd64_pvt *pvt) ...@@ -3112,7 +3115,7 @@ f17h_determine_edac_ctl_cap(struct mem_ctl_info *mci, struct amd64_pvt *pvt)
{ {
u8 i, ecc_en = 1, cpk_en = 1, dev_x4 = 1, dev_x16 = 1; u8 i, ecc_en = 1, cpk_en = 1, dev_x4 = 1, dev_x16 = 1;
for (i = 0; i < NUM_UMCS; i++) { for_each_umc(i) {
if (pvt->umc[i].sdp_ctrl & UMC_SDP_INIT) { if (pvt->umc[i].sdp_ctrl & UMC_SDP_INIT) {
ecc_en &= !!(pvt->umc[i].umc_cap_hi & UMC_ECC_ENABLED); ecc_en &= !!(pvt->umc[i].umc_cap_hi & UMC_ECC_ENABLED);
cpk_en &= !!(pvt->umc[i].umc_cap_hi & UMC_ECC_CHIPKILL_CAP); cpk_en &= !!(pvt->umc[i].umc_cap_hi & UMC_ECC_CHIPKILL_CAP);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册