[Skiboot] [PATCH 14/14] opal/hmi: Generate hmi event for recovered HDEC parity error.

Mahesh J Salgaonkar mahesh at linux.vnet.ibm.com
Wed Mar 14 21:08:50 AEDT 2018


From: Mahesh Salgaonkar <mahesh at linux.vnet.ibm.com>

Signed-off-by: Mahesh Salgaonkar <mahesh at linux.vnet.ibm.com>
---
 core/hmi.c        |    5 ++---
 hw/chiptod.c      |   11 +++++++----
 include/chiptod.h |    2 +-
 3 files changed, 10 insertions(+), 8 deletions(-)

diff --git a/core/hmi.c b/core/hmi.c
index ef9c9c169..5b609ee93 100644
--- a/core/hmi.c
+++ b/core/hmi.c
@@ -984,10 +984,9 @@ static int handle_all_core_tfac_error(uint64_t tfmr, uint64_t *out_flags)
 	hmi_rendez_vous(2);
 
 	/* We can now clear the error conditions in the core. */
-	if (!tfmr_clear_core_errors(tfmr)) {
-		recover = 0;
+	recover = tfmr_clear_core_errors(tfmr);
+	if (recover == 0)
 		goto error_out;
-	}
 
 	/* Third rendez-vous. We could in theory do the timebase resync as
 	 * part of the previous one, but I prefer having all the error
diff --git a/hw/chiptod.c b/hw/chiptod.c
index 28ed8973a..df1274ca8 100644
--- a/hw/chiptod.c
+++ b/hw/chiptod.c
@@ -1491,18 +1491,21 @@ void tfmr_cleanup_core_errors(uint64_t tfmr)
 	}
 }
 
-bool tfmr_clear_core_errors(uint64_t tfmr)
+int tfmr_clear_core_errors(uint64_t tfmr)
 {
 	uint64_t tfmr_reset_errors = 0;
 
-	if (tfmr & SPR_TFMR_HDEC_PARITY_ERROR)
-		tfmr_reset_errors |= SPR_TFMR_HDEC_PARITY_ERROR;
+	/* return -1 if there is nothing to be fixed. */
+	if (!(tfmr & SPR_TFMR_HDEC_PARITY_ERROR))
+		return -1;
+
+	tfmr_reset_errors |= SPR_TFMR_HDEC_PARITY_ERROR;
 
 	/* Write TFMR twice to clear the error */
 	mtspr(SPR_TFMR, base_tfmr | tfmr_reset_errors);
 	mtspr(SPR_TFMR, base_tfmr | tfmr_reset_errors);
 
-	return true;
+	return 1;
 }
 
 /*
diff --git a/include/chiptod.h b/include/chiptod.h
index 5860e34d2..3717e6674 100644
--- a/include/chiptod.h
+++ b/include/chiptod.h
@@ -33,7 +33,7 @@ extern int chiptod_recover_tb_errors(bool *out_resynced);
 extern bool tfmr_recover_local_errors(uint64_t tfmr);
 extern bool recover_corrupt_tfmr(void);
 extern void tfmr_cleanup_core_errors(uint64_t tfmr);
-extern bool tfmr_clear_core_errors(uint64_t tfmr);
+extern int tfmr_clear_core_errors(uint64_t tfmr);
 extern void chiptod_reset_tb(void);
 extern bool chiptod_adjust_topology(enum chiptod_topology topo, bool enable);
 extern bool chiptod_capp_timebase_sync(unsigned int chip_id, uint32_t tfmr_addr,



More information about the Skiboot mailing list