The present technique relates to the field of true random number generators.
A true random number generator (TRNG) measures random numbers based on a physical phenomenon that is expected to be random, such as atmospheric noise, thermal noise, or radioactive decay for example Since the physical phenomenon used as the entropy source for the TRNG is unpredictable, the generated random numbers are truly random. This contrasts with pseudo random number generators (PRNGs), which use mathematical formulae or precalculated tables of random numbers to produce sequences of numbers that appear random, but are actually predictable and deterministic given the initial seed condition used to generate the pseudo random numbers. For many applications, PRNGs are sufficient and these may typically be implemented more cheaply than a TRNG. However, for other applications the true randomness generated by a TRNG is essential and a PRNG may not be sufficient.
Previous work has demonstrated TRNGs based on a resistor-amplifier-ADC chain, oscillator jitter, metastability and other device noise. However, analog designs suffer from variation and noise, making them difficult to integrate with digital circuits. Recent metastability-based methods provide excellent performance but often require careful calibration to remove bias. SiN MOSFETs exploit larger thermal noise but require post-processing to achieve sufficient randomness. An oxide breakdown-based TRNG shows high entropy but suffers from low performance and high energy/bit. Ring oscillator (RO) based TRNGs offer the advantage of design simplicity, but previous methods using a slow jittery clock to sample a fast clock provide low randomness and are vulnerable to power supply attacks. In addition, the majority of previous methods cannot pass all NIST (National Institute of Standards and Technology) randomness tests.
The present technique seeks to provide a TRNG that can simultaneously achieve ease of design, high randomness, good throughput, energy efficiency and resistance to attack.
Viewed from one aspect, the present technique provides a true random number generator (TRNG) comprising:
a ring oscillator;
a control circuit configured to trigger the ring oscillator to start oscillating in a first mode of oscillation at an oscillation start time; and
a time measuring circuit configured to measure a collapse time value indicative of a length of time from the oscillation start time to an oscillation collapse time at which the ring oscillator switches from the first mode of oscillation to a second mode of oscillation.
The present technique provides a ring oscillator which can oscillate in a first mode of oscillation and a second mode of oscillation. The first mode of oscillation may be unstable and so after a period of time the ring oscillator may collapse to the second mode of oscillation. The length of time taken to collapse from the first to the second mode of oscillation may depend on thermal noise, and so by measuring a collapse time value indicating the length of time from the start of oscillation in the first mode of oscillation to the collapse to the second mode of oscillation, the collapse time value can be used to derive a true random number. This contrasts with conventional ring oscillator based TRNGs which use jitter within a single mode of oscillation as the source of randomness, rather than the collapse from one mode of oscillation to another. Unlike previous approaches, a TRNG according to present technique can be synthesized entirely using standard digital synthesis techniques (e.g. using a standard cell library and conventional placing and routing tools) while still providing a high degree of randomness, making the TRNG cheaper and simpler to construct. Also, the throughput (number of random bits generated per second), energy efficiency (energy consumption per random bit generated) and circuit area are improved relative to previous techniques.
In one example, in the first mode of oscillation the ring oscillator may oscillate at a higher frequency than in the second mode of oscillation. The collapse of the second mode of oscillation can then be detected from a reduction in frequency of an output of the ring oscillator.
For example, in the first mode of oscillation the ring oscillator may propagate multiple edges around the ring oscillator with a phase difference between each edge. For example, the ring oscillator may have a number of stages with multiple input nodes located at different stages of the ring oscillator. A control circuit may supply a start signal to the multiple input nodes, and in response to the start signal, each input node may inject a respective edge into the ring oscillator. Each edge will then propagate around the ring in the same way as a single-edge ring oscillator. Each edge has the same period as the single-edge oscillator, but the edges are phase shifted with respect to each other and the overall frequency at a given output point is higher. Over time, each edge will independently accumulate jitter from thermal noise, causing an increasing variation of the pulse width between two neighboring edges with each complete cycle. Eventually, two neighboring edges will get so close together that they collapse and cancel each other out, leaving one or more other edges remaining At this point, the frequency of the ring oscillator drops because there are now fewer edges in the second mode of oscillation than in the first mode of oscillation. The time taken from the start of oscillation in the first mode to the collapse to the second mode reflects the accumulation of jitter at each edge and can therefore be used as the entropy source for random number generation. Also, the collapse time will be independent of any process variation in the ring oscillator because each edge passes through the same ring oscillator stages, evening out any mismatch in the switching time for each stage.
In general, the second mode of oscillation may have fewer edges propagating around the ring oscillator than the first mode. However, it may be simplest to detect the collapse when the second mode of oscillation propagates only a single edge.
The first mode of oscillation may propagate any number of edges. However, it may be preferable to provide a mode of oscillation where an odd number of edges greater than one propagate around the ring oscillator. With an even number of edges, the first mode of oscillation is more susceptible to process variation because a given stage of the ring oscillator will act only on rising edges or falling edges of the pulses, which may reduce the randomness of the collapse time. By using an odd number of edges, this process variation can be eliminated because each stage of the ring oscillator will act on both rising and falling edges. Any odd number of edges may be used in the first mode of oscillation, although it has been found that a three edge mode of oscillation is sufficient. In this example, the ring oscillator may be provided with three input nodes for injecting the respective edges in response to the start signal, and then over time two of these edges may drift closer together and cancel each other out, leaving the third edge as the single edge oscillating in the second mode of oscillation.
At the start of oscillation in the first mode, it is possible to inject edges with different phase differences between each successive pair of neighboring edges. Hence, the input nodes associated with each edge need not be evenly distributed around the ring. However, it may be preferable to provide the edges with an equal phase difference at the start of the first mode of oscillation, because this can increase the amount of randomness. When the initial edges are evenly distributed in phase, then which pair of edges will collapse together first will be unpredictable and dependent on thermal noise, and so the overall randomness will be dependent on thermal noise experienced by each of the edges. In contrast, if some of the edges are closer together in phase than others then the edges which start off closer together are more likely to be the ones that collapse together and so the randomness will be affected by the jitter in these edges more than the jitter in other edges. Therefore, it may be preferable to inject the edges at evenly distributed points around the ring.
The start signal may in some embodiments comprise a pulse with a first edge which resets the ring oscillator and a second edge which triggers the ring oscillator to start oscillating in the first mode of oscillation.
The time measuring circuit for measuring the collapse time value may be implemented in a number of ways. For example, the time measuring circuit may have a cycle counter which maintains a cycle count value indicating the number of cycles which have elapsed since the oscillation start time. A collapse detector may output a collapse signal in response to detecting the ring oscillator switching from the first mode to the second mode of oscillation. A capture circuit may respond to the collapse signal from the collapse detector by capturing a current value of the cycle count value from the cycle counter. Hence, the captured value will be indicative of the number of cycles taken to collapse to the second mode of oscillation, and this can be output and used to derive a true random number.
While in general the cycle counter may use any reference clock to count the number of cycles, it can be advantageous for the cycle counter to count oscillation cycles of the ring oscillator itself. Firstly, this reduces the need to provide a further oscillator for providing the count reference clock. Also, as the frequency of the ring oscillator may be higher in the first mode than in the second mode, then when the ring oscillator collapses to the second mode, the period between successive cycles will be increased and so there is more time available for the capture circuit (e.g. a latch) to capture the current value of the cycle count before it is incremented again in response to another cycle of the ring oscillator.
In one example, the collapse detector may comprise a phase frequency detector (PFD) which generates the collapse signal based on a phase comparison of an output of the ring oscillator and an output of a reference ring oscillator which oscillates at a predetermined frequency. Where the first mode of oscillation of the ring oscillator has a first frequency which is greater than a second frequency of the second mode of oscillation, the reference ring oscillator may be set so that the predetermined frequency is between the first and second frequencies. Hence, when the ring oscillator is in the first mode of oscillation then it will be oscillating faster than the reference ring oscillator and when the ring oscillator is in the second mode of oscillation it will be oscillating slower than the reference ring oscillator. The phase frequency detector can output a signal which indicates the relative frequency of the two oscillators and this can be used to determine when the ring oscillator has collapsed to the second mode of oscillation.
It can be useful to provide a glitch removal circuit to filter out glitches in the collapse signal generated by the collapse detector. For example, when a phase frequency detector is used then there may be the odd glitch when the collapse signal changes value for a short period of time before returning to its previous value even though there was not a change in the mode of oscillation of the ring oscillator. The glitch removal circuit can filter out these short glitches so that the collapse is only detected when there is a more long term change in the state of the collapse signal For example, the glitch removal circuit may comprise an AND gate which receives as inputs the collapse signal and a delayed version of the collapse signal This ensures that if the collapse signal changes state for a shorter period of time than the delay through the delaying buffer/inverter, then this glitch will not cause a collapse detection.
In addition to or instead of the glitch removal circuit, a shift register may be provided in the time measuring circuit for increasing the confidence in collapse detection. The shift register may have a number of shift stages, with each shift stage receiving the output of the preceding stage in each clock cycle. The collapse signal may be input at a first stage of the shift register and then the output of a final stage of the shift register may be sent to the capture device. This effectively delays the collapse signal so that the capture device detects the change in state of the collapse signal a number of cycles later than it was actually generated. If there is a change in state of the collapse detector shortly after an earlier transition then the shift register can be reset to prevent the previous transition affecting the capture device. This ensures that the capture device will only capture the current value of the cycle count value if the collapse signal changes and remains at its new value for a number of cycles equivalent to the number of shift stages of the shift register.
The TRNG may in some embodiments comprise a random number determining unit which determines a random number value based on the collapsed time value measured by the measuring circuit. However, this is not essential as in other embodiments the collapse time value may be output to an external device which is not part of the TRNG itself, and the external device may then determine the random number value.
It is possible to map the collapse time value directly to a random number value. However, as the collapse time value is dependent on thermal noise which will tend to exhibit a normal distribution, the collapse time value will take some numeric values more frequently than others. To produce a random number with a uniform probability distribution, the random number value may be determined based on a subset of bits of the collapse time value measured by the time measuring circuit. For example, the collapse time value may be truncated to generate a truncated value corresponding to a number of least significant bits of the collapse time value, and then the random number value may be determined based on the truncated value. The probability distribution with which the least significant bits of the collapse time value take different numeric values tends to be more uniform than the probability distribution for the collapse time value as a whole, and so truncating the collapse time value can improve the randomness of TRNG.
In some examples, it may also be desirable to exclude the least significant bit of the truncated value when determining the random number value. This can be useful to eliminate sensitivity of the random number to mismatch in the capture device which samples the cycle counter.
All hardware TRNGs should cope with interference from a potentially noisy environment as well as dedicated attacks attempting to reduce the randomness of the generated random numbers. It is known that ring oscillators may be sensitivity to frequency injection, if the power supply to the ring oscillator is noisy or an attacker deliberately introduces some high frequency noise on the power supply rail. It has been found that with the TRNG of the present technique, the components of an integrated circuit comprising the TRNG, which may have an inherent resistance and capacitance, may themselves provide sufficient noise filtering to protect against environmental noise and dedicated attacks. However, to improve protection against noise and reduce susceptibility to attacks, a low pass filter may be coupled between the ring oscillator and its power supply rail. The low pass filter may be provided with a cutoff frequency which is lower than the expected frequency at which noise is expected to affect the randomness of the generated numbers. In this way, a robust TRNG can be produced which is difficult to attack and which more reliably generates truly random numbers.
Viewed from another aspect, the present technique provides a true random number generator comprising:
ring oscillator means for oscillating in one of a first mode of oscillation and a second mode of oscillation;
control means for triggering the ring oscillator to start oscillating in the first mode of oscillation at an oscillation start time; and
time measuring means for measuring a collapse time value indicative of a length of time from the oscillation start time to an oscillation collapse time at which the ring oscillator means switches from the first mode of oscillation to the second mode of oscillation.
Viewed from a further aspect, the present technique provides a method of generating a true random number, comprising:
at an oscillation start time, triggering a ring oscillator to start oscillating in a first mode of oscillation;
measuring a collapse time value indicative of a length of time from the oscillation start time to an oscillation collapse time at which the ring oscillator switches from the first mode of oscillation to a second mode of oscillation; and
determining the true random number based on the collapse time value.
Further aspects, features and advantages of the present technique will be apparent from the following detailed description of the examples which is to be read in conjunction with the accompanying drawings.
As shown in
In this example, the time measuring circuit comprises a phase frequency detector (PFD) 80 which compares the phase of the output of the ring oscillator 20 and the output of a reference ring oscillator 82 which oscillates at a predetermined frequency which lies between the frequency of oscillation in the first mode of oscillation of the ring oscillator and the frequency in the second mode of oscillation. For example, the frequency of the reference ring oscillator 82 may be 1.5 times the frequency of the ring oscillator 20 in the second mode of oscillation (half the frequency of the ring oscillator 20 in the first mode of oscillation). This can be achieved by providing the reference ring oscillator 82 with two thirds the number of stages 4, 6 as the ring oscillator 20. Any conventional phase frequency detector design can be used for the PFD 80. An example PFD design is shown in
The collapse signal 83 output by the PFD 80 could be output directly to the capture register 90 to trigger capturing the count value from the cycle counter 86. However, it is unlikely that the ring oscillator will collapse to the second mode after only a very few number of cycles. To prevent glitches in the collapse signal 83 triggering the capture of the count value during the first few cycles, which would be likely to be incorrect and may skew the random number distribution, an intermediate bit of the counter (bit [3] in this example) is used to prevent false triggers of the collapse in the first few cycles. Latches 92, 94 and NOR gate 96 prevent the capture registers 90 from capturing the cycle count until bit 3 of the count value has switched to logical 1. The capture registers 90 are triggered by the gated collapse signal 84 output from the latch 94 instead of the collapse signal 83 output by the PFD. This ensures that the collapse event cannot be detected in the first eight cycles of operation. If a different number of cycles is required for the initial period, then a different bit of the cycle count value can be used to gate the collapse detection.
The lower part of
Also, the PFD 80 may have a shift register stage 110 which delays the collapse signal for a number of cycles. In this example a 2-bit shift register is provided and so there is a two cycle delay in the output of the collapse signal 83 (although a greater number of stages could be provided if desired). Each of the UP and DOWN signals is passed through a two-stage shift register, the UP shift register is reset if there is a rising edge transition in the DOWN signal, and the DOWN shift register is reset if there is a rising edge transition in the UP signal The shift register stage ensures that a change in value of the UP/DOWN signals must persist for at least two consecutive cycles in order to be registered as a collapse event. Hence, the collapse event is flagged only after two consecutive cycles of the ring oscillator 20 are detected at the lower frequency.
The collapse signal 83 output by the PFD 80 may be based on either the UP output OUT_A or the DOWN output OUT_B of the shift register stage 110. In the example shown in
In some embodiments, the random number determining unit 70 may not be provided in the TRNG 50 and instead the count value 62 may be output to an external device which then determines a random number.
All hardware TRNGs must cope with interference from a potentially noisy environment as well as dedicated attacks. Ring oscillators are known to be sensitive to frequency injection, which has been reported to introduce errors in ring oscillator-based TRNGs. To measure the S-edge TRNG's sensitivity to deliberate attack we tested its robustness with off-chip noise sources. Furthermore, we created on-chip test structures to both inject and measure noise and demonstrate means to protect from such noise (see
In addition, an RC noise filter 110 with 210 MHz corner (cutoff) frequency was designed to mitigate the impact of supply noise. As shown in the right hand portion of
The proposed 3-edge TRNG was evaluated using two test chips; one in 28 nm CMOS with 8 different rings; the other in 65 nm CMOS with 48 different TRNGs. The NIST Pub 800-22 RNG testing suite was used to evaluate the randomness of generated bits. As shown in
Using an RF signal generator, up to 600 mVpp noise was injected on the power supplies (after removing board decoupling caps) to test the TRNG's robustness against off-chip attack. The 65 nm TRNGs retained randomness up to 360 mVpp noise without the filter and up to the 600 mVpp generator limit with the filter. To compensate for filter IR drop, TRNGs with filters operate at 5% increased supply voltage, incurring a slight power penalty. Since ROs in 28 nm TRNGs operate at a higher frequency they are less sensitive to external attack; even unfiltered versions did not suffer randomness degradation at the generator limit EMI noise injected by antenna also did not cause failure in any randomness tests.
The table of
As shown in
Although illustrative embodiments of the invention have been described in detail herein with reference to the accompanying drawings, it is to be understood that the invention is not limited to those precise embodiments, and that various changes and modifications can be effected therein by one skilled in the art without departing from the scope and spirit of the invention as defined by the appended claims