Strange results from Locking API testsuite on ARM

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello,

on our ARM-Cortex-A8-based board (using a TI AM3505 Sitara CPU) running
3.2.54-rt77, the Locking API testsuite displays 87 unexpected failures.

The pattern in the output looks interesting, but I'm not sure what it means:

> [    0.000000] | Locking API testsuite:
> [    0.000000] ----------------------------------------------------------------------------
> [    0.000000]                                  | spin |wlock |rlock |mutex | wsem | rsem |
> [    0.000000]   --------------------------------------------------------------------------
> [    0.000000]                      A-A deadlock:  ok  |  ok  |FAILED|  ok  |  ok  |  ok  |
> [    0.000000]                  A-B-B-A deadlock:  ok  |  ok  |FAILED|  ok  |  ok  |  ok  |
> [    0.000000]              A-B-B-C-C-A deadlock:  ok  |  ok  |FAILED|  ok  |  ok  |  ok  |
> [    0.000000]              A-B-C-A-B-C deadlock:  ok  |  ok  |FAILED|  ok  |  ok  |  ok  |
> [    0.000000]          A-B-B-C-C-D-D-A deadlock:  ok  |  ok  |FAILED|  ok  |  ok  |  ok  |
> [    0.000000]          A-B-C-D-B-D-D-A deadlock:  ok  |  ok  |FAILED|  ok  |  ok  |  ok  |
> [    0.000000]          A-B-C-D-B-C-D-A deadlock:  ok  |  ok  |FAILED|  ok  |  ok  |  ok  |
> [    0.000000]                     double unlock:  ok  |  ok  |FAILED|  ok  |  ok  |FAILED|
> [    0.000000]                   initialize held:  ok  |  ok  |  ok  |  ok  |  ok  |  ok  |
> [    0.000000]                  bad unlock order:  ok  |  ok  |  ok  |  ok  |  ok  |  ok  |
> [    0.000000]   --------------------------------------------------------------------------
> [    0.000000]               recursive read-lock:             |  ok  |             |FAILED|
> [    0.000000]            recursive read-lock #2:             |FAILED|             |  ok  |
> [    0.000000]             mixed read-write-lock:             |  ok  |             |  ok  |
> [    0.000000]             mixed write-read-lock:             |  ok  |             |  ok  |
> [    0.000000]   --------------------------------------------------------------------------
> [    0.000000]      hard-irqs-on + irq-safe-A/12:  ok  |  ok  |FAILED|
> [    0.000000]      soft-irqs-on + irq-safe-A/12:FAILED|FAILED|  ok  |
> [    0.000000]      hard-irqs-on + irq-safe-A/21:  ok  |  ok  |FAILED|
> [    0.000000]      soft-irqs-on + irq-safe-A/21:FAILED|FAILED|  ok  |
> [    0.000000]        sirq-safe-A => hirqs-on/12:FAILED|FAILED|  ok  |
> [    0.000000]        sirq-safe-A => hirqs-on/21:FAILED|FAILED|  ok  |
> [    0.000000]          hard-safe-A + irqs-on/12:  ok  |  ok  |FAILED|
> [    0.000000]          soft-safe-A + irqs-on/12:FAILED|FAILED|  ok  |
> [    0.000000]          hard-safe-A + irqs-on/21:  ok  |  ok  |FAILED|
> [    0.000000]          soft-safe-A + irqs-on/21:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #1/123:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #1/123:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #1/132:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #1/132:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #1/213:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #1/213:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #1/231:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #1/231:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #1/312:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #1/312:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #1/321:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #1/321:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #2/123:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #2/123:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #2/132:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #2/132:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #2/213:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #2/213:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #2/231:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #2/231:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #2/312:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #2/312:FAILED|FAILED|  ok  |
> [    0.000000]     hard-safe-A + unsafe-B #2/321:  ok  |  ok  |FAILED|
> [    0.000000]     soft-safe-A + unsafe-B #2/321:FAILED|FAILED|  ok  |
> [    0.000000]       hard-irq lock-inversion/123:  ok  |  ok  |FAILED|
> [    0.000000]       soft-irq lock-inversion/123:FAILED|FAILED|  ok  |
> [    0.000000]       hard-irq lock-inversion/132:  ok  |  ok  |FAILED|
> [    0.000000]       soft-irq lock-inversion/132:FAILED|FAILED|  ok  |
> [    0.000000]       hard-irq lock-inversion/213:  ok  |  ok  |FAILED|
> [    0.000000]       soft-irq lock-inversion/213:FAILED|FAILED|  ok  |
> [    0.000000]       hard-irq lock-inversion/231:  ok  |  ok  |FAILED|
> [    0.000000]       soft-irq lock-inversion/231:FAILED|FAILED|  ok  |
> [    0.000000]       hard-irq lock-inversion/312:  ok  |  ok  |FAILED|
> [    0.000000]       soft-irq lock-inversion/312:FAILED|FAILED|  ok  |
> [    0.000000]       hard-irq lock-inversion/321:  ok  |  ok  |FAILED|
> [    0.000000]       soft-irq lock-inversion/321:FAILED|FAILED|  ok  |
> [    0.000000]       hard-irq read-recursion/123:FAILED|
> [    0.000000]       soft-irq read-recursion/123:  ok  |
> [    0.000000]       hard-irq read-recursion/132:FAILED|
> [    0.000000]       soft-irq read-recursion/132:  ok  |
> [    0.000000]       hard-irq read-recursion/213:FAILED|
> [    0.000000]       soft-irq read-recursion/213:  ok  |
> [    0.000000]       hard-irq read-recursion/231:FAILED|
> [    0.000000]       soft-irq read-recursion/231:  ok  |
> [    0.000000]       hard-irq read-recursion/312:FAILED|
> [    0.000000]       soft-irq read-recursion/312:  ok  |
> [    0.000000]       hard-irq read-recursion/321:FAILED|
> [    0.000000]       soft-irq read-recursion/321:  ok  |
> [    0.000000] -----------------------------------------------------------------
> [    0.000000] BUG:  87 unexpected failures (out of 218) - debugging disabled! |

Apparently the RT capabilites are not affected.

Here is a link to the full startup log, http://pastebin.com/bBmLwebD
and the kernel configuration used, http://pastebin.com/nYHyBjqT

If I configure the kernel for "Basic RT" or less, all 218 testcases
pass. If I configure "Full RT", but don't select "prove locking
correctness", the result is the usual "135 out of 218 testcases failed,
as expected."

This phenomenon happens with the previous kernel too (at least, haven't
checked older versions yet).

I'm not sure, is the testsuite meant to work in full RT at all?
Did I miss some important kernel config options?

Thanks,
Rolf
--
To unsubscribe from this list: send the line "unsubscribe linux-rt-users" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [RT Stable]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]

  Powered by Linux