1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
// Rust interface to RDSEED / RDRAND
//
// Written by Radim Kolar <hsn@sendmail.cz> 2026
//
// This is free and unencumbered software released into the public domain.
// SPDX-License-Identifier: CC0-1.0 OR Unlicense
/// Attempts to get a 64-bit pseudo random number from the hardware.
///
/// ## Returns
/// Some(u64) if successful.
/// None if the hardware was busy or operation is not supported.
///
/// ## See also
///
/// 1. [is_available] - checks if hardware supports RDRAND instruction.
/// 1. [get32] - get 32-bit pseudo random number from the hardware.
/// 1. [get16] - get 16-bit pseudo random number from the hardware.
/// Attempts to get a 32-bit pseudo random number from the hardware.
///
/// ## Returns
/// Some(u32) if successful.
/// None if the hardware was busy or operation is not supported.
///
/// ## See also
///
/// 1. [is_available] - checks if hardware supports RDRAND instruction.
/// 1. [get64] - get 64-bit pseudo random number from the hardware.
/// 1. [get16] - get 16-bit pseudo random number from the hardware.
/// Attempts to get a 16-bit pseudo random number from the hardware.
///
/// ## Returns
/// Some(u16) if successful.
/// None if the hardware was busy or operation is not supported.
///
/// ## See also
///
/// 1. [is_available] - checks if hardware supports RDRAND instruction.
/// 1. [get64] - get 64-bit pseudo random number from the hardware.
/// 1. [get32] - get 32-bit pseudo random number from the hardware.
/// Checks if hardware supports RDRAND instruction.
///
/// ## Returns
/// true if the current CPU supports the RDRAND instruction.