selftests/powerpc: Abort load_unaligned_zeropad on unhandled SEGV
authorMichael Ellerman <mpe@ellerman.id.au>
Tue, 1 Nov 2016 04:01:07 +0000 (15:01 +1100)
committerMichael Ellerman <mpe@ellerman.id.au>
Mon, 14 Nov 2016 00:11:51 +0000 (11:11 +1100)
If the load unaligned zeropad test takes a SEGV which can't be handled,
we increment segv_error, print the offending NIP and then return without
taking any further action. In almost all cases this means we'll just
take the SEGV again, and loop eternally spamming the console.

Instead just abort(), it's a fatal error in the test. The test harness
will notice that the child died and print a nice message for us.

Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
tools/testing/selftests/powerpc/primitives/load_unaligned_zeropad.c

index 6cae06117b55297e031a210129e7f5a3f9d4c053..cf7a4a114a90424175f47e9f65da0df8cb80aff2 100644 (file)
@@ -73,7 +73,6 @@ extern char __stop___ex_table[];
 #error implement UCONTEXT_NIA
 #endif
 
-static int segv_error;
 
 static void segv_handler(int signr, siginfo_t *info, void *ptr)
 {
@@ -95,7 +94,7 @@ static void segv_handler(int signr, siginfo_t *info, void *ptr)
        }
 
        printf("No exception table match for NIA %lx ADDR %lx\n", *ip, addr);
-       segv_error++;
+       abort();
 }
 
 static void setup_segv_handler(void)
@@ -145,8 +144,6 @@ static int test_body(void)
        for (i = 0; i < page_size; i++)
                FAIL_IF(do_one_test(mem_region+i, i));
 
-       FAIL_IF(segv_error);
-
        return 0;
 }