blob: eb2a59262e7f6803d628bb56ecebcb802e9deca5 [file] [log] [blame]
Adam Langleye9ada862015-05-11 17:20:37 -07001#!/usr/bin/env perl
2
Adam Langleybd9957e2015-06-23 16:28:07 -07003# Copyright (c) 2015, Google Inc.
4#
5# Permission to use, copy, modify, and/or distribute this software for any
6# purpose with or without fee is hereby granted, provided that the above
7# copyright notice and this permission notice appear in all copies.
8#
9# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
12# SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
14# OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
15# CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
16
Robert Sloan4c22c5f2019-03-01 15:53:37 -080017use strict;
18
19my $flavour = shift;
20my $output = shift;
Adam Langleye9ada862015-05-11 17:20:37 -070021if ($flavour =~ /\./) { $output = $flavour; undef $flavour; }
22
Robert Sloan4c22c5f2019-03-01 15:53:37 -080023my $win64 = 0;
24$win64 = 1 if ($flavour =~ /[nm]asm|mingw64/ || $output =~ /\.asm$/);
25
26$0 =~ m/(.*[\/\\])[^\/\\]+$/;
27my $dir = $1;
28my $xlate;
Robert Sloan9254e682017-04-24 09:42:06 -070029( $xlate="${dir}../../../perlasm/x86_64-xlate.pl" and -f $xlate) or
Adam Langleye9ada862015-05-11 17:20:37 -070030die "can't locate x86_64-xlate.pl";
31
32open OUT,"| \"$^X\" $xlate $flavour $output";
33*STDOUT=*OUT;
34
Robert Sloan4c22c5f2019-03-01 15:53:37 -080035my ($out, $len, $tmp1, $tmp2) = $win64 ? ("%rcx", "%rdx", "%r8", "%r9")
36 : ("%rdi", "%rsi", "%rdx", "%rcx");
37
Adam Langleye9ada862015-05-11 17:20:37 -070038print<<___;
39.text
40
Adam Langleybd9957e2015-06-23 16:28:07 -070041# CRYPTO_rdrand writes eight bytes of random data from the hardware RNG to
42# |out|. It returns one on success or zero on hardware failure.
43# int CRYPTO_rdrand(uint8_t out[8]);
Adam Langleye9ada862015-05-11 17:20:37 -070044.globl CRYPTO_rdrand
Robert Sloan4c22c5f2019-03-01 15:53:37 -080045.type CRYPTO_rdrand,\@abi-omnipotent
Adam Langleye9ada862015-05-11 17:20:37 -070046.align 16
47CRYPTO_rdrand:
Adam Vartanianbfcf3a72018-08-10 14:55:24 +010048.cfi_startproc
Adam Langleybd9957e2015-06-23 16:28:07 -070049 xorq %rax, %rax
Robert Sloan4c22c5f2019-03-01 15:53:37 -080050 rdrand $tmp1
Adam Langleybd9957e2015-06-23 16:28:07 -070051 # An add-with-carry of zero effectively sets %rax to the carry flag.
52 adcq %rax, %rax
Robert Sloan4c22c5f2019-03-01 15:53:37 -080053 movq $tmp1, 0($out)
Adam Langleybd9957e2015-06-23 16:28:07 -070054 retq
Adam Vartanianbfcf3a72018-08-10 14:55:24 +010055.cfi_endproc
Robert Sloan4c22c5f2019-03-01 15:53:37 -080056.size CRYPTO_rdrand,.-CRYPTO_rdrand
Adam Langleybd9957e2015-06-23 16:28:07 -070057
58# CRYPTO_rdrand_multiple8_buf fills |len| bytes at |buf| with random data from
59# the hardware RNG. The |len| argument must be a multiple of eight. It returns
60# one on success and zero on hardware failure.
61# int CRYPTO_rdrand_multiple8_buf(uint8_t *buf, size_t len);
62.globl CRYPTO_rdrand_multiple8_buf
Robert Sloan4c22c5f2019-03-01 15:53:37 -080063.type CRYPTO_rdrand_multiple8_buf,\@abi-omnipotent
Adam Langleybd9957e2015-06-23 16:28:07 -070064.align 16
65CRYPTO_rdrand_multiple8_buf:
Adam Vartanianbfcf3a72018-08-10 14:55:24 +010066.cfi_startproc
Robert Sloan4c22c5f2019-03-01 15:53:37 -080067 test $len, $len
Adam Langleybd9957e2015-06-23 16:28:07 -070068 jz .Lout
Robert Sloan4c22c5f2019-03-01 15:53:37 -080069 movq \$8, $tmp1
Adam Langleybd9957e2015-06-23 16:28:07 -070070.Lloop:
Robert Sloan4c22c5f2019-03-01 15:53:37 -080071 rdrand $tmp2
Adam Langleybd9957e2015-06-23 16:28:07 -070072 jnc .Lerr
Robert Sloan4c22c5f2019-03-01 15:53:37 -080073 movq $tmp2, 0($out)
74 addq $tmp1, $out
75 subq $tmp1, $len
Adam Langleybd9957e2015-06-23 16:28:07 -070076 jnz .Lloop
77.Lout:
78 movq \$1, %rax
79 retq
80.Lerr:
81 xorq %rax, %rax
Adam Langleye9ada862015-05-11 17:20:37 -070082 retq
Adam Vartanianbfcf3a72018-08-10 14:55:24 +010083.cfi_endproc
Robert Sloan4c22c5f2019-03-01 15:53:37 -080084.size CRYPTO_rdrand_multiple8_buf,.-CRYPTO_rdrand_multiple8_buf
Adam Langleye9ada862015-05-11 17:20:37 -070085___
86
Pete Bentley0c61efe2019-08-13 09:32:23 +010087close STDOUT or die "error closing STDOUT"; # flush