Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
---
target/arm/syndrome.h | 12 ++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)
diff --git a/target/arm/syndrome.h b/target/arm/syndrome.h
index b145a52769f..abec0a4908e 100644
--- a/target/arm/syndrome.h
+++ b/target/arm/syndrome.h
@@ -384,10 +384,18 @@ static inline uint32_t syn_erettrap(int eret_op)
return res;
}
+/*
+ * ISS encoding for an exception due to SME functionality
+ */
+FIELD(SME_ISS, SMTC, 0, 2)
+
static inline uint32_t syn_smetrap(SMEExceptionType etype, bool is_16bit)
{
- return (EC_SMETRAP << ARM_EL_EC_SHIFT)
- | (is_16bit ? 0 : ARM_EL_IL) | etype;
+ uint32_t res = syn_set_ec(0, EC_SMETRAP);
+ res = FIELD_DP32(res, SYNDROME, IL, is_16bit ? 0 : 1);
+ res = FIELD_DP32(res, SME_ISS, SMTC, etype);
+
+ return res;
}
static inline uint32_t syn_pacfail(bool data, int keynumber)
--
2.47.3