[icp] fpu and asm cleanup for linux
Properly annotate functions and data section so that objtool does not complain when CONFIG_STACK_VALIDATION and CONFIG_FRAME_POINTER are enabled. Pass KERNELCPPFLAGS to assembler. Use kfpu_begin()/kfpu_end() to protect SIMD regions in Linux kernel. Reviewed-by: Tom Caputi <tcaputi@datto.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Gvozden Neskovic <neskovic@gmail.com> Closes #5872 Closes #5041
This commit is contained in:
parent
5fc73c46f9
commit
650383f283
|
@ -0,0 +1,19 @@
|
||||||
|
dnl #
|
||||||
|
dnl # 4.6 API for compile-time stack validation
|
||||||
|
dnl #
|
||||||
|
AC_DEFUN([ZFS_AC_KERNEL_OBJTOOL], [
|
||||||
|
AC_MSG_CHECKING([for compile-time stack validation (objtool)])
|
||||||
|
ZFS_LINUX_TRY_COMPILE([
|
||||||
|
#undef __ASSEMBLY__
|
||||||
|
#include <asm/frame.h>
|
||||||
|
],[
|
||||||
|
#if !defined(FRAME_BEGIN)
|
||||||
|
CTASSERT(1);
|
||||||
|
#endif
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_KERNEL_OBJTOOL, 1, [kernel does stack verification])
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
])
|
||||||
|
])
|
|
@ -5,6 +5,7 @@ AC_DEFUN([ZFS_AC_CONFIG_KERNEL], [
|
||||||
ZFS_AC_KERNEL
|
ZFS_AC_KERNEL
|
||||||
ZFS_AC_SPL
|
ZFS_AC_SPL
|
||||||
ZFS_AC_TEST_MODULE
|
ZFS_AC_TEST_MODULE
|
||||||
|
ZFS_AC_KERNEL_OBJTOOL
|
||||||
ZFS_AC_KERNEL_CONFIG
|
ZFS_AC_KERNEL_CONFIG
|
||||||
ZFS_AC_KERNEL_DECLARE_EVENT_CLASS
|
ZFS_AC_KERNEL_DECLARE_EVENT_CLASS
|
||||||
ZFS_AC_KERNEL_CURRENT_BIO_TAIL
|
ZFS_AC_KERNEL_CURRENT_BIO_TAIL
|
||||||
|
|
|
@ -24,6 +24,7 @@ ASM_SOURCES :=
|
||||||
endif
|
endif
|
||||||
|
|
||||||
EXTRA_CFLAGS = $(ZFS_MODULE_CFLAGS) @KERNELCPPFLAGS@
|
EXTRA_CFLAGS = $(ZFS_MODULE_CFLAGS) @KERNELCPPFLAGS@
|
||||||
|
EXTRA_AFLAGS = $(ZFS_MODULE_CFLAGS) @KERNELCPPFLAGS@
|
||||||
|
|
||||||
obj-$(CONFIG_ZFS) := $(MODULE).o
|
obj-$(CONFIG_ZFS) := $(MODULE).o
|
||||||
|
|
||||||
|
|
|
@ -22,23 +22,22 @@
|
||||||
* Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/zfs_context.h>
|
#if defined(_KERNEL) && defined(__amd64)
|
||||||
#include <sys/crypto/spi.h>
|
#include <linux/simd_x86.h>
|
||||||
#include <modes/modes.h>
|
|
||||||
#include <aes/aes_impl.h>
|
|
||||||
|
|
||||||
#ifdef __amd64
|
#define KPREEMPT_DISABLE kfpu_begin()
|
||||||
|
#define KPREEMPT_ENABLE kfpu_end()
|
||||||
#ifdef _KERNEL
|
|
||||||
/* Workaround for no XMM kernel thread save/restore */
|
|
||||||
#define KPREEMPT_DISABLE kpreempt_disable()
|
|
||||||
#define KPREEMPT_ENABLE kpreempt_enable()
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#define KPREEMPT_DISABLE
|
#define KPREEMPT_DISABLE
|
||||||
#define KPREEMPT_ENABLE
|
#define KPREEMPT_ENABLE
|
||||||
#endif /* _KERNEL */
|
#endif /* _KERNEL */
|
||||||
#endif /* __amd64 */
|
|
||||||
|
#include <sys/zfs_context.h>
|
||||||
|
#include <sys/crypto/spi.h>
|
||||||
|
#include <modes/modes.h>
|
||||||
|
#include <aes/aes_impl.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -22,6 +22,17 @@
|
||||||
* Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#if defined(_KERNEL) && defined(__amd64)
|
||||||
|
#include <linux/simd_x86.h>
|
||||||
|
|
||||||
|
#define KPREEMPT_DISABLE kfpu_begin()
|
||||||
|
#define KPREEMPT_ENABLE kfpu_end()
|
||||||
|
|
||||||
|
#else
|
||||||
|
#define KPREEMPT_DISABLE
|
||||||
|
#define KPREEMPT_ENABLE
|
||||||
|
#endif /* _KERNEL */
|
||||||
|
|
||||||
#include <sys/zfs_context.h>
|
#include <sys/zfs_context.h>
|
||||||
#include <modes/modes.h>
|
#include <modes/modes.h>
|
||||||
#include <sys/crypto/common.h>
|
#include <sys/crypto/common.h>
|
||||||
|
@ -30,16 +41,6 @@
|
||||||
|
|
||||||
#ifdef __amd64
|
#ifdef __amd64
|
||||||
|
|
||||||
#ifdef _KERNEL
|
|
||||||
/* Workaround for no XMM kernel thread save/restore */
|
|
||||||
#define KPREEMPT_DISABLE kpreempt_disable()
|
|
||||||
#define KPREEMPT_ENABLE kpreempt_enable()
|
|
||||||
|
|
||||||
#else
|
|
||||||
#define KPREEMPT_DISABLE
|
|
||||||
#define KPREEMPT_ENABLE
|
|
||||||
#endif /* _KERNEL */
|
|
||||||
|
|
||||||
extern void gcm_mul_pclmulqdq(uint64_t *x_in, uint64_t *y, uint64_t *res);
|
extern void gcm_mul_pclmulqdq(uint64_t *x_in, uint64_t *y, uint64_t *res);
|
||||||
static int intel_pclmulqdq_instruction_present(void);
|
static int intel_pclmulqdq_instruction_present(void);
|
||||||
#endif /* __amd64 */
|
#endif /* __amd64 */
|
||||||
|
|
|
@ -693,7 +693,8 @@ aes_decrypt_amd64(const uint32_t rk[], int Nr, const uint32_t ct[4],
|
||||||
* int aes_encrypt(const unsigned char *in,
|
* int aes_encrypt(const unsigned char *in,
|
||||||
* unsigned char *out, const aes_encrypt_ctx cx[1])/
|
* unsigned char *out, const aes_encrypt_ctx cx[1])/
|
||||||
*/
|
*/
|
||||||
.align 64
|
.data
|
||||||
|
.align 64
|
||||||
enc_tab:
|
enc_tab:
|
||||||
enc_vals(u8)
|
enc_vals(u8)
|
||||||
#ifdef LAST_ROUND_TABLES
|
#ifdef LAST_ROUND_TABLES
|
||||||
|
@ -702,7 +703,7 @@ enc_tab:
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
ENTRY_NP(aes_encrypt_amd64)
|
ENTRY_NP(aes_encrypt_amd64)
|
||||||
#ifdef GLADMAN_INTERFACE
|
#ifdef GLADMAN_INTERFACE
|
||||||
// Original interface
|
// Original interface
|
||||||
sub $[4*8], %rsp // gnu/linux/opensolaris binary interface
|
sub $[4*8], %rsp // gnu/linux/opensolaris binary interface
|
||||||
|
@ -797,7 +798,8 @@ enc_tab:
|
||||||
* int aes_decrypt(const unsigned char *in,
|
* int aes_decrypt(const unsigned char *in,
|
||||||
* unsigned char *out, const aes_encrypt_ctx cx[1])/
|
* unsigned char *out, const aes_encrypt_ctx cx[1])/
|
||||||
*/
|
*/
|
||||||
.align 64
|
.data
|
||||||
|
.align 64
|
||||||
dec_tab:
|
dec_tab:
|
||||||
dec_vals(v8)
|
dec_vals(v8)
|
||||||
#ifdef LAST_ROUND_TABLES
|
#ifdef LAST_ROUND_TABLES
|
||||||
|
@ -806,7 +808,7 @@ dec_tab:
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
ENTRY_NP(aes_decrypt_amd64)
|
ENTRY_NP(aes_decrypt_amd64)
|
||||||
#ifdef GLADMAN_INTERFACE
|
#ifdef GLADMAN_INTERFACE
|
||||||
// Original interface
|
// Original interface
|
||||||
sub $[4*8], %rsp // gnu/linux/opensolaris binary interface
|
sub $[4*8], %rsp // gnu/linux/opensolaris binary interface
|
||||||
|
|
|
@ -149,6 +149,7 @@
|
||||||
* ====================================================================
|
* ====================================================================
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#if defined(lint) || defined(__lint)
|
#if defined(lint) || defined(__lint)
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
@ -182,111 +183,6 @@ rijndael_key_setup_dec_intel(uint32_t rk[], const uint32_t cipherKey[],
|
||||||
#define _ASM
|
#define _ASM
|
||||||
#include <sys/asm_linkage.h>
|
#include <sys/asm_linkage.h>
|
||||||
|
|
||||||
#ifdef _KERNEL
|
|
||||||
/*
|
|
||||||
* Note: the CLTS macro clobbers P2 (%rsi) under i86xpv. That is,
|
|
||||||
* it calls HYPERVISOR_fpu_taskswitch() which modifies %rsi when it
|
|
||||||
* uses it to pass P2 to syscall.
|
|
||||||
* This also occurs with the STTS macro, but we dont care if
|
|
||||||
* P2 (%rsi) is modified just before function exit.
|
|
||||||
* The CLTS and STTS macros push and pop P1 (%rdi) already.
|
|
||||||
*/
|
|
||||||
#ifdef __xpv
|
|
||||||
#define PROTECTED_CLTS \
|
|
||||||
push %rsi; \
|
|
||||||
CLTS; \
|
|
||||||
pop %rsi
|
|
||||||
#else
|
|
||||||
#define PROTECTED_CLTS \
|
|
||||||
CLTS
|
|
||||||
#endif /* __xpv */
|
|
||||||
|
|
||||||
#define CLEAR_TS_OR_PUSH_XMM0_XMM1(tmpreg) \
|
|
||||||
push %rbp; \
|
|
||||||
mov %rsp, %rbp; \
|
|
||||||
movq %cr0, tmpreg; \
|
|
||||||
testq $CR0_TS, tmpreg; \
|
|
||||||
jnz 1f; \
|
|
||||||
and $-XMM_ALIGN, %rsp; \
|
|
||||||
sub $[XMM_SIZE * 2], %rsp; \
|
|
||||||
movaps %xmm0, 16(%rsp); \
|
|
||||||
movaps %xmm1, (%rsp); \
|
|
||||||
jmp 2f; \
|
|
||||||
1: \
|
|
||||||
PROTECTED_CLTS; \
|
|
||||||
2:
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If CR0_TS was not set above, pop %xmm0 and %xmm1 off stack,
|
|
||||||
* otherwise set CR0_TS.
|
|
||||||
*/
|
|
||||||
#define SET_TS_OR_POP_XMM0_XMM1(tmpreg) \
|
|
||||||
testq $CR0_TS, tmpreg; \
|
|
||||||
jnz 1f; \
|
|
||||||
movaps (%rsp), %xmm1; \
|
|
||||||
movaps 16(%rsp), %xmm0; \
|
|
||||||
jmp 2f; \
|
|
||||||
1: \
|
|
||||||
STTS(tmpreg); \
|
|
||||||
2: \
|
|
||||||
mov %rbp, %rsp; \
|
|
||||||
pop %rbp
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If CR0_TS is not set, align stack (with push %rbp) and push
|
|
||||||
* %xmm0 - %xmm6 on stack, otherwise clear CR0_TS
|
|
||||||
*/
|
|
||||||
#define CLEAR_TS_OR_PUSH_XMM0_TO_XMM6(tmpreg) \
|
|
||||||
push %rbp; \
|
|
||||||
mov %rsp, %rbp; \
|
|
||||||
movq %cr0, tmpreg; \
|
|
||||||
testq $CR0_TS, tmpreg; \
|
|
||||||
jnz 1f; \
|
|
||||||
and $-XMM_ALIGN, %rsp; \
|
|
||||||
sub $[XMM_SIZE * 7], %rsp; \
|
|
||||||
movaps %xmm0, 96(%rsp); \
|
|
||||||
movaps %xmm1, 80(%rsp); \
|
|
||||||
movaps %xmm2, 64(%rsp); \
|
|
||||||
movaps %xmm3, 48(%rsp); \
|
|
||||||
movaps %xmm4, 32(%rsp); \
|
|
||||||
movaps %xmm5, 16(%rsp); \
|
|
||||||
movaps %xmm6, (%rsp); \
|
|
||||||
jmp 2f; \
|
|
||||||
1: \
|
|
||||||
PROTECTED_CLTS; \
|
|
||||||
2:
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If CR0_TS was not set above, pop %xmm0 - %xmm6 off stack,
|
|
||||||
* otherwise set CR0_TS.
|
|
||||||
*/
|
|
||||||
#define SET_TS_OR_POP_XMM0_TO_XMM6(tmpreg) \
|
|
||||||
testq $CR0_TS, tmpreg; \
|
|
||||||
jnz 1f; \
|
|
||||||
movaps (%rsp), %xmm6; \
|
|
||||||
movaps 16(%rsp), %xmm5; \
|
|
||||||
movaps 32(%rsp), %xmm4; \
|
|
||||||
movaps 48(%rsp), %xmm3; \
|
|
||||||
movaps 64(%rsp), %xmm2; \
|
|
||||||
movaps 80(%rsp), %xmm1; \
|
|
||||||
movaps 96(%rsp), %xmm0; \
|
|
||||||
jmp 2f; \
|
|
||||||
1: \
|
|
||||||
STTS(tmpreg); \
|
|
||||||
2: \
|
|
||||||
mov %rbp, %rsp; \
|
|
||||||
pop %rbp
|
|
||||||
|
|
||||||
|
|
||||||
#else
|
|
||||||
#define PROTECTED_CLTS
|
|
||||||
#define CLEAR_TS_OR_PUSH_XMM0_XMM1(tmpreg)
|
|
||||||
#define SET_TS_OR_POP_XMM0_XMM1(tmpreg)
|
|
||||||
#define CLEAR_TS_OR_PUSH_XMM0_TO_XMM6(tmpreg)
|
|
||||||
#define SET_TS_OR_POP_XMM0_TO_XMM6(tmpreg)
|
|
||||||
#endif /* _KERNEL */
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* _key_expansion_128(), * _key_expansion_192a(), _key_expansion_192b(),
|
* _key_expansion_128(), * _key_expansion_192a(), _key_expansion_192b(),
|
||||||
|
@ -302,9 +198,9 @@ rijndael_key_setup_dec_intel(uint32_t rk[], const uint32_t cipherKey[],
|
||||||
* (%rcx) AES key
|
* (%rcx) AES key
|
||||||
*/
|
*/
|
||||||
|
|
||||||
.align 16
|
ENTRY_NP2(_key_expansion_128, _key_expansion_256a)
|
||||||
_key_expansion_128:
|
_key_expansion_128_local:
|
||||||
_key_expansion_256a:
|
_key_expansion_256a_local:
|
||||||
pshufd $0b11111111, %xmm1, %xmm1
|
pshufd $0b11111111, %xmm1, %xmm1
|
||||||
shufps $0b00010000, %xmm0, %xmm4
|
shufps $0b00010000, %xmm0, %xmm4
|
||||||
pxor %xmm4, %xmm0
|
pxor %xmm4, %xmm0
|
||||||
|
@ -314,11 +210,13 @@ _key_expansion_256a:
|
||||||
movaps %xmm0, (%rcx)
|
movaps %xmm0, (%rcx)
|
||||||
add $0x10, %rcx
|
add $0x10, %rcx
|
||||||
ret
|
ret
|
||||||
SET_SIZE(_key_expansion_128)
|
nop
|
||||||
SET_SIZE(_key_expansion_256a)
|
SET_SIZE(_key_expansion_128)
|
||||||
|
SET_SIZE(_key_expansion_256a)
|
||||||
|
|
||||||
.align 16
|
|
||||||
_key_expansion_192a:
|
ENTRY_NP(_key_expansion_192a)
|
||||||
|
_key_expansion_192a_local:
|
||||||
pshufd $0b01010101, %xmm1, %xmm1
|
pshufd $0b01010101, %xmm1, %xmm1
|
||||||
shufps $0b00010000, %xmm0, %xmm4
|
shufps $0b00010000, %xmm0, %xmm4
|
||||||
pxor %xmm4, %xmm0
|
pxor %xmm4, %xmm0
|
||||||
|
@ -340,10 +238,11 @@ _key_expansion_192a:
|
||||||
movaps %xmm1, 0x10(%rcx)
|
movaps %xmm1, 0x10(%rcx)
|
||||||
add $0x20, %rcx
|
add $0x20, %rcx
|
||||||
ret
|
ret
|
||||||
SET_SIZE(_key_expansion_192a)
|
SET_SIZE(_key_expansion_192a)
|
||||||
|
|
||||||
.align 16
|
|
||||||
_key_expansion_192b:
|
ENTRY_NP(_key_expansion_192b)
|
||||||
|
_key_expansion_192b_local:
|
||||||
pshufd $0b01010101, %xmm1, %xmm1
|
pshufd $0b01010101, %xmm1, %xmm1
|
||||||
shufps $0b00010000, %xmm0, %xmm4
|
shufps $0b00010000, %xmm0, %xmm4
|
||||||
pxor %xmm4, %xmm0
|
pxor %xmm4, %xmm0
|
||||||
|
@ -360,10 +259,11 @@ _key_expansion_192b:
|
||||||
movaps %xmm0, (%rcx)
|
movaps %xmm0, (%rcx)
|
||||||
add $0x10, %rcx
|
add $0x10, %rcx
|
||||||
ret
|
ret
|
||||||
SET_SIZE(_key_expansion_192b)
|
SET_SIZE(_key_expansion_192b)
|
||||||
|
|
||||||
.align 16
|
|
||||||
_key_expansion_256b:
|
ENTRY_NP(_key_expansion_256b)
|
||||||
|
_key_expansion_256b_local:
|
||||||
pshufd $0b10101010, %xmm1, %xmm1
|
pshufd $0b10101010, %xmm1, %xmm1
|
||||||
shufps $0b00010000, %xmm2, %xmm4
|
shufps $0b00010000, %xmm2, %xmm4
|
||||||
pxor %xmm4, %xmm2
|
pxor %xmm4, %xmm2
|
||||||
|
@ -373,7 +273,7 @@ _key_expansion_256b:
|
||||||
movaps %xmm2, (%rcx)
|
movaps %xmm2, (%rcx)
|
||||||
add $0x10, %rcx
|
add $0x10, %rcx
|
||||||
ret
|
ret
|
||||||
SET_SIZE(_key_expansion_256b)
|
SET_SIZE(_key_expansion_256b)
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -419,8 +319,7 @@ _key_expansion_256b:
|
||||||
|
|
||||||
ENTRY_NP(rijndael_key_setup_enc_intel)
|
ENTRY_NP(rijndael_key_setup_enc_intel)
|
||||||
rijndael_key_setup_enc_intel_local:
|
rijndael_key_setup_enc_intel_local:
|
||||||
CLEAR_TS_OR_PUSH_XMM0_TO_XMM6(%r10)
|
FRAME_BEGIN
|
||||||
|
|
||||||
// NULL pointer sanity check
|
// NULL pointer sanity check
|
||||||
test %USERCIPHERKEY, %USERCIPHERKEY
|
test %USERCIPHERKEY, %USERCIPHERKEY
|
||||||
jz .Lenc_key_invalid_param
|
jz .Lenc_key_invalid_param
|
||||||
|
@ -446,38 +345,38 @@ rijndael_key_setup_enc_intel_local:
|
||||||
add $0x10, %rcx
|
add $0x10, %rcx
|
||||||
|
|
||||||
aeskeygenassist $0x1, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x1, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_256a
|
call _key_expansion_256a_local
|
||||||
aeskeygenassist $0x1, %xmm0, %xmm1
|
aeskeygenassist $0x1, %xmm0, %xmm1
|
||||||
call _key_expansion_256b
|
call _key_expansion_256b_local
|
||||||
aeskeygenassist $0x2, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x2, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_256a
|
call _key_expansion_256a_local
|
||||||
aeskeygenassist $0x2, %xmm0, %xmm1
|
aeskeygenassist $0x2, %xmm0, %xmm1
|
||||||
call _key_expansion_256b
|
call _key_expansion_256b_local
|
||||||
aeskeygenassist $0x4, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x4, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_256a
|
call _key_expansion_256a_local
|
||||||
aeskeygenassist $0x4, %xmm0, %xmm1
|
aeskeygenassist $0x4, %xmm0, %xmm1
|
||||||
call _key_expansion_256b
|
call _key_expansion_256b_local
|
||||||
aeskeygenassist $0x8, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x8, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_256a
|
call _key_expansion_256a_local
|
||||||
aeskeygenassist $0x8, %xmm0, %xmm1
|
aeskeygenassist $0x8, %xmm0, %xmm1
|
||||||
call _key_expansion_256b
|
call _key_expansion_256b_local
|
||||||
aeskeygenassist $0x10, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x10, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_256a
|
call _key_expansion_256a_local
|
||||||
aeskeygenassist $0x10, %xmm0, %xmm1
|
aeskeygenassist $0x10, %xmm0, %xmm1
|
||||||
call _key_expansion_256b
|
call _key_expansion_256b_local
|
||||||
aeskeygenassist $0x20, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x20, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_256a
|
call _key_expansion_256a_local
|
||||||
aeskeygenassist $0x20, %xmm0, %xmm1
|
aeskeygenassist $0x20, %xmm0, %xmm1
|
||||||
call _key_expansion_256b
|
call _key_expansion_256b_local
|
||||||
aeskeygenassist $0x40, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x40, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_256a
|
call _key_expansion_256a_local
|
||||||
|
|
||||||
SET_TS_OR_POP_XMM0_TO_XMM6(%r10)
|
|
||||||
#ifdef OPENSSL_INTERFACE
|
#ifdef OPENSSL_INTERFACE
|
||||||
xor %rax, %rax // return 0 (OK)
|
xor %rax, %rax // return 0 (OK)
|
||||||
#else /* Open Solaris Interface */
|
#else /* Open Solaris Interface */
|
||||||
mov $14, %rax // return # rounds = 14
|
mov $14, %rax // return # rounds = 14
|
||||||
#endif
|
#endif
|
||||||
|
FRAME_END
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.align 4
|
.align 4
|
||||||
|
@ -493,28 +392,28 @@ rijndael_key_setup_enc_intel_local:
|
||||||
|
|
||||||
movq 0x10(%USERCIPHERKEY), %xmm2 // other user key
|
movq 0x10(%USERCIPHERKEY), %xmm2 // other user key
|
||||||
aeskeygenassist $0x1, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x1, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192a
|
call _key_expansion_192a_local
|
||||||
aeskeygenassist $0x2, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x2, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192b
|
call _key_expansion_192b_local
|
||||||
aeskeygenassist $0x4, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x4, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192a
|
call _key_expansion_192a_local
|
||||||
aeskeygenassist $0x8, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x8, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192b
|
call _key_expansion_192b_local
|
||||||
aeskeygenassist $0x10, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x10, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192a
|
call _key_expansion_192a_local
|
||||||
aeskeygenassist $0x20, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x20, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192b
|
call _key_expansion_192b_local
|
||||||
aeskeygenassist $0x40, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x40, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192a
|
call _key_expansion_192a_local
|
||||||
aeskeygenassist $0x80, %xmm2, %xmm1 // expand the key
|
aeskeygenassist $0x80, %xmm2, %xmm1 // expand the key
|
||||||
call _key_expansion_192b
|
call _key_expansion_192b_local
|
||||||
|
|
||||||
SET_TS_OR_POP_XMM0_TO_XMM6(%r10)
|
|
||||||
#ifdef OPENSSL_INTERFACE
|
#ifdef OPENSSL_INTERFACE
|
||||||
xor %rax, %rax // return 0 (OK)
|
xor %rax, %rax // return 0 (OK)
|
||||||
#else /* OpenSolaris Interface */
|
#else /* OpenSolaris Interface */
|
||||||
mov $12, %rax // return # rounds = 12
|
mov $12, %rax // return # rounds = 12
|
||||||
#endif
|
#endif
|
||||||
|
FRAME_END
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.align 4
|
.align 4
|
||||||
|
@ -529,51 +428,50 @@ rijndael_key_setup_enc_intel_local:
|
||||||
#endif /* OPENSSL_INTERFACE */
|
#endif /* OPENSSL_INTERFACE */
|
||||||
|
|
||||||
aeskeygenassist $0x1, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x1, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x2, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x2, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x4, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x4, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x8, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x8, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x10, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x10, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x20, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x20, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x40, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x40, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x80, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x80, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x1b, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x1b, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
aeskeygenassist $0x36, %xmm0, %xmm1 // expand the key
|
aeskeygenassist $0x36, %xmm0, %xmm1 // expand the key
|
||||||
call _key_expansion_128
|
call _key_expansion_128_local
|
||||||
|
|
||||||
SET_TS_OR_POP_XMM0_TO_XMM6(%r10)
|
|
||||||
#ifdef OPENSSL_INTERFACE
|
#ifdef OPENSSL_INTERFACE
|
||||||
xor %rax, %rax // return 0 (OK)
|
xor %rax, %rax // return 0 (OK)
|
||||||
#else /* OpenSolaris Interface */
|
#else /* OpenSolaris Interface */
|
||||||
mov $10, %rax // return # rounds = 10
|
mov $10, %rax // return # rounds = 10
|
||||||
#endif
|
#endif
|
||||||
|
FRAME_END
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.Lenc_key_invalid_param:
|
.Lenc_key_invalid_param:
|
||||||
#ifdef OPENSSL_INTERFACE
|
#ifdef OPENSSL_INTERFACE
|
||||||
SET_TS_OR_POP_XMM0_TO_XMM6(%r10)
|
|
||||||
mov $-1, %rax // user key or AES key pointer is NULL
|
mov $-1, %rax // user key or AES key pointer is NULL
|
||||||
|
FRAME_END
|
||||||
ret
|
ret
|
||||||
#else
|
#else
|
||||||
/* FALLTHROUGH */
|
/* FALLTHROUGH */
|
||||||
#endif /* OPENSSL_INTERFACE */
|
#endif /* OPENSSL_INTERFACE */
|
||||||
|
|
||||||
.Lenc_key_invalid_key_bits:
|
.Lenc_key_invalid_key_bits:
|
||||||
SET_TS_OR_POP_XMM0_TO_XMM6(%r10)
|
|
||||||
#ifdef OPENSSL_INTERFACE
|
#ifdef OPENSSL_INTERFACE
|
||||||
mov $-2, %rax // keysize is invalid
|
mov $-2, %rax // keysize is invalid
|
||||||
#else /* Open Solaris Interface */
|
#else /* Open Solaris Interface */
|
||||||
xor %rax, %rax // a key pointer is NULL or invalid keysize
|
xor %rax, %rax // a key pointer is NULL or invalid keysize
|
||||||
#endif /* OPENSSL_INTERFACE */
|
#endif /* OPENSSL_INTERFACE */
|
||||||
|
FRAME_END
|
||||||
ret
|
ret
|
||||||
SET_SIZE(rijndael_key_setup_enc_intel)
|
SET_SIZE(rijndael_key_setup_enc_intel)
|
||||||
|
|
||||||
|
@ -599,7 +497,9 @@ rijndael_key_setup_enc_intel_local:
|
||||||
* const int bits, AES_KEY *key);
|
* const int bits, AES_KEY *key);
|
||||||
* Return value is non-zero on error, 0 on success.
|
* Return value is non-zero on error, 0 on success.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ENTRY_NP(rijndael_key_setup_dec_intel)
|
ENTRY_NP(rijndael_key_setup_dec_intel)
|
||||||
|
FRAME_BEGIN
|
||||||
// Generate round keys used for encryption
|
// Generate round keys used for encryption
|
||||||
call rijndael_key_setup_enc_intel_local
|
call rijndael_key_setup_enc_intel_local
|
||||||
test %rax, %rax
|
test %rax, %rax
|
||||||
|
@ -609,8 +509,6 @@ ENTRY_NP(rijndael_key_setup_dec_intel)
|
||||||
jz .Ldec_key_exit // Failed if returned 0
|
jz .Ldec_key_exit // Failed if returned 0
|
||||||
#endif /* OPENSSL_INTERFACE */
|
#endif /* OPENSSL_INTERFACE */
|
||||||
|
|
||||||
CLEAR_TS_OR_PUSH_XMM0_XMM1(%r10)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Convert round keys used for encryption
|
* Convert round keys used for encryption
|
||||||
* to a form usable for decryption
|
* to a form usable for decryption
|
||||||
|
@ -647,11 +545,10 @@ ENTRY_NP(rijndael_key_setup_dec_intel)
|
||||||
cmp %ENDAESKEY, %rcx
|
cmp %ENDAESKEY, %rcx
|
||||||
jnz .Ldec_key_inv_loop
|
jnz .Ldec_key_inv_loop
|
||||||
|
|
||||||
SET_TS_OR_POP_XMM0_XMM1(%r10)
|
|
||||||
|
|
||||||
.Ldec_key_exit:
|
.Ldec_key_exit:
|
||||||
// OpenSolaris: rax = # rounds (10, 12, or 14) or 0 for error
|
// OpenSolaris: rax = # rounds (10, 12, or 14) or 0 for error
|
||||||
// OpenSSL: rax = 0 for OK, or non-zero for error
|
// OpenSSL: rax = 0 for OK, or non-zero for error
|
||||||
|
FRAME_END
|
||||||
ret
|
ret
|
||||||
SET_SIZE(rijndael_key_setup_dec_intel)
|
SET_SIZE(rijndael_key_setup_dec_intel)
|
||||||
|
|
||||||
|
@ -701,8 +598,8 @@ ENTRY_NP(rijndael_key_setup_dec_intel)
|
||||||
#define STATE xmm0 /* temporary, 128 bits */
|
#define STATE xmm0 /* temporary, 128 bits */
|
||||||
#define KEY xmm1 /* temporary, 128 bits */
|
#define KEY xmm1 /* temporary, 128 bits */
|
||||||
|
|
||||||
|
|
||||||
ENTRY_NP(aes_encrypt_intel)
|
ENTRY_NP(aes_encrypt_intel)
|
||||||
CLEAR_TS_OR_PUSH_XMM0_XMM1(%r10)
|
|
||||||
|
|
||||||
movups (%INP), %STATE // input
|
movups (%INP), %STATE // input
|
||||||
movaps (%KEYP), %KEY // key
|
movaps (%KEYP), %KEY // key
|
||||||
|
@ -759,7 +656,6 @@ ENTRY_NP(aes_encrypt_intel)
|
||||||
aesenclast %KEY, %STATE // last round
|
aesenclast %KEY, %STATE // last round
|
||||||
movups %STATE, (%OUTP) // output
|
movups %STATE, (%OUTP) // output
|
||||||
|
|
||||||
SET_TS_OR_POP_XMM0_XMM1(%r10)
|
|
||||||
ret
|
ret
|
||||||
SET_SIZE(aes_encrypt_intel)
|
SET_SIZE(aes_encrypt_intel)
|
||||||
|
|
||||||
|
@ -787,7 +683,6 @@ ENTRY_NP(aes_encrypt_intel)
|
||||||
* const AES_KEY *key);
|
* const AES_KEY *key);
|
||||||
*/
|
*/
|
||||||
ENTRY_NP(aes_decrypt_intel)
|
ENTRY_NP(aes_decrypt_intel)
|
||||||
CLEAR_TS_OR_PUSH_XMM0_XMM1(%r10)
|
|
||||||
|
|
||||||
movups (%INP), %STATE // input
|
movups (%INP), %STATE // input
|
||||||
movaps (%KEYP), %KEY // key
|
movaps (%KEYP), %KEY // key
|
||||||
|
@ -844,7 +739,6 @@ ENTRY_NP(aes_decrypt_intel)
|
||||||
aesdeclast %KEY, %STATE // last round
|
aesdeclast %KEY, %STATE // last round
|
||||||
movups %STATE, (%OUTP) // output
|
movups %STATE, (%OUTP) // output
|
||||||
|
|
||||||
SET_TS_OR_POP_XMM0_XMM1(%r10)
|
|
||||||
ret
|
ret
|
||||||
SET_SIZE(aes_decrypt_intel)
|
SET_SIZE(aes_decrypt_intel)
|
||||||
|
|
||||||
|
|
|
@ -95,99 +95,18 @@ gcm_mul_pclmulqdq(uint64_t *x_in, uint64_t *y, uint64_t *res) {
|
||||||
#define _ASM
|
#define _ASM
|
||||||
#include <sys/asm_linkage.h>
|
#include <sys/asm_linkage.h>
|
||||||
|
|
||||||
#ifdef _KERNEL
|
|
||||||
/*
|
|
||||||
* Note: the CLTS macro clobbers P2 (%rsi) under i86xpv. That is,
|
|
||||||
* it calls HYPERVISOR_fpu_taskswitch() which modifies %rsi when it
|
|
||||||
* uses it to pass P2 to syscall.
|
|
||||||
* This also occurs with the STTS macro, but we dont care if
|
|
||||||
* P2 (%rsi) is modified just before function exit.
|
|
||||||
* The CLTS and STTS macros push and pop P1 (%rdi) already.
|
|
||||||
*/
|
|
||||||
#ifdef __xpv
|
|
||||||
#define PROTECTED_CLTS \
|
|
||||||
push %rsi; \
|
|
||||||
CLTS; \
|
|
||||||
pop %rsi
|
|
||||||
#else
|
|
||||||
#define PROTECTED_CLTS \
|
|
||||||
CLTS
|
|
||||||
#endif /* __xpv */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If CR0_TS is not set, align stack (with push %rbp) and push
|
|
||||||
* %xmm0 - %xmm10 on stack, otherwise clear CR0_TS
|
|
||||||
*/
|
|
||||||
#define CLEAR_TS_OR_PUSH_XMM_REGISTERS(tmpreg) \
|
|
||||||
push %rbp; \
|
|
||||||
mov %rsp, %rbp; \
|
|
||||||
movq %cr0, tmpreg; \
|
|
||||||
testq $CR0_TS, tmpreg; \
|
|
||||||
jnz 1f; \
|
|
||||||
and $-XMM_ALIGN, %rsp; \
|
|
||||||
sub $[XMM_SIZE * 11], %rsp; \
|
|
||||||
movaps %xmm0, 160(%rsp); \
|
|
||||||
movaps %xmm1, 144(%rsp); \
|
|
||||||
movaps %xmm2, 128(%rsp); \
|
|
||||||
movaps %xmm3, 112(%rsp); \
|
|
||||||
movaps %xmm4, 96(%rsp); \
|
|
||||||
movaps %xmm5, 80(%rsp); \
|
|
||||||
movaps %xmm6, 64(%rsp); \
|
|
||||||
movaps %xmm7, 48(%rsp); \
|
|
||||||
movaps %xmm8, 32(%rsp); \
|
|
||||||
movaps %xmm9, 16(%rsp); \
|
|
||||||
movaps %xmm10, (%rsp); \
|
|
||||||
jmp 2f; \
|
|
||||||
1: \
|
|
||||||
PROTECTED_CLTS; \
|
|
||||||
2:
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If CR0_TS was not set above, pop %xmm0 - %xmm10 off stack,
|
|
||||||
* otherwise set CR0_TS.
|
|
||||||
*/
|
|
||||||
#define SET_TS_OR_POP_XMM_REGISTERS(tmpreg) \
|
|
||||||
testq $CR0_TS, tmpreg; \
|
|
||||||
jnz 1f; \
|
|
||||||
movaps (%rsp), %xmm10; \
|
|
||||||
movaps 16(%rsp), %xmm9; \
|
|
||||||
movaps 32(%rsp), %xmm8; \
|
|
||||||
movaps 48(%rsp), %xmm7; \
|
|
||||||
movaps 64(%rsp), %xmm6; \
|
|
||||||
movaps 80(%rsp), %xmm5; \
|
|
||||||
movaps 96(%rsp), %xmm4; \
|
|
||||||
movaps 112(%rsp), %xmm3; \
|
|
||||||
movaps 128(%rsp), %xmm2; \
|
|
||||||
movaps 144(%rsp), %xmm1; \
|
|
||||||
movaps 160(%rsp), %xmm0; \
|
|
||||||
jmp 2f; \
|
|
||||||
1: \
|
|
||||||
STTS(tmpreg); \
|
|
||||||
2: \
|
|
||||||
mov %rbp, %rsp; \
|
|
||||||
pop %rbp
|
|
||||||
|
|
||||||
|
|
||||||
#else
|
|
||||||
#define PROTECTED_CLTS
|
|
||||||
#define CLEAR_TS_OR_PUSH_XMM_REGISTERS(tmpreg)
|
|
||||||
#define SET_TS_OR_POP_XMM_REGISTERS(tmpreg)
|
|
||||||
#endif /* _KERNEL */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Use this mask to byte-swap a 16-byte integer with the pshufb instruction
|
* Use this mask to byte-swap a 16-byte integer with the pshufb instruction
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// static uint8_t byte_swap16_mask[] = {
|
// static uint8_t byte_swap16_mask[] = {
|
||||||
// 15, 14, 13, 12, 11, 10, 9, 8, 7, 6 ,5, 4, 3, 2, 1, 0 };
|
// 15, 14, 13, 12, 11, 10, 9, 8, 7, 6 ,5, 4, 3, 2, 1, 0 };
|
||||||
.text
|
.data
|
||||||
.align XMM_ALIGN
|
.align XMM_ALIGN
|
||||||
.Lbyte_swap16_mask:
|
.Lbyte_swap16_mask:
|
||||||
.byte 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0
|
.byte 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* void gcm_mul_pclmulqdq(uint64_t *x_in, uint64_t *y, uint64_t *res);
|
* void gcm_mul_pclmulqdq(uint64_t *x_in, uint64_t *y, uint64_t *res);
|
||||||
*
|
*
|
||||||
|
@ -221,8 +140,6 @@ gcm_mul_pclmulqdq(uint64_t *x_in, uint64_t *y, uint64_t *res) {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ENTRY_NP(gcm_mul_pclmulqdq)
|
ENTRY_NP(gcm_mul_pclmulqdq)
|
||||||
CLEAR_TS_OR_PUSH_XMM_REGISTERS(%r10)
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Copy Parameters
|
// Copy Parameters
|
||||||
//
|
//
|
||||||
|
@ -325,9 +242,8 @@ ENTRY_NP(gcm_mul_pclmulqdq)
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Cleanup and Return
|
// Return
|
||||||
//
|
//
|
||||||
SET_TS_OR_POP_XMM_REGISTERS(%r10)
|
|
||||||
ret
|
ret
|
||||||
SET_SIZE(gcm_mul_pclmulqdq)
|
SET_SIZE(gcm_mul_pclmulqdq)
|
||||||
|
|
||||||
|
|
|
@ -58,6 +58,7 @@
|
||||||
#include <sys/stdint.h>
|
#include <sys/stdint.h>
|
||||||
#include <sys/sha1.h>
|
#include <sys/sha1.h>
|
||||||
|
|
||||||
|
|
||||||
/* ARGSUSED */
|
/* ARGSUSED */
|
||||||
void
|
void
|
||||||
sha1_block_data_order(SHA1_CTX *ctx, const void *inpp, size_t blocks)
|
sha1_block_data_order(SHA1_CTX *ctx, const void *inpp, size_t blocks)
|
||||||
|
@ -1341,6 +1342,8 @@ ENTRY_NP(sha1_block_data_order)
|
||||||
pop %rbx
|
pop %rbx
|
||||||
ret
|
ret
|
||||||
SET_SIZE(sha1_block_data_order)
|
SET_SIZE(sha1_block_data_order)
|
||||||
|
|
||||||
|
.data
|
||||||
.asciz "SHA1 block transform for x86_64, CRYPTOGAMS by <appro@openssl.org>"
|
.asciz "SHA1 block transform for x86_64, CRYPTOGAMS by <appro@openssl.org>"
|
||||||
|
|
||||||
#endif /* lint || __lint */
|
#endif /* lint || __lint */
|
||||||
|
|
|
@ -2036,6 +2036,7 @@ ENTRY_NP(SHA256TransformBlocks)
|
||||||
ret
|
ret
|
||||||
SET_SIZE(SHA256TransformBlocks)
|
SET_SIZE(SHA256TransformBlocks)
|
||||||
|
|
||||||
|
.data
|
||||||
.align 64
|
.align 64
|
||||||
.type K256,@object
|
.type K256,@object
|
||||||
K256:
|
K256:
|
||||||
|
|
|
@ -2037,6 +2037,7 @@ ENTRY_NP(SHA512TransformBlocks)
|
||||||
ret
|
ret
|
||||||
SET_SIZE(SHA512TransformBlocks)
|
SET_SIZE(SHA512TransformBlocks)
|
||||||
|
|
||||||
|
.data
|
||||||
.align 64
|
.align 64
|
||||||
.type K512,@object
|
.type K512,@object
|
||||||
K512:
|
K512:
|
||||||
|
|
|
@ -33,4 +33,14 @@
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(_KERNEL) && defined(HAVE_KERNEL_OBJTOOL)
|
||||||
|
|
||||||
|
#include <asm/frame.h>
|
||||||
|
|
||||||
|
#else /* userspace */
|
||||||
|
#define FRAME_BEGIN
|
||||||
|
#define FRAME_END
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif /* _SYS_ASM_LINKAGE_H */
|
#endif /* _SYS_ASM_LINKAGE_H */
|
||||||
|
|
Loading…
Reference in New Issue