This U.S. non-provisional patent application claims priority under 35 U.S.C. § 119 to Korean Patent Application No. 10-2016-0157442 filed Nov. 24, 2016, in the Korean Intellectual Property Office, the entire contents of which are hereby incorporated by reference.
Embodiments of the inventive concepts disclosed herein relate to random number generators, and more particularly, to random number generators using an adjustable meta-stable voltage.
As information communication technologies develop, the encryption of information is very important to maintain security of information. A random number is used, in general, to encrypt information, and thus, a random number generator for the generation of the random number is required. To make decryption of encrypted information difficult, a random number should not be regular, and a specific value (e.g., “0” or “1”) should not be continuously output by a uniform length or longer.
In general, in the case of a random number generator that uses a ring-oscillator circuit, there is a considerable time to accumulate jitter, and thus, a speed at which a random number is generated is limited. In contrast, in the case of a random number generator that uses meta-stability, a speed at which a random number is generated is fast, but the quality of random number decreases due to mismatch between a meta-stable inverter and an amplifier or between meta-stable inverters.
Accordingly, to encrypt information quickly and to protect the information, there is a need to develop a random number generator that improves a speed, at which a random number is generated, and quickly generates the random number.
Example embodiments of the inventive concepts provide a device and a method for generating a random number by using an adjustable meta-stable voltage.
According to some example embodiments, a random number generator may be configured to be operated according to different modes of operation of a plurality of modes of operation. The random number generator may include a first meta-stable inverter, a second meta-stable inverter, a control circuitry, and a sampler. The first meta-stable inverter may include an input terminal and an output terminal connected to each other. The first meta-stable inverter may be configured to generate a meta-stable voltage. The second meta-stable inverter may be configured to amplify the meta-stable voltage or include an input terminal and an output terminal that are connected to each other based on the random number generator being operated according to a first mode of operation or a second mode of operation, respectively, of the plurality of modes of operation. The control circuitry may be configured to adjust at least one voltage of a threshold voltage associated with the first meta-stable inverter and a common mode input voltage associated with the second meta-stable inverter. The meta-stable voltage may be based on the threshold voltage and the common mode input voltage. The sampler may be configured to generate a random number based on sampling the meta-stable voltage.
According to some example embodiments, a random number generator may include a meta-stable inverter, an amplifier, control circuitry, and a sampler. The meta-stable inverter may include an input terminal and an output terminal connected to each other. The meta-stable inverter may be configured to generate a meta-stable voltage. The amplifier may be configured to amplify the meta-stable voltage. The control circuitry may be configured to adjust a threshold voltage of the meta-stable voltage. The threshold voltage of the meta-stable voltage may be a base of the meta-stable voltage. The sampler may be configured to generate a random number based on sampling the meta-stable voltage.
According to some example embodiments, a method of generating a random number may include outputting a meta-stable voltage from a first meta-stable inverter, the first meta-stable inverter including an input terminal and an output terminal connected to each other. The method may include amplifying the meta-stable voltage based on using a second meta-stable inverter and generating a random number based on sampling the amplified meta-stable voltage. The meta-stable voltage may be based on a threshold voltage of the first meta-stable inverter and a common mode input voltage of the second meta-stable inverter. At least one voltage of the threshold voltage and the common mode input voltage may be adjustable.
According to some example embodiments, a random number generator may include a memory storing a program of instructions and a processor. The processor may be configured to execute the program of instructions to adjust a threshold voltage of a first meta-stable voltage that is output by a first meta-stable inverter, the meta-stable voltage based on at least the threshold voltage, and generate a random number based on sampling the meta-stable voltage.
The above and other objects and features will become apparent from the following description with reference to the following figures, wherein like reference numerals refer to like parts throughout the various figures unless otherwise specified, and wherein:
Below, example embodiments of the inventive concepts may be described in detail and clearly to such an extent that an ordinary one in the art easily implements the inventive concepts.
The meta-stable inverter 1101 (also referred to herein as a “first meta-stable inverter”) may be configured to generate a meta-stable voltage V1. The meta-stable inverter 1101 may include at least one diode-connected PMOS transistor and at least one diode-connected NMOS transistor. In some example embodiments, the meta-stable voltage V1 generated by the meta-stable inverter 1101 may be determined according to (“may be based at least in part upon”) a ratio of a resistance value of the diode-connected PMOS transistor to a resistance value of the diode-connected NMOS transistor. For example, if and/or when the meta-stable inverter 1101 includes a plurality of diode-connected PMOS transistors and diode-connected NMOS transistors, the meta-stable inverter 1101 may further include appropriate switching elements that operate the transistors independently.
The amplifier 1102 may amplify the meta-stable voltage V1 output from (“generated by”) the meta-stable inverter 1101 to output (“generate”) an amplified voltage V2. For example, a configuration of the amplifier 1102 may be the same as a configuration of the meta-stable inverter 1101. In some example embodiments, the configuration of the amplifier 1102 may not be limited thereto. The amplifier 1102 may be variously configured to amplify the meta-stable voltage V1 that oscillates with a relatively small amplitude (e.g., an amplitude that is less than a particular threshold oscillation amplitude).
The control circuitry 1200 may be configured to adjust the meta-stable voltage V1 output from the meta-stable inverter 1101. For example, the control circuitry 1200 may generate a meta-stable control signal CTRL_MS for controlling the meta-stable inverter 1101. For example, the meta-stable control signal CTRL_MS may control the diode-connected PMOS transistors and the diode-connected NMOS transistors of the meta-stable inverter 1101 independently. Accordingly, it may be possible to generate the meta-stable voltage V1 of a desired level. The control circuitry 1200, in some example embodiments, may be implemented by a processor (“processing circuitry”) executing a program of instructions stored on a memory (“non-transitory computer readable storage medium”).
The sampler 1300 may generate a random number based on the amplified voltage V2 and a sampling clock CLK. For example, the sampler 1300 may sample the amplified voltage V2 that is input in synchronization with the sampling clock CLK. A flip-flop may be used as an example of the sampler 1300. In some example embodiments, the sampler 1300 may be implemented by a processor executing a program of instructions stored at a memory. The processor may be included in the control circuitry 1200. However, embodiments of the inventive concepts may not be limited thereto. As well as the flip-flop, various logic elements (circuitry) for performing a sampling operation may be used.
The multiplexing circuit 1400 and the switch SW may be switched on or off appropriately to generate a random number by controlling the meta-stable inverter 1101. For example, if and/or when the random number generator 1000 operates according to a first mode (or an amplification mode, first mode of operation, etc.), the multiplexing circuit 1400 may be switched off to allow (“enable”) the control circuitry 1200 to fail to detect the meta-stable voltage V1. In the first mode (“if and/or when the random number generator 100 is operated according to the first mode of operation”), the switch SW may be switched on to allow the amplifier 1102 to amplify the meta-stable voltage V1. In contrast, in a second mode (“if and/or when the random number generator 1000 operates according to a second mode (or a detection mode, sensing mode, second mode of operation, etc.)”), the multiplexing circuit 1400 may be switched on to allow the control circuitry 1200 to detect the meta-stable voltage V1. In the second mode, the switch SW may be switched off to allow the meta-stable voltage V1 not to be transferred to the amplifier 1102.
According to some example embodiments of the inventive concepts, the random number generator 1000 may operate according to various modes of operation (“modes”) to limit and/or prevent a random number from the sampler 1300 to be stuck to one bit “0” or “1”. For example, the random number generator 1000 may generate a random number in the first mode and may adjust or tune the meta-stable inverter 1101 in the second mode. Some modes of operation of the random number generator 1000 are illustrated in
In the first mode, the meta-stable inverter 1101 may generate the meta-stable voltage V1. As shown in
In some example embodiments, if and/or when the meta-stable inverter 1101 and the amplifier 1102 are matched, that is, if a voltage level (i.e., the threshold voltage) that corresponds to the center of vibration of the meta-stable voltage V1 is the same as a level of a common mode input voltage of the amplifier 1102, a random number output from the sampler 1300 may include bits “0” and/or “1” that are arranged randomly.
In some example embodiments, a level (“magnitude”) difference between the threshold voltage of the meta-stable inverter 1101 and the common mode input voltage of the amplifier 1102 may be different from any threshold value. In this case, a random number output from the sampler 1300 may be stuck to “0” or “1”. That is, to generate a high-quality random number, there is a need to adjust or tune the meta-stable inverter 1101 such that a random number is not stuck to “0” or “1”.
In the second mode, the control circuitry 1200 may detect a level (“magnitude”) of a threshold voltage of the meta-stable inverter 1101. To this end, the multiplexing circuit 1400 may perform a switching operation such that the meta-stable voltage V1 from the meta-stable inverter 1101 is transferred to the control circuitry 1200. For example, if and/or when the meta-stable voltage V1 oscillates between an upper limit and a lower limit of any specific value, a threshold voltage level of the meta-stable inverter 1101 may be approximately an intermediate value of an upper limit and a lower limit of the meta-stable voltage V1.
The control circuitry 1200 may match the meta-stable inverter 1101 and the amplifier 1102 so that the voltage V2 amplified from the meta-stable voltage V1 is not stuck. For example, the control circuitry 1200 may generate the meta-stable control signals CTRL_MS that are used to adjust or tune the meta-stable inverter 1101 such that the threshold voltage of the meta-stable inverter 1101 is the same voltage as the common mode input voltage of the amplifier 1102. For example, the meta-stable control signal CTRL_MS may include a plurality of control signals that cause the diode-connected PMOS transistors and the diode-connected NMOS transistors of the meta-stable inverter 1101 to be controlled independently.
In some example embodiments, the control circuitry 1200 may adjust the threshold voltage of the meta-stable inverter 1101 so that the common mode input voltage of the amplifier 1102 is between the upper limit and the lower limit of the meta-stable voltage V1. As will be described later in detail, threshold voltage of the meta-stable inverter 1101 may be adjusted by allowing some of PMOS transistors and NMOS transistors of the meta-stable inverter 1101 to operate.
If and/or when the threshold voltage of the meta-stable inverter 1101 is completely adjusted or tuned in the second mode, under control of the multiplexing circuit 1400, the output terminal of the meta-stable inverter 1101 and the control circuitry 1200 may be disconnected from each other, and the output terminal of the meta-stable inverter 1101 and the amplifier 1102 may be connected to each other. This may mean that the random number generator 1000 enters the first mode again.
First, referring to
A random number may be stuck to “0” if the upper limit of the meta-stable voltage V1 is smaller than a common mode input voltage Vth2 of the amplifier 1102, as shown in
A random number may be stuck to “0” or “l” based on various factors: the number of inverters that amplify the meta-stable voltage V1 and whether an inverter that amplifies the meta-stable voltage V1 is implemented with an inverting amplifier or a non-inverting amplifier. In some example embodiments, that a random number is stuck to “0” only means that the random number is not generated normally, and a value of the random number may not be important.
Referring to
As described with reference to
Unlike
First, referring to
Referring to
As described with reference to
Further, as understood from
The meta-stable inverter 1101 may include a plurality of diode-connected PMOS transistors P1 to Pm and a plurality of diode-connected NMOS transistors N1 to Nm. As used herein, “m” may be an integer. As illustrated in
The meta-stable inverter 1101 may further include switching transistors PS1 to PSm and NS1 to NSm that are configured to control the diode-connected PMOS transistors P1 to Pm and the diode-connected NMOS transistors N1 to Nm. For example, each of PMOS switching transistors PS1 to PSm may be connected between one end of the corresponding diode-connected PMOS transistor (e.g., a source electrode of the corresponding PMOS transistor) and a power supply voltage VDD, and each of NMOS switching transistors NS1 to NSm may be connected between one end of the corresponding diode-connected PMOS transistor and a ground voltage.
The meta-stable inverter 1101 may further include a first decoder DEC1 that is configured to control the PMOS switching transistors PS1 to PSm independently and a second decoder DEC2 that is configured to control the NMOS switching transistors NS1 to NSm independently. The PMOS switching transistors PS1 to PSm may not be connected to each other. That is, gate electrodes of the PMOS switching transistors PS1 to PSm may be independently connected with the first decoder DEC1. Similarly, gate electrodes of the NMOS switching transistors NS1 to NSm may be independently connected with the second decoder DEC2.
The first decoder DEC and the second decoder DEC2 may be respectively controlled by a first meta-stable control signal CTRL_MS1 and a second meta-stable control signal CTRL_MS2. The meta-stable voltage V1 of a desired level, in detail, a threshold voltage of a desired level, may be generated by independently turning on or off the switching transistors PS1 to PSm and NS1 to NSm by the meta-stable control signals CTRL_MS and CTRL_MS2. This is illustrated in
In this case, the meta-stable inverter 1101 may be modeled as illustrated in
In some example embodiments, since the meta-stable inverter 1101 includes “m” PMOS transistors P1 to Pm and “m” NMOS transistors N1 to Nm, the meta-stable voltage V1 having a “m by m” bit resolution may be generated. In some example embodiments, the number “m” of transistors may be variously determined in consideration of specifications of a system to which the random number generator 1000 is applied, a chip area, costs, etc.
The control circuitry 1200 may include an amplifier 1202, an analog-to-digital converter 1204, and meta-stable voltage control circuitry 1206. The meta-stable voltage control circuitry 1206 may be implemented by a processor (“processing circuitry”) executing a program of instructions stored at a memory.
The amplifier 1202 may receive and amplify the meta-stable voltage V1. For example, the amplifier 1202 may be implemented with a voltage follower.
The analog-to-digital converter 1204 may generate a digital value by converting an output voltage of the amplifier 1202. That is, an output of the analog-to-digital converter 1204 may correspond to a value of the digitized meta-stable voltage V1.
The meta-stable voltage control circuitry 1206 may determine whether there is a need to adjust or tune the meta-stable inverter 1101. For example, the meta-stable voltage control circuitry 1206 may in advance store a common mode input voltage of the amplifier 1102. In this case, the meta-stable voltage control circuitry 1206 determine whether there is a need to adjust or tune the meta-stable inverter 1101, by comparing the digitized meta-stable voltage and the common mode input voltage of the amplifier 1202 stored in advance.
If the comparison result indicates that the digitized meta-stable voltage is within a permissible range, there is no need to adjust the meta-stable inverter 1101. In some example embodiments, the permissible range may refer to a range that is defined by an upper limit and a lower limit of the meta-stable voltage V1 described with reference to
If the comparison result indicates that the digitized meta-stable voltage gets out of the permissible range, the meta-stable voltage control circuitry may generate the meta-stable control signal CTRL_MS for adjusting a threshold voltage Vth1 (refer to
In operation S110, a random number may be generated by using the meta-stable inverter 1101. For example, the amplifier 1102 and the sampler 1300 may be further used in addition to the meta-stable inverter 1101.
In operation S120, whether an output of the meta-stable inverter 1101, that is, the meta-stable voltage V1 is within a permissible range may be determined. In some example embodiments, the permissible range may refer to a range that is defined by an upper limit and a lower limit of the meta-stable voltage V1 described with reference to
For example, operation S120 may be performed in real time or periodically. In some example embodiments, operation S120 may be performed when a random number is stuck to a specific value (i.e., “0” or “1”). In this case, the random number generator 1000 may further include a separate sensor that senses a stuck random number.
An operation branch may be made according to the determination result. If the meta-stable voltage V1 is within the permissible range, the process proceeds to operation S110 to continue to generate a random number. In contrast, if the meta-stable voltage V1 gets out of the permissible range, the process proceeds to operation S130.
In operation S130, the meta-stable inverter 1101 may be adjusted to generate a meta-stable voltage within the permissible range. For example, the adjustment may be made by independently controlling switching transistors that are connected with the diode-connected PMOS transistors and the diode-connected NMOS transistors of the meta-stable inverter 1101. If the adjusting or tuning of the meta-stable inverter 1101 is completed, the process proceeds to operation S110.
Although not illustrated in
An embodiment is described as the meta-stable inverter 1101 is adjusted after a random number is first generated. In some example embodiments, embodiments of the inventive concepts may not be limited thereto. For example, a random number may be generated after the meta-stable inverter 1101 is first adjusted or tuned.
In operation S112, the meta-stable voltage V1 may be generated by using the meta-stable inverter 1101. A noise that vertically oscillates with respect to the threshold voltage Vth1 may be output from the meta-stable inverter 1101 based on a resistance ratio of the diode-connected PMOS transistors and the diode-connected NMOS transistors.
In operation S114, the meta-stable voltage V1 may be amplified by the amplifier 1102. A configuration of the amplifier 1102 may be the same as or similar to that of the meta-stable inverter 1101, but embodiments of the inventive concepts may not be limited thereto.
In operation S116, the amplified voltage that is input in synchronization with the sampling clock CLK may be sampled. A random number may be generated as the sampling result.
The random number generator 2000 may include a meta-stable inverter 2101, an amplifier 2102, a control circuitry 2200, a sampler 2300, a multiplexing circuit 2400, and a switch SW. The random number generator 2000 may further include a voltage regulator 2500 and a divider 2600. The random number generator 2000 is substantially the same (e.g., the same within manufacturing tolerances and/or material tolerances) as the random number generator 1000 of
The voltage regulator 2500 may be configured to supply a stable voltage to the random number generator 2000. As described with reference to
For example, the power supply voltage VDD generated by the voltage regulator 2500 may be provided to source terminals of the PMOS switching transistors PS1 to PSm of the meta-stable inverter 2101. The power supply terminal VDD may be provided to drive the amplifier 2102.
The divider 2600 may be provided to make it easy to sample a noise (i.e., a meta-stable voltage) that oscillates at high speed. For example, a flip-flop may be used as an example of the divider 2600. In this case, the flip-flop may operate as a divider by connecting an input “D” and an output “Q” of the flip-flop. In some example embodiments, a configuration of the divider 2600 may not be limited thereto, and various logic elements may be used as the divider 2600.
The voltage regulator 2500 may include an error amplifier EA, first and second resistors R1 and R2, a pass transistor PT, a switching transistor ST, a stabilization capacitor C, and a protection circuit 2510.
A reference voltage Vref may be applied to a first input terminal of the error amplifier EA. An output terminal of the error amplifier EA may be connected to a gate electrode of the pass transistor PT. A voltage VS from the outside may be applied to a source terminal of the pass transistor PT, and the power supply voltage VDD may be output through a drain terminal of the pass transistor PT. The first resistor R1 may be connected between a second input terminal of the error amplifier EA and the drain terminal of the pass transistor PT, and the second resistor R2 may be connected between the second input terminal of the error amplifier EA and a ground.
The switching transistor ST may be configured to be turned on or off by an ON/OFF signal and to provide the power supply voltage VDD to the meta-stable inverter 2101 and/or the amplifier 2102 at desired timing. For example, the switching transistor ST may be turned on when the random number generator 2000 generates a random number or when the meta-stable inverter 2101 of the random number generator 2000 is adjusted or tuned.
The stabilization capacitor C may be connected between the drain terminal of the pass transistor PT and the ground. The stabilization capacitor C may limit and/or prevent the power supply voltage VDD from changing rapidly, and thus, the power supply voltage VDD may be stably supplied. According to some example embodiments, the stabilization capacitor C may not be provided.
The protection circuit 2510 may limit and/or prevent generation of the power supply voltage VDD getting out of a specific range. For example, the protection circuit 2510 may include an over voltage protection device that limits and/or prevents generation of a voltage exceeding a specific level and an under voltage protection device that limits and/or prevents generation of a voltage smaller than a specific level.
It will be understood that the configuration of the voltage regulator 2500 illustrated in
The first meta-stable inverter 3101 may be configured to generate the meta-stable voltage V1. For example, the first meta-stable inverter 3101 may include at least one diode-connected PMOS transistor and at least one diode-connected NMOS transistor. A configuration and an operation of the first meta-stable inverter 3101 are substantially the same as those described with reference to
The second meta-stable inverter 3102 may receive the meta-stable voltage V1 and may generate the amplified voltage V2. A configuration of the second meta-stable inverter 3102 may be substantially the same as a configuration of the first meta-stable inverter 3101. Thus, a description thereof may not be repeated here.
The control circuitry 3200 may be configured to adjust the meta-stable voltage V1 output from the first meta-stable inverter 3101, in detail, a threshold voltage of the first meta-stable inverter 3101. In addition, the control circuitry 3200 may be configured to adjust a common mode input voltage of the second meta-stable inverter 3102.
For example, the control circuitry 3200 may adjust the first and second meta-stable inverters 3101 and 3102 such that a threshold voltage of the first meta-stable inverter 3101 and the common mode input voltage of the second meta-stable inverter 3102 are the same as a preset value. For example, the control circuitry 3200 may adjust the first meta-stable inverter 3101 such that the threshold voltage of the first meta-stable inverter 3101 is the same as a preset value and may adjust the second meta-stable inverter 3102 within a permissible range in which a random number is not stuck. In this case, the control circuitry 3200 may generate a meta-stable control signal CTRL_MS for adjusting or tuning the first and second meta-stable inverters 3101 and 3102.
In some example embodiments, the control circuitry 3200 may adjust the first meta-stable inverter 3101 such that the threshold voltage of the first meta-stable inverter 3101 and the common mode input voltage of the second meta-stable inverter 3102 are the same (or are within the permissible range). The procedure may be similar to that described with reference to
In some example embodiments, the control circuitry 3200 may adjust the second meta-stable inverter 3102 such that the threshold voltage of the first meta-stable inverter 3101 and the common mode input voltage of the second meta-stable inverter 3102 are the same (or are within the permissible range). In this case, the control circuitry 3200 may generate the meta-stable control signal CTRL_MS for adjusting or tuning the second meta-stable inverter 3102.
Unlike the embodiment described with reference to
The sampler 3300 may sample the amplified voltage V2 that is input in synchronization with the sampling clock CLK. A flip-flop may be used as an example of the sampler 3300. In some example embodiments, embodiments of the inventive concepts may not be limited thereto. As well as the flip-flop, various logic elements for performing a sampling operation may be used.
The multiplexing circuit 3400 and the switches SW1 and SW2 may be appropriately switched on or off according to an operating mode of the random number generator 3000.
For example, in the first mode, the multiplexing circuit 3400 may be switched off to allow the control circuitry 3200 to fail to detect the meta-stable voltage V1. In the first mode, the first switch SW1 may be switched on to allow the second meta-stable inverter 3102 to amplify the meta-stable voltage V1. The second switch SW2 may be switched on to allow the amplified voltage V2 to be input to the sampler 3300.
In contrast, in the second mode, the multiplexing circuit 3400 may be switched on to allow the control circuitry 3200 to detect the meta-stable voltage V1 and the amplified voltage V2. In the second mode, the first switch SW1 may be controlled to allow the meta-stable voltage V1 not to be transferred to the second meta-stable inverter 3102 and the amplified voltage V2 to be input to the second meta-stable inverter 3102. In the second mode, the second switch SW2 may be controlled to allow the amplified voltage V2 not to be transferred to the sampler 3300 and the amplified voltage V2 to be input to the second meta-stable inverter 3102.
According to some example embodiments of the inventive concepts, the random number generator 3000 may operate in the first and second modes to limit and/or prevent a random number from the sampler 3300 from being stuck to one bit “0” or “1” and may adjust or tune the first and second meta-stable inverters 3101 and 3102 in the second mode.
In some example embodiments, the random number generator 3000 may further include the voltage regulator 2500 and the divider 2600 that are described with reference to
In the first mode, the first meta-stable inverter 3101 may generate the meta-stable voltage V1, and the second meta-stable inverter 3102 may amplify the meta-stable voltage V1. Even though a configuration of the second meta-stable inverter 3102 is different from a configuration of the amplifier 1102 illustrated in
In the second mode, the control circuitry 3200 may detect the meta-stable voltage V1, that is, a level of a threshold voltage of the first meta-stable inverter 3101. In addition, the control circuitry 3200 may detect the amplified voltage V2, that is, a level of a common mode input voltage of the second meta-stable inverter 3102.
To detect voltages, the control circuitry 3200 may include an amplifier, an analog-to-digital converter, and meta-stable voltage control circuitry that are illustrated in
The control circuitry 3200 may match the first meta-stable inverter 3101 and the second meta-stable inverter 3102 such that the voltage V2 amplified from the meta-stable voltage V1 is not stuck. For example, the control circuitry 3200 may adjust at least one of the first and second meta-stable inverters 3101 and 3102 such that a threshold voltage of the first meta-stable inverter 3101 and the common mode input voltage of the second meta-stable inverter 3102 are the same.
In some example embodiments, the control circuitry 3200 may control at least one of the first and second meta-stable inverters 3101 and 3102 such that the common mode input voltage of the second meta-stable inverter 3102 is between the upper limit and the lower limit of the meta-stable voltage V1.
If at least one of the first and second meta-stable inverters 3101 and 3102 is completely adjusted or tuned in the second mode, under control of the multiplexing circuit 3400, the output terminal of the first meta-stable inverter 3101 and the control circuitry 3200 are disconnected from each other, and the output terminal of the first meta-stable inverter 3101 and the second meta-stable inverter 3102 are connected to each other. This may mean that the random number generator 3000 enters the first mode again.
First, referring to
As the first meta-stable inverter 3101 is adjusted or tuned under control of the meta-stable control signal CTRL_MS, the first meta-stable inverter 3101 may generate the meta-stable voltage V1 that vertically oscillates with respect to the adjusted threshold voltage Vth1 or the target voltage Vtar. The adjustment of the threshold voltage Vth1 of the first meta-stable inverter 3101 may be made to be similar to that described with reference to
As the second meta-stable inverter 3102 is adjusted or tuned under control of the meta-stable control signal CTRL_MS, a common mode input voltage Vth2′ of the second meta-stable inverter 3102 may be between the upper limit and the lower limit of the metal-stable voltage V1. A random number of “1” may be generated based on the meta-stable voltage V1 larger than the common mode input voltage Vth2′, and a random number of “0” may be generated based on the meta-stable voltage V1 smaller than the common mode input voltage Vth2′ (or vice versa).
Even though the meta-stable inverters 3101 and 3102 are the same in configuration, the embodiment is similar to that described with reference to
In operation S210, a random number may be generated. Operation S210 may correspond to an operation of the random number generator 3000 in the first mode.
In operation S212, a meta-stable voltage may be generated by using the first meta-stable inverter (INV1) 3101. A noise that vertically oscillates with respect to the threshold voltage Vth1 may be output from the first meta-stable inverter 3101 based on a resistance ratio of the diode-connected PMOS transistors and the diode-connected NMOS transistors.
In operation S214, the meta-stable voltage V1 may be amplified by the second meta-stable inverter (INV2) 3102. The first switch SW1 may be appropriately switched to amplify the meta-stable voltage V1. A configuration of the second meta-stable inverter 3102 may be substantially the same as a configuration of the meta-stable inverter 1101.
In operation S216, the amplified voltage V2 that is input in synchronization with the sampling clock CLK may be sampled. The second switch SW2 may be appropriately switched to sample the amplified voltage V2. A random number may be generated as the sampling result.
In operation S220, it may be determined whether a random number is stuck. For example, operation S220 may be performed in real time or periodically. That the random number is not stuck (No) means that the random number is generated normally. Therefore, operation S210 may be continuously performed until a separate instruction to stop generating a random number is received. In contrast, if it is determined that the random number is stuck (Yes), the process proceeds to operation S230.
In operation S230, at least one of the first meta-stable inverter (INV1) 3101 and the second meta-stable inverter (INV2) 3102 may be adjusted or tuned.
In operation S232a, whether the threshold voltage Vth1 of the first meta-stable inverter 3101 is within a permissible range may be determined. The threshold voltage Vth1 and the common mode input voltage Vth2 may be first detected for comparison. Even though the term “target range” is used in
An operation branch may be made according to the determination result. In contrast, if the meta-stable voltage Vth1 is within the target range of voltages, the process proceeds to operation S236a. That a random number may be stuck even though the meta-stable voltage Vth1 is within the target range means that the common mode input voltage Vth2 of the second meta-stable inverter 3102 gets out of the permissible range. In contrast, if the meta-stable voltage Vth1 gets out of the target range, the process proceeds to operation S234a.
In operation S234a, the first meta-stable inverter (INV1) 3101 may be adjusted or tuned such that the threshold voltage Vth1 of the first meta-stable inverter (INV1) 3101 is within the target range. This may be accomplished by independently controlling switching transistors that are respectively connected with the diode-connected PMOS transistors and the diode-connected NMOS transistors of the first meta-stable inverter 3101 (refer to
In operation S236a, the common mode input voltage Vth2 of the second meta-stable inverter (INV2) 3102 may be adjusted within the permissible range. As illustrated in
In operation S232b, a level of the threshold voltage Vth1 of the first meta-stable inverter (INV1) 3101 and a level of the common mode input voltage Vth2 of the second meta-stable inverter (INV2) 3102 may be detected.
In operation S234b, the first meta-stable inverter (INV1) 3101 may be adjusted such that the threshold voltage Vth1 is within the permissible range. In some example embodiments, since the permissible range is a range in which a random number is not stuck, the upper limit of the meta-stable voltage V1 that oscillates with respect to the threshold voltage Vth1 may be larger than the common mode input voltage Vth2, and the lower limit of the meta-stable voltage V1 may be smaller than the common mode input voltage Vth2.
In addition, in some example embodiments, since the first meta-stable inverter (INV1) 3101 is adjusted based on the common mode input voltage Vth2, there is no need for information associated with the target voltage Vtar illustrated in
In operation S232c, a level of the threshold voltage Vth1 of the first meta-stable inverter (INV1) 3101 and a level of the common mode input voltage Vth2 of the second meta-stable inverter (INV2) 3102 may be detected.
In operation S234c, the second meta-stable inverter (INV2) 3102 may be adjusted such that the common mode input voltage Vth2 is within the permissible range. In some example embodiments, since the permissible range is a range in which a random number is not stuck, the common mode input voltage Vth2′ of the second meta-stable inverter 3102 may be between the upper limit and the lower limit of the meta-stable voltage Vth1.
The first to n-th meta-stable inverters 4101 to 410n may have the same configuration. For example, each meta-stable inverter may include diode-connected PMOS transistors (“output terminal-connected PMOS transistors”), diode-connected NMOS transistors (“output terminal-connected NMOS transistors”), switching transistors respectively connected with the PMOS and NMOS transistors, and a decoder configured to control the switching transistors (refer to
In the first mode, the first meta-stable inverter 4101 may operate as a source for generating the meta-stable voltage V1, and each of the second to n-th meta-stable inverters 4102 to 410n may operate as an amplifier for amplifying an output of a previous stage. To this end, the switches SW1 to SWn may be appropriately switched such that meta-stable inverters of front and rear stages are connected to each other.
In the second mode, a threshold voltage of the first meta-stable inverter 4101 (i.e., a voltage that the meta-stable voltage V1 oscillates with the center as) may be detected. A common mode input voltage of each of the second to n-th meta-stable inverters 4102 to 410n may be also detected by the control circuitry 4200. To this end, of course, the multiplexing circuit 4400 and the switches SW1 to SWn may be appropriately switched.
For example, the control circuitry 4200 may adjust common mode input voltages Vth2 to Vthn within a permissible range while setting the threshold voltage Vth1 to a preset value. In some example embodiments, the common mode input voltages Vth2 to Vthn may correspond to the meta-stable inverters 4102 to 410n, respectively.
In some example embodiments, the control circuitry 4200 may adjust or tune the second to n-th meta-stable inverters 4102 to 410n based on the threshold voltage Vth1 of the first meta-stable inverter 4101.
In some example embodiments, the control circuitry 4200 may adjust or tune the first and third to n-th meta-stable inverters 4101 and 4103 to 410n based on the common mode input voltage Vth2 of the second meta-stable inverter 4102. That is, it may be possible to use a common mode input voltage of any of the second to n-th meta-stable inverters 4102 to 410n as a reference for tuning or adjusting.
A graph indicated by “INV1” refers to an input/output graph of the first meta-stable inverter 4101. A graph indicated by “INV2” refers to an input/output graph of the second meta-stable inverter 4102. A graph indicated by “INV3” refers to an input/output graph of the third meta-stable inverter 4103.
If voltages that are distributed on an upper side with respect to a dotted line indicated by “a” are input, “1” may be output; if voltages that are distributed on a lower side with respect to the dotted line indicated by “a” are input, “0” may be output. That is, an intersection of the graph indicated by “INV1” and the graph indicated by “a” may be understood as the threshold voltage Vth1 of the first meta-stable inverter INV1. As in the above description, an intersection of the graph indicated by “INV2” and the graph indicated by “a” may be understood as the common mode input voltage Vth2 of the second meta-stable inverter INV2. An intersection of the graph indicated by “INV3” and the graph indicated by “a” may be understood as the common mode input voltage Vth3 of the third meta-stable inverter INV3.
For a brief description, it is assumed that a voltage output from the first meta-stable inverter INV1 is “Vth1”. Actually, of course, the voltage output from the first meta-stable inverter INV1 may be a noise that oscillates with respect to the threshold voltage Vth1. “Vth1” may be input to the second meta-stable inverter INV2, and thus, the second meta-stable inverter INV2 may output “V2”. Next, “V2” may be input to the third meta-stable inverter INV3, and thus, the third meta-stable inverter INV3 may output “V2”. That is, since the first to third meta-stable inverters INV1 to INV3 are not matched with each other, a random number may be stuck.
As illustrated in
According to some example embodiments of the inventive concepts, it may be possible to generate a random number by using an adjustable meta-stable voltage.
In addition, according to some example embodiments of the inventive concepts, it may be possible to improve a random number generation speed and to generate a high-quality random number that is not stuck to a specific value.
While the inventive concepts have been described with reference to exemplary embodiments, it will be apparent to those skilled in the art that various changes and modifications may be made without departing from the spirit and scope of the inventive concepts. Therefore, it should be understood that the above embodiments are not limiting, but illustrative.
Number | Date | Country | Kind |
---|---|---|---|
10-2016-0157442 | Nov 2016 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
6963888 | Weimerskirch | Nov 2005 | B2 |
7325021 | Hars | Jan 2008 | B2 |
8150900 | Golic | Apr 2012 | B2 |
8341201 | Vasyltsov et al. | Dec 2012 | B2 |
8522065 | Regev et al. | Aug 2013 | B2 |
8527567 | Vasyltsov et al. | Sep 2013 | B2 |
8650233 | Ikegami et al. | Feb 2014 | B2 |
9047152 | Chu | Jun 2015 | B2 |
9377997 | Vasyltsov et al. | Jun 2016 | B2 |
9405510 | Karpinskyy et al. | Aug 2016 | B2 |
9557964 | Lee | Jan 2017 | B2 |
20040019617 | Hars | Jan 2004 | A1 |
20080091755 | Mudge | Apr 2008 | A1 |
20100201419 | Vasyltsov | Aug 2010 | A1 |
20110302232 | Vasyltsov | Dec 2011 | A1 |
20120278372 | Gribok et al. | Nov 2012 | A1 |
20150106415 | Mei et al. | Apr 2015 | A1 |
20160210121 | Gammel et al. | Jul 2016 | A1 |
Number | Date | Country |
---|---|---|
2013-182097 | Sep 2013 | JP |
20140110142 | Sep 2014 | KR |
10-1481572 | Jan 2015 | KR |
Entry |
---|
V. Suresh, “On-chip True Random Number Generation in Nanometer CMOS”, Diss. University of Massachusetts Amherst, 2012. |
V. Suresh, W. Burleson, “Entropy extraction in metastability-based TRNG”, Proc. IEEE Int. Symp. Hardware-Oriented Security Trust (HOST), pp. 135-140, 2010. |
C. Tokunaga, D. Blaauw, T. Mudge, “True random number generator with a metastability-based quality control”, J. Solid-State Circuits, vol. 43, No. 1, pp. 404-611, 2008. |
S. Srinivasan, S. Mathew, V. Erraguntla, R. Krishnamurthy, “A 4gbps 0.57pj/bit process-voltage-temperature variation tolerant all-digital true random number generator in 45 nm cmos”, Proc. 22nd International Conference on VLSI Design, 2009. |
Number | Date | Country | |
---|---|---|---|
20180143806 A1 | May 2018 | US |