summaryrefslogtreecommitdiffstats
path: root/arch/x86/crypto/crc32-pclmul_asm.S
diff options
context:
space:
mode:
authorJan Beulich <JBeulich@suse.com>2013-05-29 14:43:54 +0200
committerH. Peter Anvin <hpa@linux.intel.com>2013-05-31 01:36:23 +0200
commit2baad6121e2b2fa3428ee6cb2298107be11ab23a (patch)
treee2f944a9ff91a60ab7ac73152f1ff9a8bb56f96c /arch/x86/crypto/crc32-pclmul_asm.S
parentx86-64, init: Fix a possible wraparound bug in switchover in head_64.S (diff)
downloadlinux-2baad6121e2b2fa3428ee6cb2298107be11ab23a.tar.xz
linux-2baad6121e2b2fa3428ee6cb2298107be11ab23a.zip
x86, crc32-pclmul: Fix build with older binutils
binutils prior to 2.18 (e.g. the ones found on SLE10) don't support assembling PEXTRD, so a macro based approach like the one for PCLMULQDQ in the same file should be used. This requires making the helper macros capable of recognizing 32-bit general purpose register operands. [ hpa: tagging for stable as it is a low risk build fix ] Signed-off-by: Jan Beulich <jbeulich@suse.com> Link: http://lkml.kernel.org/r/51A6142A02000078000D99D8@nat28.tlf.novell.com Cc: Alexander Boyko <alexander_boyko@xyratex.com> Cc: Herbert Xu <herbert@gondor.apana.org.au> Cc: Huang Ying <ying.huang@intel.com> Cc: <stable@vger.kernel.org> v3.9 Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
Diffstat (limited to 'arch/x86/crypto/crc32-pclmul_asm.S')
-rw-r--r--arch/x86/crypto/crc32-pclmul_asm.S2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/x86/crypto/crc32-pclmul_asm.S b/arch/x86/crypto/crc32-pclmul_asm.S
index 94c27df8a549..f247304299a2 100644
--- a/arch/x86/crypto/crc32-pclmul_asm.S
+++ b/arch/x86/crypto/crc32-pclmul_asm.S
@@ -240,7 +240,7 @@ fold_64:
pand %xmm3, %xmm1
PCLMULQDQ 0x00, CONSTANT, %xmm1
pxor %xmm2, %xmm1
- pextrd $0x01, %xmm1, %eax
+ PEXTRD 0x01, %xmm1, %eax
ret
ENDPROC(crc32_pclmul_le_16)