#define HPRE_RAS_FE_ENB 0x301418
#define HPRE_OOO_SHUTDOWN_SEL 0x301a3c
#define HPRE_HAC_RAS_FE_ENABLE 0
+#define HPRE_RAS_MASK_ALL GENMASK(31, 0)
+#define HPRE_RAS_CLEAR_ALL GENMASK(31, 0)
#define HPRE_CORE_ENB (HPRE_CLSTR_BASE + HPRE_CORE_EN_OFFSET)
#define HPRE_CORE_INI_CFG (HPRE_CLSTR_BASE + HPRE_CORE_INI_CFG_OFFSET)
static void hpre_hw_error_disable(struct hisi_qm *qm)
{
- struct hisi_qm_err_mask *dev_err = &qm->err_info.dev_err;
- u32 err_mask = dev_err->ce | dev_err->nfe | dev_err->fe;
-
/* disable hpre hw error interrupts */
- writel(err_mask, qm->io_base + HPRE_INT_MASK);
+ writel(HPRE_RAS_MASK_ALL, qm->io_base + HPRE_INT_MASK);
/* disable HPRE block master OOO when nfe occurs on Kunpeng930 */
hpre_master_ooo_ctrl(qm, false);
}
u32 err_mask = dev_err->ce | dev_err->nfe | dev_err->fe;
/* clear HPRE hw error source if having */
- writel(err_mask, qm->io_base + HPRE_HAC_SOURCE_INT);
+ writel(HPRE_RAS_CLEAR_ALL, qm->io_base + HPRE_HAC_SOURCE_INT);
/* configure error type */
writel(dev_err->ce, qm->io_base + HPRE_RAS_CE_ENB);
#define QM_ABNORMAL_INT_SOURCE 0x100000
#define QM_ABNORMAL_INT_MASK 0x100004
-#define QM_ABNORMAL_INT_MASK_VALUE 0x7fff
#define QM_ABNORMAL_INT_STATUS 0x100008
#define QM_ABNORMAL_INT_SET 0x10000c
#define QM_ABNORMAL_INF00 0x100010
#define QM_DB_TIMEOUT BIT(10)
#define QM_OF_FIFO_OF BIT(11)
#define QM_RAS_AXI_ERROR (BIT(0) | BIT(1) | BIT(12))
+#define QM_RAS_MASK_ALL GENMASK(31, 0)
+#define QM_RAS_CLEAR_ALL GENMASK(31, 0)
#define QM_RESET_WAIT_TIMEOUT 400
#define QM_PEH_VENDOR_ID 0x1000d8
static void qm_hw_error_init_v1(struct hisi_qm *qm)
{
- writel(QM_ABNORMAL_INT_MASK_VALUE, qm->io_base + QM_ABNORMAL_INT_MASK);
+ writel(QM_RAS_MASK_ALL, qm->io_base + QM_ABNORMAL_INT_MASK);
}
static void qm_hw_error_cfg(struct hisi_qm *qm)
qm->error_mask = qm_err->nfe | qm_err->ce | qm_err->fe;
/* clear QM hw residual error source */
- writel(qm->error_mask, qm->io_base + QM_ABNORMAL_INT_SOURCE);
+ writel(QM_RAS_CLEAR_ALL, qm->io_base + QM_ABNORMAL_INT_SOURCE);
if (qm->ver >= QM_HW_V5)
writeq(QM_FUNC_RAS_CLEAR_ALL, qm->io_base + QM_FUNC_AXI_ERR_ST0);
static void qm_hw_error_init_v2(struct hisi_qm *qm)
{
- u32 irq_unmask;
-
qm_hw_error_cfg(qm);
- irq_unmask = ~qm->error_mask;
- irq_unmask &= readl(qm->io_base + QM_ABNORMAL_INT_MASK);
- writel(irq_unmask, qm->io_base + QM_ABNORMAL_INT_MASK);
+ writel(~qm->error_mask, qm->io_base + QM_ABNORMAL_INT_MASK);
}
static void qm_hw_error_uninit_v2(struct hisi_qm *qm)
{
- u32 irq_mask = qm->error_mask;
-
- irq_mask |= readl(qm->io_base + QM_ABNORMAL_INT_MASK);
- writel(irq_mask, qm->io_base + QM_ABNORMAL_INT_MASK);
+ writel(QM_RAS_MASK_ALL, qm->io_base + QM_ABNORMAL_INT_MASK);
}
static void qm_hw_error_init_v3(struct hisi_qm *qm)
{
- u32 irq_unmask;
-
qm_hw_error_cfg(qm);
/* enable close master ooo when hardware error happened */
writel(qm->err_info.qm_err.shutdown_mask, qm->io_base + QM_OOO_SHUTDOWN_SEL);
-
- irq_unmask = ~qm->error_mask;
- irq_unmask &= readl(qm->io_base + QM_ABNORMAL_INT_MASK);
- writel(irq_unmask, qm->io_base + QM_ABNORMAL_INT_MASK);
+ writel(~qm->error_mask, qm->io_base + QM_ABNORMAL_INT_MASK);
}
static void qm_hw_error_uninit_v3(struct hisi_qm *qm)
{
- u32 irq_mask = qm->error_mask;
-
- irq_mask |= readl(qm->io_base + QM_ABNORMAL_INT_MASK);
- writel(irq_mask, qm->io_base + QM_ABNORMAL_INT_MASK);
+ writel(QM_RAS_MASK_ALL, qm->io_base + QM_ABNORMAL_INT_MASK);
/* disable close master ooo when hardware error happened */
writel(0x0, qm->io_base + QM_OOO_SHUTDOWN_SEL);
#define SEC_OOO_SHUTDOWN_SEL 0x301014
#define SEC_RAS_DISABLE 0x0
#define SEC_AXI_ERROR_MASK (BIT(0) | BIT(1))
+#define SEC_RAS_CLEAR_ALL GENMASK(31, 0)
#define SEC_MEM_START_INIT_REG 0x301100
#define SEC_MEM_INIT_DONE_REG 0x301104
}
/* clear SEC hw error source if having */
- writel(err_mask, qm->io_base + SEC_CORE_INT_SOURCE);
+ writel(SEC_RAS_CLEAR_ALL, qm->io_base + SEC_CORE_INT_SOURCE);
/* enable RAS int */
writel(dev_err->ce, qm->io_base + SEC_RAS_CE_REG);
#define HZIP_OOO_SHUTDOWN_SEL 0x30120C
#define HZIP_SRAM_ECC_ERR_NUM_SHIFT 16
#define HZIP_SRAM_ECC_ERR_ADDR_SHIFT 24
-#define HZIP_CORE_INT_MASK_ALL GENMASK(12, 0)
+#define HZIP_CORE_INT_MASK_ALL GENMASK(31, 0)
+#define HZIP_CORE_RAS_CLEAR_ALL GENMASK(31, 0)
#define HZIP_AXI_ERROR_MASK (BIT(2) | BIT(3))
#define HZIP_SQE_SIZE 128
#define HZIP_PF_DEF_Q_NUM 64
}
/* clear ZIP hw error source if having */
- writel(err_mask, qm->io_base + HZIP_CORE_INT_SOURCE);
+ writel(HZIP_CORE_RAS_CLEAR_ALL, qm->io_base + HZIP_CORE_INT_SOURCE);
/* configure error type */
writel(dev_err->ce, qm->io_base + HZIP_CORE_INT_RAS_CE_ENB);
static void hisi_zip_hw_error_disable(struct hisi_qm *qm)
{
- struct hisi_qm_err_mask *dev_err = &qm->err_info.dev_err;
- u32 err_mask = dev_err->ce | dev_err->nfe | dev_err->fe;
-
/* disable ZIP hw error interrupts */
- writel(err_mask, qm->io_base + HZIP_CORE_INT_MASK_REG);
+ writel(HZIP_CORE_INT_MASK_ALL, qm->io_base + HZIP_CORE_INT_MASK_REG);
hisi_zip_master_ooo_ctrl(qm, false);