提交 9c940446 编写于 作者: A Andy Polyakov

crypto/x86[_64]cpuid.pl: add OPENSSL_ia32_rd[rand|seed]_bytes.

Reviewed-by: NRichard Levitte <levitte@openssl.org>
上级 b1837abd
...@@ -805,7 +805,7 @@ my $rdrand = sub { ...@@ -805,7 +805,7 @@ my $rdrand = sub {
my @opcode=(); my @opcode=();
my $dst=$1; my $dst=$1;
if ($dst !~ /[0-9]+/) { $dst = $regrm{"%e$dst"}; } if ($dst !~ /[0-9]+/) { $dst = $regrm{"%e$dst"}; }
rex(\@opcode,0,$1,8); rex(\@opcode,0,$dst,8);
push @opcode,0x0f,0xc7,0xf0|($dst&7); push @opcode,0x0f,0xc7,0xf0|($dst&7);
@opcode; @opcode;
} else { } else {
...@@ -818,7 +818,7 @@ my $rdseed = sub { ...@@ -818,7 +818,7 @@ my $rdseed = sub {
my @opcode=(); my @opcode=();
my $dst=$1; my $dst=$1;
if ($dst !~ /[0-9]+/) { $dst = $regrm{"%e$dst"}; } if ($dst !~ /[0-9]+/) { $dst = $regrm{"%e$dst"}; }
rex(\@opcode,0,$1,8); rex(\@opcode,0,$dst,8);
push @opcode,0x0f,0xc7,0xf8|($dst&7); push @opcode,0x0f,0xc7,0xf8|($dst&7);
@opcode; @opcode;
} else { } else {
......
...@@ -393,36 +393,67 @@ OPENSSL_instrument_bus2: ...@@ -393,36 +393,67 @@ OPENSSL_instrument_bus2:
___ ___
} }
sub gen_random {
my $rdop = shift;
print<<___; print<<___;
.globl OPENSSL_ia32_rdrand .globl OPENSSL_ia32_${rdop}
.type OPENSSL_ia32_rdrand,\@abi-omnipotent .type OPENSSL_ia32_${rdop},\@abi-omnipotent
.align 16 .align 16
OPENSSL_ia32_rdrand: OPENSSL_ia32_${rdop}:
mov \$8,%ecx mov \$8,%ecx
.Loop_rdrand: .Loop_${rdop}:
rdrand %rax ${rdop} %rax
jc .Lbreak_rdrand jc .Lbreak_${rdop}
loop .Loop_rdrand loop .Loop_${rdop}
.Lbreak_rdrand: .Lbreak_${rdop}:
cmp \$0,%rax cmp \$0,%rax
cmove %rcx,%rax cmove %rcx,%rax
ret ret
.size OPENSSL_ia32_rdrand,.-OPENSSL_ia32_rdrand .size OPENSSL_ia32_${rdop},.-OPENSSL_ia32_${rdop}
.globl OPENSSL_ia32_rdseed .globl OPENSSL_ia32_${rdop}_bytes
.type OPENSSL_ia32_rdseed,\@abi-omnipotent .type OPENSSL_ia32_${rdop}_bytes,\@abi-omnipotent
.align 16 .align 16
OPENSSL_ia32_rdseed: OPENSSL_ia32_${rdop}_bytes:
mov \$8,%ecx xor %rax, %rax # return value
.Loop_rdseed: cmp \$0,$arg2
rdseed %rax je .Ldone_${rdop}_bytes
jc .Lbreak_rdseed
loop .Loop_rdseed mov \$8,%r11
.Lbreak_rdseed: .Loop_${rdop}_bytes:
cmp \$0,%rax ${rdop} %r10
cmove %rcx,%rax jc .Lbreak_${rdop}_bytes
dec %r11
jnz .Loop_${rdop}_bytes
jmp .Ldone_${rdop}_bytes
.align 16
.Lbreak_${rdop}_bytes:
cmp \$8,$arg2
jb .Ltail_${rdop}_bytes
mov %r10,($arg1)
lea 8($arg1),$arg1
add \$8,%rax
sub \$8,$arg2
jz .Ldone_${rdop}_bytes
mov \$8,%r11
jmp .Loop_${rdop}_bytes
.align 16
.Ltail_${rdop}_bytes:
mov %r10b,($arg1)
lea 1($arg1),$arg1
inc %rax
shr \$8,%r8
dec $arg2
jnz .Ltail_${rdop}_bytes
.Ldone_${rdop}_bytes:
ret ret
.size OPENSSL_ia32_rdseed,.-OPENSSL_ia32_rdseed .size OPENSSL_ia32_${rdop}_bytes,.-OPENSSL_ia32_${rdop}_bytes
___ ___
}
gen_random("rdrand");
gen_random("rdseed");
close STDOUT; # flush close STDOUT; # flush
...@@ -492,29 +492,64 @@ my $max = "ebp"; ...@@ -492,29 +492,64 @@ my $max = "ebp";
&function_end("OPENSSL_instrument_bus2"); &function_end("OPENSSL_instrument_bus2");
} }
&function_begin_B("OPENSSL_ia32_rdrand"); sub gen_random {
my $rdop = shift;
&function_begin_B("OPENSSL_ia32_${rdop}");
&mov ("ecx",8); &mov ("ecx",8);
&set_label("loop"); &set_label("loop");
&rdrand ("eax"); &${rdop}("eax");
&jc (&label("break")); &jc (&label("break"));
&loop (&label("loop")); &loop (&label("loop"));
&set_label("break"); &set_label("break");
&cmp ("eax",0); &cmp ("eax",0);
&cmove ("eax","ecx"); &cmove ("eax","ecx");
&ret (); &ret ();
&function_end_B("OPENSSL_ia32_rdrand"); &function_end_B("OPENSSL_ia32_${rdop}");
&function_begin_B("OPENSSL_ia32_${rdop}_bytes");
&push ("edi");
&push ("ebx");
&xor ("eax","eax"); # return value
&mov ("edi",&wparam(0));
&mov ("ebx",&wparam(1));
&cmp ("ebx",0);
&je (&label("done"));
&function_begin_B("OPENSSL_ia32_rdseed");
&mov ("ecx",8); &mov ("ecx",8);
&set_label("loop"); &set_label("loop");
&rdseed ("eax"); &${rdop}("edx");
&jc (&label("break")); &jc (&label("break"));
&loop (&label("loop")); &loop (&label("loop"));
&set_label("break"); &jmp (&label("done"));
&cmp ("eax",0);
&cmove ("eax","ecx"); &set_label("break",16);
&cmp ("ebx",4);
&jb (&label("tail"));
&mov (&DWP(0,"edi"),"edx");
&lea ("edi",&DWP(4,"edi"));
&add ("eax",4);
&sub ("ebx",4);
&jz (&label("done"));
&mov ("ecx",8);
&jmp (&label("loop"));
&set_label("tail",16);
&mov (&BP(0,"edi"),"dl");
&lea ("edi",&DWP(1,"edi"));
&inc ("eax");
&shr ("edx",8);
&dec ("ebx");
&jnz (&label("tail"));
&set_label("done");
&pop ("ebx");
&pop ("edi");
&ret (); &ret ();
&function_end_B("OPENSSL_ia32_rdseed"); &function_end_B("OPENSSL_ia32_${rdop}_bytes");
}
&gen_random("rdrand");
&gen_random("rdseed");
&initseg("OPENSSL_cpuid_setup"); &initseg("OPENSSL_cpuid_setup");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册