Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Openssl
提交
c7c7a8e6
T
Third Party Openssl
项目概览
OpenHarmony
/
Third Party Openssl
接近 2 年 前同步成功
通知
12
Star
18
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Openssl
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
c7c7a8e6
编写于
7月 08, 2017
作者:
A
Andy Polyakov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Optimize sha/asm/keccak1600-avx2.pl.
Reviewed-by:
N
Rich Salz
<
rsalz@openssl.org
>
上级
29724d0e
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
87 addition
and
84 deletion
+87
-84
crypto/sha/asm/keccak1600-avx2.pl
crypto/sha/asm/keccak1600-avx2.pl
+87
-84
未找到文件。
crypto/sha/asm/keccak1600-avx2.pl
浏览文件 @
c7c7a8e6
...
@@ -111,10 +111,16 @@ my @A_jagged = ([0,0], [1,0], [1,1], [1,2], [1,3], # [0][0..4]
...
@@ -111,10 +111,16 @@ my @A_jagged = ([0,0], [1,0], [1,1], [1,2], [1,3], # [0][0..4]
#
#
# r=1088(*)
# r=1088(*)
#
#
# Haswell 9.6
# Haswell 8.9/+8%
# Skylake 8.8
# Skylake 7.9/+19%
# Ryzen 17(**)
#
#
# (*) Corresponds to SHA3-256.
# (*) Corresponds to SHA3-256. Percentage after slash is improvement
# coefficient in comparison to scalar keccak1600-x86_64.pl.
# (**) It's expected that Ryzen performs poorly, because instruction
# issue rate is limited to two AVX2 instructions per cycle and
# in addition vpblendd is reportedly bound to specific port.
# Obviously this code path should not be executed on Ryzen.
my
@T
=
map
("
%ymm
$_
",(
7
..
15
));
my
@T
=
map
("
%ymm
$_
",(
7
..
15
));
my
(
$C14
,
$C00
,
$D00
,
$D14
)
=
@T
[
5
..
8
];
my
(
$C14
,
$C00
,
$D00
,
$D14
)
=
@T
[
5
..
8
];
...
@@ -134,138 +140,135 @@ __KeccakF1600:
...
@@ -134,138 +140,135 @@ __KeccakF1600:
.align 32
.align 32
.Loop_avx2:
.Loop_avx2:
######################################### Theta
######################################### Theta
vpxor $A01,$A31,$C14
vpshufd \$0b01001110,$A20,$C00
vpxor $A21,$C14,$C14
vpxor $A31,$A01,$C14
vpxor $A41,$C14,$C14
vpxor $A41,$A21,@T[0]
vpxor $A11,$C14,$C14 # C[1..4]
vpxor $A11,$C14,$C14
vpermq \$0b10110001,$A20,$C00
vpxor @T[0],$C14,$C14 # C[1..4]
vpermq \$0b11111111,$C14,@T[3]
vpermq \$0b10010011,$C14,@T[4]
vpxor $A20,$C00,$C00
vpxor $A20,$C00,$C00
vpermq \$0b01001110,$C00,@T[0]
vpermq \$0b01001110,$C00,@T[0]
vpxor $A00,$C00,$C00
vpxor @T[0],$C00,$C00 # C[0..0]
vpsrlq \$63,$C14,@T[1]
vpsrlq \$63,$C14,@T[1]
vpaddq $C14,$C14,@T[
3
]
vpaddq $C14,$C14,@T[
2
]
vpor @T[
3
],@T[1],@T[1] # ROL64(C[1..4],1)
vpor @T[
2
],@T[1],@T[1] # ROL64(C[1..4],1)
vpsrlq \$63,$C00,@T[0]
vpermq \$0b00111001,@T[1],$D14
vpaddq $C00,$C00,@T[2]
vpxor @T[3],@T[1],$D00
vpor @T[2],@T[0],@T[0] # ROL64(C[0..0],1)
vpermq \$0b00000000,@T[1],$D00
vpxor $A00,$C00,$C00
vpermq \$0b11111111,$C14,@T[3]
vpxor @T[0],$C00,$C00 # C[0..0]
vpxor @T[3],$D00,$D00 # D[0..0] = ROL64(C[1],1) ^ C[4]
vpermq \$0b00111001,@T[1],$D14
vpsrlq \$63,$C00,@T[0]
vpblendd \$0b11000000,@T[0],$D14,$D14
vpaddq $C00,$C00,@T[1]
vpermq \$0b10010011,$C14,@T[2]
vpor @T[0],@T[1],@T[1] # ROL64(C[0..0],1)
vpblendd \$0b00000011,$C00,@T[2],@T[2]
vpxor @T[2],$D14,$D14 # D[1..4] = ROL64(C[2..4,0),1) ^ C[0..3]
vp
xor $D00,$A00,$A00 # ^= D[0..0
]
vp
ermq \$0b00000000,$D00,$D00 # D[0..0] = ROL64(C[1],1) ^ C[4
]
vpxor $D00,$A20,$A20 # ^= D[0..0]
vpxor $D00,$A20,$A20 # ^= D[0..0]
vpxor $D
14,$A01,$A01 # ^= D[1..4
]
vpxor $D
00,$A00,$A00 # ^= D[0..0
]
vpxor $D14,$A31,$A31 # ^= D[1..4]
vp
xor $D14,$A21,$A21 # ^= D[1..4]
vp
blendd \$0b11000000,@T[1],$D14,$D14
vp
xor $D14,$A41,$A41 # ^= D[1..
4]
vp
blendd \$0b00000011,$C00,@T[4],@T[
4]
vpxor
$D14,$A11,$A11 # ^= D[1..4
]
vpxor
@T[4],$D14,$D14 # D[1..4] = ROL64(C[2..4,0),1) ^ C[0..3
]
######################################### Rho
######################################### Rho
+ Pi + pre-Chi shuffle
vpsllvq 0*32-96(%r8),$A20,@T[0]
vpsllvq 0*32-96(%r8),$A20,@T[0]
vpsrlvq 0*32-96(%r9),$A20,$A20
vpsrlvq 0*32-96(%r9),$A20,$A20
vpor @T[0],$A20,$A20
vpor $A20,@T[0],@T[0] # $A20
vpsllvq 1*32-96(%r8),$A01,@T[1]
vpsrlvq 1*32-96(%r9),$A01,$A01
vpor @T[1],$A01,$A01
vpxor $D14,$A31,$A31 # ^= D[1..4]
vpsllvq 2*32-96(%r8),$A31,@T[2]
vpsllvq 2*32-96(%r8),$A31,@T[2]
vpsrlvq 2*32-96(%r9),$A31,$A31
vpsrlvq 2*32-96(%r9),$A31,$A31
vpor
@T[2],$A31,
$A31
vpor
$A31,@T[2],@T[2] #
$A31
vpxor $D14,$A21,$A21 # ^= D[1..4]
vpsllvq 3*32-96(%r8),$A21,@T[3]
vpsllvq 3*32-96(%r8),$A21,@T[3]
vpsrlvq 3*32-96(%r9),$A21,$A21
vpsrlvq 3*32-96(%r9),$A21,$A21
vpor
@T[3],$A21,
$A21
vpor
$A21,@T[3],@T[3] #
$A21
vpermq \$0b10001101,@T[0],$A31 # $A20 -> $A31
vpermq \$0b10001101,@T[2],$A21 # $A31 -> $A21
vpxor $D14,$A41,$A41 # ^= D[1..4]
vpsllvq 4*32-96(%r8),$A41,@T[4]
vpsllvq 4*32-96(%r8),$A41,@T[4]
vpsrlvq 4*32-96(%r9),$A41,$A41
vpsrlvq 4*32-96(%r9),$A41,$A41
vpor @T[4],$A41,$A41
vpsllvq 5*32-96(%r8),$A11,@T[5]
vpxor $D14,$A01,$A01 # ^= D[1..4]
vpsrlvq 5*32-96(%r9),$A11,$A11
vpxor $D14,$A11,$T[6] # ^= D[1..4]
vpor @T[5],$A11,$A11
vpsllvq 1*32-96(%r8),$A01,@T[1]
vpsrlvq 1*32-96(%r9),$A01,$A01
vpor $A41,@T[4],@T[4] # $A41
vpor @T[1],$A01,$A20 # $A01 -> $A20
######################################### Pi + pre-Chi shuffle
vpermq \$0b00011011,@T[3],$A41 # $A21 -> $A41
vpermq \$0b01110010,$A41,@T[0] # vpermq \$0b00011011,$A41,@T[0]
vpermq \$0b01110010,@T[4],$A11 # $A41 -> $A11
vpermq \$0b00011011,$A21,$A41 # vpermq \$0b01110010,$A21,$A41
vpsllvq 5*32-96(%r8),$T[6],@T[5]
vpermq \$0b10001101,$A31,$A21
vpsrlvq 5*32-96(%r9),@T[6],@T[6]
vpermq \$0b10001101,$A20,$A31 # vpermq \$0b01110010,$A20,$A31
vpor @T[5],@T[6],$A01 # $A11 -> $A01
vmovdqa $A01,$A20
vmovdqa $A11,$A01
vmovdqa @T[0],$A11
######################################### Chi
######################################### Chi
vpermq \$0b00000000,$A01,@T[0] # [0][1] [0][1] [0][1] [0][1]
vpsrldq \$8,$A01,@T[0]
vpermq \$0b01010101,$A01,@T[2] # [0][2] [0][2] [0][2] [0][2]
vpandn @T[0],$A01,@T[0] # tgting [0][0]
vpandn @T[2],@T[0],@T[0] # tgting [0][0] [0][0] [0][0] [0][0]
vpermq \$0b00111001,$A01,@T[1] # [0][1] [0][4] [0][3] [0][2]
vpermq \$0b00111001,$A01,@T[1] # [0][1] [0][4] [0][3] [0][2]
vpermq \$0b00011110,$A01,@T[
3
] # [0][1] [0][2] [0][4] [0][3]
vpermq \$0b00011110,$A01,@T[
8
] # [0][1] [0][2] [0][4] [0][3]
vpblendd \$0b11000000,$A00,@T[1],@T[1] # [0][0] [0][4] [0][3] [0][2]
vpblendd \$0b11000000,$A00,@T[1],@T[1] # [0][0] [0][4] [0][3] [0][2]
vpblendd \$0b00110000,$A00,@T[3],@T[3] # [0][1] [0][0] [0][4] [0][3]
vpblendd \$0b00110000,$A00,@T[8],@T[8] # [0][1] [0][0] [0][4] [0][3]
vpandn @T[3],@T[1],@T[1] # tgting [0][4] [0][3] [0][2] [0][1]
vpxor @T[0],$A00,$A00 # broadcasted below
vpandn @T[8],@T[1],@T[1] # tgting [0][4] [0][3] [0][2] [0][1]
vpblendd \$0b00001100,$A41,$A21, @T[2] # [4][1] [2][1]
vpblendd \$0b00001100,$A41,$A21, @T[2] # [4][1] [2][1]
vpblendd \$0b00110000,$A11,@T[2],@T[2] # [1][1] [4][1] [2][1]
vpblendd \$0b11000000,$A31,@T[2],@T[2] # [3][1] [1][1] [4][1] [2][1]
vpblendd \$0b00001100,$A21,$A11, @T[4] # [4][2] [2][2]
vpblendd \$0b00001100,$A21,$A11, @T[4] # [4][2] [2][2]
vpblendd \$0b00110000,$A11,@T[2],@T[2] # [1][1] [4][1] [2][1]
vpblendd \$0b00110000,$A31,@T[4],@T[4] # [1][2] [4][2] [2][2]
vpblendd \$0b00110000,$A31,@T[4],@T[4] # [1][2] [4][2] [2][2]
vpblendd \$0b11000000,$A31,@T[2],@T[2] # [3][1] [1][1] [4][1] [2][1]
vpblendd \$0b11000000,$A41,@T[4],@T[4] # [3][2] [1][2] [4][2] [2][2]
vpblendd \$0b11000000,$A41,@T[4],@T[4] # [3][2] [1][2] [4][2] [2][2]
vpandn @T[4],@T[2],@T[2] # tgting [3][0] [1][0] [4][0] [2][0]
vpandn @T[4],@T[2],@T[2] # tgting [3][0] [1][0] [4][0] [2][0]
vpblendd \$0b00001100,$A11,$A20, @T[3] # [4][4] [2][0]
vpblendd \$0b00001100,$A11,$A20, @T[3] # [4][4] [2][0]
vpblendd \$0b00110000,$A21,@T[3],@T[3] # [1][3] [4][4] [2][0]
vpblendd \$0b11000000,$A41,@T[3],@T[3] # [3][2] [1][3] [4][4] [2][0]
vpblendd \$0b00001100,$A20,$A21, @T[5] # [4][0] [2][1]
vpblendd \$0b00001100,$A20,$A21, @T[5] # [4][0] [2][1]
vpblendd \$0b00110000,$A21,@T[3],@T[3] # [1][3] [4][4] [2][0]
vpblendd \$0b00110000,$A41,@T[5],@T[5] # [1][4] [4][0] [2][1]
vpblendd \$0b00110000,$A41,@T[5],@T[5] # [1][4] [4][0] [2][1]
vpblendd \$0b11000000,$A41,@T[3],@T[3] # [3][2] [1][3] [4][4] [2][0]
vpblendd \$0b11000000,$A11,@T[5],@T[5] # [3][3] [1][4] [4][0] [2][1]
vpblendd \$0b11000000,$A11,@T[5],@T[5] # [3][3] [1][4] [4][0] [2][1]
vpandn @T[5],@T[3],@T[3] # tgting [3][1] [1][2] [4][3] [2][4]
vpandn @T[5],@T[3],@T[3] # tgting [3][1] [1][2] [4][3] [2][4]
vpxor $A31,@T[3],@T[3]
vpblendd \$0b00001100,$A31,$A11, @T[4] # [4][3] [2][2]
vpblendd \$0b00110000,$A41,@T[4],@T[4] # [1][4] [4][3] [2][2]
vpblendd \$0b11000000,$A20,@T[4],@T[4] # [3][0] [1][4] [4][3] [2][2]
vpblendd \$0b00001100,$A11,$A41, @T[6] # [4][4] [2][3]
vpblendd \$0b00110000,$A20,@T[6],@T[6] # [1][0] [4][4] [2][3]
vpblendd \$0b11000000,$A31,@T[6],@T[6] # [3][1] [1][0] [4][4] [2][3]
vpandn @T[6],@T[4],@T[4] # tgting [3][4] [1][3] [4][2] [2][1]
vpblendd \$0b00001100,$A21,$A31, @T[5] # [4][2] [2][4]
vpblendd \$0b00001100,$A21,$A31, @T[5] # [4][2] [2][4]
vpblendd \$0b00001100,$A31,$A20, @T[6] # [4][3] [2][0]
vpblendd \$0b00110000,$A20,@T[5],@T[5] # [1][0] [4][2] [2][4]
vpblendd \$0b00110000,$A20,@T[5],@T[5] # [1][0] [4][2] [2][4]
vpblendd \$0b00110000,$A11,@T[6],@T[6] # [1][1] [4][3] [2][0]
vpblendd \$0b11000000,$A11,@T[5],@T[5] # [3][3] [1][0] [4][2] [2][4]
vpblendd \$0b11000000,$A11,@T[5],@T[5] # [3][3] [1][0] [4][2] [2][4]
vpblendd \$0b00001100,$A31,$A20, @T[7] # [4][3] [2][0]
vpblendd \$0b11000000,$A21,@T[6],@T[6] # [3][4] [1][1] [4][3] [2][0]
vpblendd \$0b00110000,$A11,@T[7],@T[7] # [1][1] [4][3] [2][0]
vpandn @T[6],@T[5],@T[5] # tgting [3][2] [1][4] [4][1] [2][3]
vpblendd \$0b11000000,$A21,@T[7],@T[7] # [3][4] [1][1] [4][3] [2][0]
vpxor $A41,@T[5],@T[5]
vpandn @T[7],@T[5],@T[5] # tgting [3][2] [1][4] [4][1] [2][3]
vpblendd \$0b00001100,$A20,$A41, @T[6] # [4][0] [2][3]
vpblendd \$0b00001100,$A20,$A41, @T[6] # [4][0] [2][3]
vpblendd \$0b00001100,$A41,$A31, @T[7] # [4][1] [2][4]
vpblendd \$0b00110000,$A31,@T[6],@T[6] # [1][2] [4][0] [2][3]
vpblendd \$0b00110000,$A31,@T[6],@T[6] # [1][2] [4][0] [2][3]
vpblendd \$0b00110000,$A21,@T[7],@T[7] # [1][3] [4][1] [2][4]
vpblendd \$0b11000000,$A21,@T[6],@T[6] # [3][4] [1][2] [4][0] [2][3]
vpblendd \$0b11000000,$A21,@T[6],@T[6] # [3][4] [1][2] [4][0] [2][3]
vpblendd \$0b00001100,$A41,$A31, @T[8] # [4][1] [2][4]
vpblendd \$0b11000000,$A20,@T[7],@T[7] # [3][0] [1][3] [4][1] [2][4]
vpblendd \$0b00110000,$A21,@T[8],@T[8] # [1][3] [4][1] [2][4]
vpblendd \$0b00001100,$A31,$A41, @T[4] # [1][4] [4][3]
vpblendd \$0b11000000,$A20,@T[8],@T[8] # [3][0] [1][3] [4][1] [2][4]
vpblendd \$0b11000000,$A31,$A41, @T[8] # [3][1] [2][3]
vpandn @T[8],@T[6],@T[6] # tgting [3][3] [1][1] [4][4] [2][2]
vpandn @T[7],@T[6],@T[6] # tgting [3][3] [1][1] [4][4] [2][2]
vpermq \$0b00011011,@T[3],$A31 ######### post-Chi shuffle
vpermq \$0b10001101,@T[5],$A41
vpxor $A11,@T[6],@T[6]
vpermq \$0b00000000,$A00,$A00 # broadcast A[0][0]
vpblendd \$0b00000011,$A11,@T[4],@T[4] # [1][4] [4][3] [2][2]
vpblendd \$0b00001100,$A11,@T[8],@T[8] # [3][1] [4][4] [2][3]
vpermq \$0b01110010,@T[6],$A11
vpblendd \$0b11000000,$A20,@T[4],@T[4] # [3][0] [1][4] [4][3] [2][2]
vpblendd \$0b00110000,$A20,@T[8],@T[8] # [3][1] [1][0] [4][4] [2][3]
vpandn @T[8],@T[4],@T[4] # tgting [3][4] [1][3] [4][2] [2][1]
vpxor @T[0],$A00,$A00
vpxor @T[1],$A01,$A01
vpxor @T[2],$A20,$A20
vpxor @T[2],$A20,$A20
vpxor @T[
3],$A31,$A3
1
vpxor @T[
1],$A01,$A0
1
vpxor @T[4],$A21,$A21
vpxor @T[4],$A21,$A21
vpxor @T[5],$A41,$A41
vpxor @T[6],$A11,$A11
vpermq \$0b00011011,$A31,$A31 # post-Chi shuffle
vpermq \$0b10001101,$A41,$A41
vpermq \$0b01110010,$A11,$A11
######################################### Iota
######################################### Iota
vpxor (%r10),$A00,$A00
vpxor (%r10),$A00,$A00
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录