6410e18e91
This change syncs several assembly files from upstream. The only meanful additions are more CFI directives. Change-Id: I6aec50b6fddbea297b79bae22cfd68d5c115220f Reviewed-on: https://boringssl-review.googlesource.com/30364 Reviewed-by: Adam Langley <agl@google.com>
80 lines
2.3 KiB
Raku
80 lines
2.3 KiB
Raku
#!/usr/bin/env perl
|
|
|
|
# Copyright (c) 2015, Google Inc.
|
|
#
|
|
# Permission to use, copy, modify, and/or distribute this software for any
|
|
# purpose with or without fee is hereby granted, provided that the above
|
|
# copyright notice and this permission notice appear in all copies.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
|
# SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
|
|
# OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
|
# CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
|
|
|
|
$flavour = shift;
|
|
$output = shift;
|
|
if ($flavour =~ /\./) { $output = $flavour; undef $flavour; }
|
|
|
|
$0 =~ m/(.*[\/\\])[^\/\\]+$/; $dir=$1;
|
|
( $xlate="${dir}../../../perlasm/x86_64-xlate.pl" and -f $xlate) or
|
|
die "can't locate x86_64-xlate.pl";
|
|
|
|
open OUT,"| \"$^X\" $xlate $flavour $output";
|
|
*STDOUT=*OUT;
|
|
|
|
print<<___;
|
|
.text
|
|
|
|
# CRYPTO_rdrand writes eight bytes of random data from the hardware RNG to
|
|
# |out|. It returns one on success or zero on hardware failure.
|
|
# int CRYPTO_rdrand(uint8_t out[8]);
|
|
.globl CRYPTO_rdrand
|
|
.type CRYPTO_rdrand,\@function,1
|
|
.align 16
|
|
CRYPTO_rdrand:
|
|
.cfi_startproc
|
|
xorq %rax, %rax
|
|
# This is rdrand %rcx. It sets rcx to a random value and sets the carry
|
|
# flag on success.
|
|
.byte 0x48, 0x0f, 0xc7, 0xf1
|
|
# An add-with-carry of zero effectively sets %rax to the carry flag.
|
|
adcq %rax, %rax
|
|
movq %rcx, 0(%rdi)
|
|
retq
|
|
.cfi_endproc
|
|
|
|
# CRYPTO_rdrand_multiple8_buf fills |len| bytes at |buf| with random data from
|
|
# the hardware RNG. The |len| argument must be a multiple of eight. It returns
|
|
# one on success and zero on hardware failure.
|
|
# int CRYPTO_rdrand_multiple8_buf(uint8_t *buf, size_t len);
|
|
.globl CRYPTO_rdrand_multiple8_buf
|
|
.type CRYPTO_rdrand_multiple8_buf,\@function,2
|
|
.align 16
|
|
CRYPTO_rdrand_multiple8_buf:
|
|
.cfi_startproc
|
|
test %rsi, %rsi
|
|
jz .Lout
|
|
movq \$8, %rdx
|
|
.Lloop:
|
|
# This is rdrand %rcx. It sets rcx to a random value and sets the carry
|
|
# flag on success.
|
|
.byte 0x48, 0x0f, 0xc7, 0xf1
|
|
jnc .Lerr
|
|
movq %rcx, 0(%rdi)
|
|
addq %rdx, %rdi
|
|
subq %rdx, %rsi
|
|
jnz .Lloop
|
|
.Lout:
|
|
movq \$1, %rax
|
|
retq
|
|
.Lerr:
|
|
xorq %rax, %rax
|
|
retq
|
|
.cfi_endproc
|
|
___
|
|
|
|
close STDOUT; # flush
|