[PATCH v3 0/3] powerpc/lib: Optimisation of string functions for PPC32 - part 1

From: Christophe Leroy
Date: Tue May 22 2018 - 11:12:48 EST


This serie intends to optimise string functions for PPC32 in the
same spirit as already done on PPC64.

The first patch moves PPC32 specific functions from string.S into
a dedicated file named string_32.S
The second patch rewrites __clear_user() by using dcbz intruction
The third patch rewrites memcmp() to compare 32 bits words instead
of comparing byte per byte.

As shown in each individual commit log, second and third patches provide
significant improvment.

Changes in v3:
- Fixed the sign of the result returned by memcmp() by using a logical
comparison of u32 words and returning -1, 0 or 1 instead of doing a substract.
- In first patch, replaced PPC_LCMPI by cmpwi
- Fixed licence in string_32.S
- Removed the two last patches from the serie. They will be handled later as
they require further tests and analysis to properly identify their real benefit
in all possible cases.

Changes in v2:
- Moved out the patch removing the hot loop alignment on PPC32
- Squashed the changes related to NUL size verification in a single patch
- Reordered the patches in a more logical order
- Modified the inlining patch to avoid warning about impossibility to version symbols.

Christophe Leroy (3):
powerpc/lib: move PPC32 specific functions out of string.S
powerpc/lib: optimise 32 bits __clear_user()
powerpc/lib: optimise PPC32 memcmp

arch/powerpc/lib/Makefile | 5 +-
arch/powerpc/lib/string.S | 61 -------------------
arch/powerpc/lib/string_32.S | 140 +++++++++++++++++++++++++++++++++++++++++++
3 files changed, 143 insertions(+), 63 deletions(-)
create mode 100644 arch/powerpc/lib/string_32.S

--
2.13.3