struct edac_device_ctl_info *edac_dev;
void __iomem *pmd_csr;
u32 pmd;
+ int version;
};
static void xgene_edac_pmd_l1_check(struct edac_device_ctl_info *edac_dev,
writel(0x00000101, pg_f + MEMERR_CPU_MMUECR_PAGE_OFFSET);
}
-static bool xgene_edac_pmd_l2c_version1(void)
-{
- /* Check all chips with PMD L2C version 1 HW */
- #define REVIDR_MINOR_REV(revidr) ((revidr) & 0x00000007)
-
- switch (MIDR_VARIANT(read_cpuid_id())) {
- case 0:
- switch (MIDR_REVISION(read_cpuid_id())) {
- case 0:
-
- switch (REVIDR_MINOR_REV(read_cpuid(REVIDR_EL1))) {
- case 1:
- case 2:
- return true;
- };
- break;
- case 1:
- if (REVIDR_MINOR_REV(read_cpuid(REVIDR_EL1)) == 1)
- return true;
- break;
- }
- break;
- case 1:
- switch (MIDR_REVISION(read_cpuid_id())) {
- case 0:
- switch (REVIDR_MINOR_REV(read_cpuid(REVIDR_EL1))) {
- case 1:
- return true;
- };
- break;
- case 1:
- switch (REVIDR_MINOR_REV(read_cpuid(REVIDR_EL1))) {
- case 1:
- case 0:
- return true;
- };
- break;
- }
- break;
- }
-
- return false;
-}
-
static void xgene_edac_pmd_hw_cfg(struct edac_device_ctl_info *edac_dev)
{
struct xgene_edac_pmd_ctx *ctx = edac_dev->pvt_info;
/* Enable PMD memory error - MEMERR_L2C_L2ECR and L2C_L2RTOCR */
writel(0x00000703, pg_e + MEMERR_L2C_L2ECR_PAGE_OFFSET);
/* Configure L2C HW request time out feature if supported */
- if (!xgene_edac_pmd_l2c_version1())
+ if (ctx->version > 1)
writel(0x00000119, pg_d + CPUX_L2C_L2RTOCR_PAGE_OFFSET);
}
return (efuse & (1 << pmd)) ? 0 : 1;
}
-static int xgene_edac_pmd_add(struct xgene_edac *edac, struct device_node *np)
+static int xgene_edac_pmd_add(struct xgene_edac *edac, struct device_node *np,
+ int version)
{
struct edac_device_ctl_info *edac_dev;
struct xgene_edac_pmd_ctx *ctx;
ctx->edac = edac;
ctx->edac_dev = edac_dev;
ctx->ddev = *edac->dev;
+ ctx->version = version;
edac_dev->dev = &ctx->ddev;
edac_dev->ctl_name = ctx->name;
edac_dev->dev_name = ctx->name;
if (of_device_is_compatible(child, "apm,xgene-edac-mc"))
xgene_edac_mc_add(edac, child);
if (of_device_is_compatible(child, "apm,xgene-edac-pmd"))
- xgene_edac_pmd_add(edac, child);
+ xgene_edac_pmd_add(edac, child, 1);
+ if (of_device_is_compatible(child, "apm,xgene-edac-pmd-v2"))
+ xgene_edac_pmd_add(edac, child, 2);
}
return 0;