]> git.baikalelectronics.ru Git - kernel.git/commit
parisc: Improve LWS-CAS performance
authorJohn David Anglin <dave.anglin@bell.net>
Sun, 11 May 2014 22:40:50 +0000 (18:40 -0400)
committerHelge Deller <deller@gmx.de>
Thu, 15 May 2014 19:12:26 +0000 (21:12 +0200)
commitd1e5a0467512b919ce9598478d06588eecad029d
treec6f26e9791042801f87cd36d87ebb0d527b344b1
parent3a21cfdec2e0914ae3bf07dd6a30c3e2ed6c68b0
parisc: Improve LWS-CAS performance

The attached change significantly improves the performance of the LWS-CAS code
in syscall.S.
This allows a number of packages to build (e.g., zeromq3, gtest and libxs)
that previously failed because slow LWS-CAS performance under contention. In
particular, interrupts taken while the lock was taken degraded performance
significantly.

The change does the following:

1) Disables interrupts around the CAS operation, and
2) Changes the loads and stores to use the ordered completer, "o", on
PA 2.0. "o" and "ma" with a zero offset are equivalent. The latter is
accepted on both PA 1.X and 2.0.

The use of ordered loads and stores probably makes no difference on all
existing hardware, but it seemed pedantically correct. In particular, the CAS
operation must complete before LDCW lock is released. As written before, a
processor could reorder the operations.

I don't believe the period interrupts are disabled is long enough to
significantly increase interrupt latency. For example, the TLB insert code is
longer. Worst case is a memory fault in the CAS operation.

Signed-off-by: John David Anglin <dave.anglin@bell.net>
Cc: stable@vger.kernel.org # 3.13+
Signed-off-by: Helge Deller <deller@gmx.de>
arch/parisc/kernel/syscall.S