]> git.baikalelectronics.ru Git - kernel.git/commit
Revert "fast_hash: avoid indirect function calls"
authorJay Vosburgh <jay.vosburgh@canonical.com>
Fri, 14 Nov 2014 19:05:06 +0000 (11:05 -0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 14 Nov 2014 21:36:25 +0000 (16:36 -0500)
commit0f54583dcbfc18b0a211200ca430927a23e8896a
tree003964de0cc772f361d254385406fa75f3fcbff2
parent515a2765b54998136ea4bb85cd0235ddf0e43a42
Revert "fast_hash: avoid indirect function calls"

This reverts commit 01a5f8f1e6258c702a9791f1c41e30c40900a9fe.

Commit 01a5f8f1 introduced an alternative_call, arch_fast_hash2,
that selects between __jhash2 and __intel_crc4_2_hash based on the
X86_FEATURE_XMM4_2.

Unfortunately, the alternative_call system does not appear to be
suitable for use with C functions, as register usage is not handled
properly for the called functions.  The __jhash2 function in particular
clobbers registers that are not preserved when called via
alternative_call, resulting in a panic for direct callers of
arch_fast_hash2 on older CPUs lacking sse4_2.  It is possible that
__intel_crc4_2_hash works merely by chance because it uses fewer
registers.

This commit was suggested as the source of the problem by Jesse
Gross <jesse@nicira.com>.

Signed-off-by: Jay Vosburgh <jay.vosburgh@canonical.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
arch/x86/include/asm/hash.h
arch/x86/lib/hash.c
include/asm-generic/hash.h
include/linux/hash.h
lib/Makefile
lib/hash.c [new file with mode: 0644]