Commit 44d947ef authored by Breno Leitao's avatar Breno Leitao Committed by Michael Ellerman

selftests/powerpc: Do not fail with reschedule

There are cases where the test is not expecting to have the transaction
aborted, but, the test process might have been rescheduled, either in the
OS level or by KVM (if it is running on a KVM guest machine). The process
reschedule will cause a treclaim/recheckpoint which will cause the
transaction to doom, aborting the transaction as soon as the process is
rescheduled back to the CPU. This might cause the test to fail, but this is
not a failure in essence.

If that is the case, TEXASR[FC] is indicated with either
TM_CAUSE_RESCHEDULE or TM_CAUSE_KVM_RESCHEDULE for KVM interruptions.

In this scenario, ignore these two failures and avoid the whole test to
return failure.
Signed-off-by: default avatarBreno Leitao <leitao@debian.org>
Reviewed-by: default avatarGustavo Romero <gromero@linux.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent 984ecdd6
...@@ -236,7 +236,8 @@ void *tm_una_ping(void *input) ...@@ -236,7 +236,8 @@ void *tm_una_ping(void *input)
} }
/* Check if we were not expecting a failure and a it occurred. */ /* Check if we were not expecting a failure and a it occurred. */
if (!expecting_failure() && is_failure(cr_)) { if (!expecting_failure() && is_failure(cr_) &&
!failure_is_reschedule()) {
printf("\n\tUnexpected transaction failure 0x%02lx\n\t", printf("\n\tUnexpected transaction failure 0x%02lx\n\t",
failure_code()); failure_code());
return (void *) -1; return (void *) -1;
...@@ -244,9 +245,11 @@ void *tm_una_ping(void *input) ...@@ -244,9 +245,11 @@ void *tm_una_ping(void *input)
/* /*
* Check if TM failed due to the cause we were expecting. 0xda is a * Check if TM failed due to the cause we were expecting. 0xda is a
* TM_CAUSE_FAC_UNAV cause, otherwise it's an unexpected cause. * TM_CAUSE_FAC_UNAV cause, otherwise it's an unexpected cause, unless
* it was caused by a reschedule.
*/ */
if (is_failure(cr_) && !failure_is_unavailable()) { if (is_failure(cr_) && !failure_is_unavailable() &&
!failure_is_reschedule()) {
printf("\n\tUnexpected failure cause 0x%02lx\n\t", printf("\n\tUnexpected failure cause 0x%02lx\n\t",
failure_code()); failure_code());
return (void *) -1; return (void *) -1;
......
...@@ -52,6 +52,15 @@ static inline bool failure_is_unavailable(void) ...@@ -52,6 +52,15 @@ static inline bool failure_is_unavailable(void)
return (failure_code() & TM_CAUSE_FAC_UNAV) == TM_CAUSE_FAC_UNAV; return (failure_code() & TM_CAUSE_FAC_UNAV) == TM_CAUSE_FAC_UNAV;
} }
static inline bool failure_is_reschedule(void)
{
if ((failure_code() & TM_CAUSE_RESCHED) == TM_CAUSE_RESCHED ||
(failure_code() & TM_CAUSE_KVM_RESCHED) == TM_CAUSE_KVM_RESCHED)
return true;
return false;
}
static inline bool failure_is_nesting(void) static inline bool failure_is_nesting(void)
{ {
return (__builtin_get_texasru() & 0x400000); return (__builtin_get_texasru() & 0x400000);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment