This application claims priority to German Application DE 10 2019 123 555.3, which was filed on Sep. 3, 2019, the entire contents of which are hereby incorporated fully herein by reference.
The present disclosure relates to physically obfuscated circuits.
Piracy and Reverse Engineering (RE) of Integrated Circuits (ICs) is considered as one of the most serious threats to semi-conductor industry, since they may be misused to steal and/or pirate a design: successful attackers can overbuild ICs, or fabricate and sell similar, i.e. “cloned” ICs, they may illegally use or sell the extracted and stolen IP, and reveal competitor's trade secrets, etc. For all these reasons, it is desirable to develop concepts and techniques that thwart IC piracy and Reverse Engineering.
In the drawings, like reference characters generally refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead generally being placed upon illustrating the principles of the invention. In the following description, various aspects are described with reference to the following drawings, in which:
According to various embodiments, a physically obfuscated circuit is provided including a plurality of subcircuits, each subcircuit including at least one p-channel field effect transistor, at least one n-channel field effect transistor, a first power supply terminal configured to receive a first supply voltage with an upper supply potential and a second power supply terminal configured to receive a second supply voltage with a lower supply potential, wherein the at least one p-channel field effect transistor and the at least one n-channel field effect transistor are connected such that the at least one n-channel field effect transistor, if supplied with the upper supply potential at its gate, supplies the lower supply potential to the gate of the at least one p-channel field effect transistor and the at least one p-channel field effect transistor, if supplied with the lower supply potential at its gate, supplies the upper supply potential to the gate of the at least one n-channel field effect transistor and a precharge circuit configured to precharge the subcircuit to a first state in which the potential at the gate of the at least one n-channel field effect transistor is lower than the upper supply potential and the potential at the gate of the at least one p-channel field effect transistor is higher than the lower supply potential and wherein the physically obfuscated circuit further includes a physically obfuscated circuit value bit generation circuit configured to generate at least one physically obfuscated circuit value bit depending on which of the subcircuits first enters a second state in which the potential at the gate of the at least one n-channel field effect transistor is the upper supply potential and the potential at the gate of the at least one p-channel field effect transistor is the lower supply potential.
The following detailed description refers to the accompanying drawings that show, by way of illustration, specific details and aspects of this disclosure in which the invention may be practiced. Other aspects may be utilized and structural, logical, and electrical changes may be made without departing from the scope of the invention. The various aspects of this disclosure are not necessarily mutually exclusive, as some aspects of this disclosure can be combined with one or more other aspects of this disclosure to form new aspects.
One promising approach for reliable and secure identification and authentication of ICs consists in employing so-called Physical Random Functions or physically obfuscated circuits (POCs) to securely generate on-chip secret keys for cryptographic algorithms. Ideally, silicon POCs generate chip-specific keys that are arbitrarily repeatable but unpredictable and cannot be determined externally. This can be accomplished by leveraging random variations of IC manufacturing processes and at the same time rejecting global process, temperature and supply voltage variations and noise.
Since these POCs may be integrated on-chip together with dedicated control logic, any attempt to physically access the POC circuitry itself can be restricted very effectively and efficiently. This significant resistance to physical attacks is the principal advantage of using controlled silicon POCs.
Moreover, for secret-key generation only weak POCs are required, i.e. POCs that generate POC values for only a limited number of challenge-response pairs (compared to the number of possible challenge-response pairs).
A POC value P can be imagined to be a type of fingerprint of a physical object. By way of the true POC value P, i.e., the POC value at its registration, the physical object can be uniquely identified and a key, for example, can be produced on the basis of the identification. The physical object can be a controller or a microcontroller. It may also be a chip card IC (integrated circuit) of a chip card such as a smart card with any form factor, e.g., for a passport or for a SIM (subscriber identity module).
The chip card 100, which is illustrated here in the card format but may have any form factor, has a carrier 101 and a chip card module 102. The chip card module 102 has various components, such as, e.g., a non-volatile memory 103 and a CPU (central processing unit) 104. In various embodiments, the chip card has a component 105, which serves as a POC source, for example a circuit including a multiplicity of subcircuits, wherein an output of a subcircuit specifies (or is used as a basis for) one or more bits of a POC value. It should be noted that the chip card using a POC is only an example and may be a device including any kind of integrated circuit.
The POC value P can be considered to be an identification number for the chip card 100 (more precisely, for the chip card module 102 in the chip card 100). By way of example, the chip card module 102 has a cryptoprocessor which derives a chip-card-individual cryptographic key from this identification number or the CPU 104 itself derives a cryptographic key therefrom.
For security reasons, neither the true POC value P nor the cryptographic key derived therefrom are stored on the chip card 100. Instead, a so-called POC module 106 is situated on the chip card 100 and connected to the physical object 105. If the POC value P is required (e.g. for key generation), a so-called POC request is then made to the POC module 106, whereupon the POC module 106 determines the POC value anew in each case (by way of an internal electronic operation). Expressed differently, the POC module 106 replies to a POC request with the output of a POC value P′, which may differ to a greater or lesser extent from the true POC value P, i.e., the POC value upon registration thereof, depending on the bit stability of the bits supplied by the POC source 105.
There are various approaches to realize controlled silicon-chip-based POCs (i.e., POC sources 105), e.g. SRAM-based, sense-amplifier-based, butterfly-based and latch-based POC fields on the one hand and delay-based POCs such as ring oscillator POCs and arbiter POCs on the other hand.
Approaches like SRAM-POCs (based on the process variation induced tendency of the single bit-cells to assume one of their two stable states at power-up with preference) typically suffer from severe limitations such as poor bit stability and high vulnerability to semi-invasive attacks such as electrical and optical probing, and/or inadequate statistical quality.
As for delay-based POCs, like Ring-Oscillator (RO) and Arbiter POCs (comparing the delays of two ideally identically implemented delay lines), there are similar limitations in terms of bit stability and statistical quality, whereas their known weakness against model building attacks is irrelevant for on-chip cryptographic key generation because the very low number of the controlled silicon POC challenge-response pairs is never directly exposed and cannot be determined externally.
Realizing silicon Arbiter POCs typically leads to relatively poor statistical quality and POC bit stability since, on the one hand, any irregular placement and automated routing of the Arbiter POC's elements result in asymmetric wirings and, as a consequence, in systematic delay skews i.e. in poor statistical quality. On the other hand, the delay differences between the two paths with the same nominal layout length only depend on the small process variations of the involved gates and the wiring making up the competing delay paths, resulting in poor bit stability. This in turn necessitates the generation of so-called helper data during POC enrollment, i.e. along with initial key generation, as well as an expensive (in terms of gate and area count as well as energy dissipation) and time consuming error correction during key reconstruction in the field.
For example, POC bit stability may be enhanced by so-called stable-bit-marking or pre-selection of POC bits (by which unstable bits are discarded in enrollment and no longer considered during reconstruction).
In the following, approaches for realizing a secure and cost efficient POC, e.g. for secret-key generation, are described featuring significantly improved security against physical attacks and exhibiting a reproducibility that is so high that it does not need error correction (which is a considerably expensive measure and typically indispensable for conventional POCs).
These features are achieved by POC circuitry that takes advantage of extremely non-linear electro-thermal deep-sub-threshold relaxation processes from non-equilibrium states towards states of constrained equilibrium.
Specifically, according to various embodiments, the POC source 105 is based on so-called TIE-cells as illustrated in
The TIE cell 200 includes a p-channel field effect transistor (FET) 201 whose source is connected to a high supply potential (VDD), whose gate is connected to the drain of an n-channel field effect transistor 202 and whose drain is connected to the gate of the n-channel field effect transistor 202. The source of the n-channel field effect transistor 202 is connected to a low supply potential (VSS). It should be noted that all FETs mentioned herein may for example be MOSFETs (Metal Oxide Semiconductor Field Effect Transistors) and may be formed in CMOS (Complementary MOS) technology.
The node (or connection) connecting the gate of the p-channel field effect transistor 201 with the drain of the n-channel field effect transistor 202 is in the following referred to as TN and the node (or connection) connecting the gate of the n-channel field effect transistor 202 with the drain of the p-channel field effect transistor 201 is in the following referred to as T. In the following, for simplicity, the state of a node is also denoted with the name to the node, e.g. T is also referred to the state (or signal) at node T.
Let first the case of constrained electro-thermal equilibrium be assumed. It is assumed that the supply potential difference VDD-VSS is high enough so that in steady state equilibrium both FETs 201, 202 operate in strong inversion (i.e. they feature fully developed channel inversion):
VDD−VSS>Vth(n-channel FET 202)+|Vth(p-channel FET 201)|
where Vth(FET) denotes the threshold voltage of the FET indicated in the parenthesis.
Then, the node voltages' expectation values are the steady state values V(T)=VDD and V(TN)=VSS. That is, even for time variant voltages VDD and VSS, the time-averaged values are the above indicated steady state (and time averaged) values V(T)=VDD and V(TN)=VS S.
Moreover, the circuit's relaxation time ranges from some 100 ps up to the nanosecond regime, depending on process technology, supply voltage, and temperature. That is, the potentials V(T) and V(TN) relax from small perturbations (deviations from their steady state values) to their steady state values VDD and VSS with relaxation times in the (sub-)nano-second regime.
For large deviations of V(T) and V(TN) from their equilibrium values, however, there results a completely different behavior of the TIE-Cell circuit components. In particular consider the extreme case of the initial constraint
V(T)=VSS and V(TN)=VDD at time t=0.
That is, the node voltages are first kept at the “inverse” values relative to their above equilibrium values so that initially both FETs 201, 202 are OFF, i.e. they are both in their deep-sub-threshold domain.
If then for t>0 the initial constraint is released (i.e. the nodes T and TN are no longer forced to their initial values), the circuitry 200 finds itself initially in a non-equilibrium state, namely in a state as far as possible away from its above described steady state. As a consequence, the potentials of nodes T and TN will, due to inevitable (deep) sub-threshold currents move in the direction of their equilibrium (steady state) values V(T)=VDD and V(TN)=VSS. This transition is, however, an extremely non-linear one that depends heavily on the VDD voltage level relative to VSS, on the temperature T, and in particular on inevitable manufacturing process variations of the circuit components (here FETs 201, 202), so that two instances (copies) of the “same” TIE cell will with very high probability differ in their relaxation times.
According to various embodiments, two (or more than two, see the examples described below) copies of circuits featuring the above described TIE cell behavior when relaxing from a state far from equilibrium are used for POC circuitry. Such circuits are especially suitable for POC circuitry because of the extremely wide statistical distribution of deep sub-threshold relaxation times due to manufacturing variations.
Specifically, dedicated circuitry based on the above described deep sub-threshold TIE cell relaxation from non-equilibrium states far away from their steady states is introduced (e.g. as in POC source 105), for example as illustrated in
Like all POC cells described herein, a multiplicity of POC cells 300 may be included in a circuit configured to generate one or more POC values, e.g. POC source 105.
The POC cell 300 includes a first TIE cell 312 formed by a first p-channel FET 301 and a first n-channel field effect transistor 302. The FETs 301, 302 are cross-coupled and connected to VDD and VSS, respectively, as explained with reference to
The gate of the second p-channel FET 304 receives a control input signal S. The inverter 303 receives the control input signal S and inverts it to an inverted control signal SN which it supplies to the gate of the second n-channel FET 305.
The source of the second p-channel FET 304 is connected to the source of the first p-channel FET 301 and its drain is connected to the gate of the first p-channel FET 301.
The source of the second n-channel FET 305 is connected to the source of the first n-channel FET 302 and its drain is connected to the gate of the first n-channel FET 302.
The gate of the first p-channel FET 301 is further connected to a first output inverter 306 whose output Z1 is one of the outputs of the POC cell 300.
The POC cell 300 further includes a second TIE cell 313 formed by a third p-channel FET 307 and a third n-channel field effect transistor 308. The FETs 307, 308 are cross-coupled and connected to VDD and VSS, respectively, as explained with reference to
The gate of the fourth p-channel FET 309 receives the control input signal S. The inverted control signal SN is supplied to the gate of the fourth n-channel FET 310.
The source of the fourth p-channel FET 309 is connected to the source of the third p-channel FET 307 and its drain is connected to the gate of the third p-channel FET 307.
The source of the fourth n-channel FET 310 is connected to the source of the third n-channel FET 308 and its drain is connected to the gate of the third n-channel FET 308.
The gate of the third p-channel FET 307 is further connected to a second output inverter 311 whose output Z0 is another one of the outputs of the POC cell 300.
The nodes TN and T of the first TIE cell 312 are referred to as Y1 and Y1N, respectively. The nodes TN and T of the second TIE cell 313 are referred to as Y0 and Y0N, respectively.
The POC cell 300 may be used (e.g. in POC source 105) to generate one bit of a POC value. It may thus also be referred to as POC bit cell. As explained, it has two subcircuits each including a TIE cell 312, 313 and precharge circuitry for enforcing and releasing the non-equilibrium initial condition.
If the control input S is set to 0 (i.e. to VSS level) the precharge circuitry (for the two TIE cells 312, 313) enforces initial TIE cell constraints
V(Y1)=VDD, V(Y1N)=VSS,
V(Y0)=VDD, V(Y0N)=VSS,
since then all precharge transistors 304, 305, 309, 310 for the TIE cell nodes Y1, Y1N and Y0, Y0N are in their respective ON states (where the FETs 304, 305, 309, 310 are in strong inversion).
The signals S, Y1, Y1N, Y0, Y0N, Z1, Z0 are shown over time from left to right (wherein in each case, a line further to the top represents a higher potential (e.g. equal or close to VDD) and a line further to the bottom represents a lower potential (e.g. equal or close to VSS).
First, the precharge control circuitry for the two TIE cells 312, 313 enforces initial TIE cell the constraints
V(Y1)=VDD, V(Y1N)=VSS,
V(Y0)=VDD, V(Y0N)=VSS,
This state is referred to as reset state 401 as the initial state. Then, the control input S is set to 1, whereby a POC access state 402 is initiated. After the POC access the signal S is reset to 0, whereby the circuit enters again its reset state 401.
The extremely non-linear relaxation from the deep sub-threshold non-equilibrium state of nodes Y1, Y1N and Y0, Y0N after the constraints have been released with S=1 (i.e. during the POC access phase 402) is illustrated in
Due to manufacturing variations of the relevant FETs 301, 302 of the first TIE cell 312, as well as FETs 307, 308 of the second TIE cell 313 the electro-thermal relaxations of Y1, Y1N and Y0, Y0N differ usually significantly in their relaxation times (being in the order of some ns up to several μs, depending also heavily on VDD-VSS, and temperature). As a consequence, the output signals Z1 and Z0 switch to 1 at different times.
This is indicated by a time difference 403, denoted as Δtrelax, in
Since the geometrical dimensions (i.e. gate lengths and widths) of the TIE cell components 301, 302, 307, 308 can be chosen to be very small they can be made extremely sensitive to manufacturing process variations. This extreme variation sensitivity of the TIE cells is typically large enough for allowing a very effective so-called stable-bit-marking or adjustable pre-selection of POC bits featuring pre-determined minimum bit stability also with respect to environmental variations (like temperature and supply voltage) as well as to aging.
That can, for instance, be achieved in the following ways.
The POC circuit 500 includes a POC cell 501, for example corresponding to the POC cell 300 of
A switchable (and inverting) delay element 502, 503, referred to by τε, is arranged in each output signal path between the outputs X1 (corresponding to output Z1 of TIE cell 501) and X0 (corresponding to output Z0 of TIE cell 501) of the POC cell 300 and an appropriate RS-Flip-Flop (RS-FF) serving for capturing the resulting POC bit. The delay elements can be seen as pre-selection circuitry for the RS-FF for capturing the POC bit value. The POC bit value that is captured, stored and output is either Z1=0 (and Z0=1) or Z1=1 (and Z0=0).
The RS-FF is in this example formed by a first NOR gate 504 and a second NOR gate 505. One input of the first NOR gate 504 is coupled to the output Y1 of the first delay element 502 and the other input of the first NOR gate 504 is coupled to the output of the second NOR gate 505. One input of the second NOR gate 505 is coupled to the output Y0 of the second delay element 503 and the other input of the second NOR gate 505 is coupled to the output of the first NOR gate 504.
The output of the first NOR gate 504 is a first output Z1 of the POC circuit 500 and the output of the second NOR gate 505 is a second output Z0 of the POC circuit 500.
The first delay element 502, i.e. the delay element of the X1 path, is controlled by a control signal D1 and the second delay element 503, i.e. the delay element of the X0 path, is controlled by a control signal D2.
For Dj=0, j=1, 0, the respective delay element is in a state of minimum delay τ(0), whereas for Dj=1, j=1, 0, the respective delay element is in a state of large delay τ(1)>>τ(0). It should be noted that this approach may be extended to more than two delay adjustment states by including more than two possible values for Dj.
The Dj may be set by a controller, e.g. by the POC module 106. The controller (or a further circuit, e.g. of the POC module 106) may also be supplied by the captured POC bit.
The controller may classify a POC bit as being “stable”, if and only if for both (D1=1, D0=0) and (D1=0, D0=1) the same result is captured by the RS-FF, i.e. pre-selection means that the faster signal path must be at least by τ(1)-τ(0) faster than the slower one to be classified as being a valid POC bit. Otherwise, the controller discards the POC bit, i.e. the corresponding POC Bit is marked invalid or irrelevant in the POC's enrollment phase, and is sorted out for and will not be considered in the POC evaluation/reconstruction phase.
In contrast with POC bit enrollment, during POC reconstruction for all valid POC bits the controller sets both delay elements to the same, e.g. minimum delay τ(0) by applying (D1=0, D0=0) in order to make proper use of the valid POC bit's high stability.
The start value 0 at the POC Bit Cell input S results in a 1 at the Y1 and Y0 inputs of the RS-FF, so that the RS-FF is set to its precharge value (Z1,Z0)=(0,0).
To evaluate the output (Z1,Z0) for a rising signal edge S->1, the RS-FF senses which of the two TIE cell delays within the POC Bit Cell is smaller: (Z1,Z0)=(1,0) if the signal, i.e. the falling edge, arriving at Y1 is faster, and (Z1,Z0)=(0,1) if the falling edge arriving at Y0 is faster. It should be noted that the signal arriving later does not change the value of (Z1,Z0) anymore since then Y1=Y0=0, i.e. the RS-FF switches to its “data storing” state.
An alternative way to realize stable-bit-marking or adjustable pre-selection of POC bits can be implemented by means of a counter that is started by the faster of the two TIE cell outputs Z1 and Z0, and which is stopped by the slower one. An POC bit value is then only accepted as valid (e.g. again by a corresponding controller, e.g. POC module 106) if the counter has reached a predefined (and even adjustable) value. Otherwise, the considered POC bit is marked as invalid since it is considered as not being stable enough.
In addition to that, another criterion for POC Bits that are accepted as valid can be implemented by requiring a maximum delay between the rising edge of S (i.e. the point in time when the POC Bit Cell is activated) and the rising edge of the faster POC Bit Cell outputs Z1 or Z0. That is, the POC Bit is only accepted as valid if the RS-FF can capture the faster POC Bit Cell outputs Z1 or Z0 within a predefined (and even adjustable) time interval that can also be controlled by the above mentioned bit counter.
The POC Bit Cell of
According to one embodiment, this is generalized to circuitry that allows for comparison of more than two TIE cell deep sub-threshold relaxation times. This is illustrated in
The POC cell 600 includes three TIE cells 601, 602, 603, which are like the TIE cells 312, 313 of
The POC cell 600 thus allows for pairwise comparison of three TIE cell deep sub-threshold relaxation times, so that the TIE cell outputs may be configured to perform all three possible comparisons of the delays of the three outputs Z2, Z1 and Z0, thus representing up to three POC bits, two of which can in general be considered independent. The six possible combinations of the values of the three POC bits are given by which of the three outputs switches to One first (three possibilities), times which of the remaining two outputs switches to One second (two possibilities).
A possible generalization of this principle consists in comparing all n*(n−1)/2 outputs Zn−1, Zn−2, . . . , Z0 of a POC Bit Cell including n TIE cells.
Yet another variant of the POC bit generation principle illustrated by
In the following, various variations of the POC generation principle explained with reference to
Similarly to the POC cell 300 of
Similarly to
The buffers 716, 717 together with the input inverter 703 and the n-channel FETs 704, 705, 709, 710 form circuitry for enforcing and releasing the non-equilibrium initial condition.
If the control input S is set to 0 (i.e. to VSS level, e.g. by a corresponding controller, e.g. POC module 106) the initial TIE cell constraints
V(Y1)=VSS, V(Y1N)=VSS,
V(Y0)=VSS, V(Y0N)=VSS,
are now enforced since then the TIE cells' upper supply voltage (VDD in
This reset state 801 is indicated in
POC access is initiated with the rising edge 803 of S (S=0->1), whereby first of all SD, which is the upper supply of the TIE cells 712, 713 switches to 1 (i.e. VDD level) so that nodes Y1 and Y0 are pulled up via the n-channel FETs 704, 709 to voltage levels of approximately VDD-Vth(FET 704) and VDD-Vth(FET 709), respectively. Shortly afterwards SN switches to 0 and disables the precharge transistors 704, 705, 709, 710 for the TIE cell nodes Y1, Y1N and Y0, Y0N, whereby the latter's node voltages drop a little by a difference ΔVcc and a difference ΔVcc′, respectively, due to capacitive coupling from SN.
Then, the relaxation of node pairs Y1, Y1N and Y0, Y0N takes place, however, compared to that described with
Moreover and more importantly, there is also realized a negative feedback with respect to temperature variations: since Vth(FET 704) and Vth(FET 709) rise with falling temperature, the start values of the voltages at nodes Y1 and Y0 decrease with lower temperatures thereby increasing the relaxation speed and counteracting the decrease in relaxation speed due to higher threshold voltages of FETs 701, 714, 702 and 707, 715, 708.
The extremely non-linear relaxation from the deep sub-threshold non-equilibrium state of nodes Y1, Y1N and Y0, Y0N after the constraints have been released with S=1 (i.e. during the POC access phase 802) is indicated in
Due to manufacturing variations of the relevant transistors 701, 714, 702 (of first TIE cell 712), as well as transistors 707, 715 and 708 (of second TIE cell 713) the electro-thermal relaxations of Y1, Y1N and Y0, Y0N differ usually significantly in their relaxation times (being in the order of some ns up to several 10 ns). As a consequence, the output signals Z1 and Z0 switch to 1 at different times which is indicated by a time difference 804, denoted as Δtrelax, in
The POC cell 900 differs from the POC cell 700 in that the input inverter 903 does not receive its input signal via a second buffer 717 but receives an enable signal E (and thus generates a signal EN instead of SN).
Thus, the only difference to
Similarly to the POC cell 700 of
Moreover, there is also circuitry for enforcing and releasing the non-equilibrium initial condition including a first input inverter 1011 with input S and output SN, a second input inverter 1012 with input SN and output SD, a first buffer 1013 with input SN and output SND, a third input inverter 1014 with input SND and output SD2, a second buffer 1015 with input SD2 and output SDD, a fourth inverter 1016 with input SDD and output SNDD, as well as (only nMOS) precharge transistors 1017 to 1020 for the TIE cell nodes Y1, Y1N and Y0, Y0N, respectively (which are denoted as in
Specifically, the first precharge n-channel FET 1017 is supplied with SND at its gate and SD at its source and is coupled to Y1 with its drain, the second precharge n-channel FET 1018 is supplied with SNDD at its gate and VSS at its source and is coupled to Y1N with its drain, the third precharge n-channel FET 1019 is supplied with SND at its gate and SD at its source and is coupled to Y0 with its drain and the fourth precharge n-channel FET 1020 is supplied with SNDD at its gate and VSS at its source and is coupled to Y0N with its drain.
Similarly to
If the control input S is set to 0 (i.e. to VSS level, e.g. by a corresponding controller, e.g. POC module 106) the initial TIE cell constraints
V(Y1)=VSS, V(Y1N)=VSS,
V(Y0)=VSS, V(Y0N)=VSS,
are enforced since then the TIE cells' upper supply voltage (VDD in
This reset state is indicated in
POC access is initiated with the rising edge 1103 of S (S=0->1), whereby first of all SD, the precharge value for nodes Y1 and Y0 switches to 1 (i.e. VDD level) thereby pulling up nodes Y1 and Y0 via the first precharge FET 1017 and the third precharge FET 1019 to voltage levels of approximately VDD-Vth (FET 1017) and VDD-Vth (FET 1019), respectively, since signal SND, controlling the gates of these precharge FETs 1017, 1019, remains at VDD level for a short time interval due to the first delay buffer 1013. Then, SND switches to 0 and disables the precharge FETs 1017, 1019 for the TIE cell nodes Y1 and Y0, whereby the latter's node voltages drop a little by ΔVcc due to capacitive coupling from SND. Finally, SNDD switches to 0 and disables the second precharge FET 1018 and the fourth precharge FET 1019 for nodes Y1N and Y0N, whereby the latter's node voltages drop a little by ΔVcc′ due to capacitive coupling from SNDD.
Then, the relaxation of node pairs Y1, Y1N and Y0, Y0N takes place, however, compared to that in
Moreover and more importantly, there is also realized a negative feedback with respect to temperature variations: since Vth(FET 1017) and Vth(FET 1019) rise with falling temperature, the start values of the voltages at nodes Y1 and Y0 decrease with lower temperatures thereby increasing the relaxation speed and counteracting the decrease in relaxation speed due to higher threshold voltages of the TIE cells' FETs 1002, 1003, 1004, 1007, 1008, 1009.
The extremely non-linear relaxation from the deep sub-threshold non-equilibrium state of nodes Y1, Y1N and Y0, Y0N after the constraints have been released with S=1 (i.e. during the POC access phase 1102) is indicated in
Due to manufacturing variations of the relevant transistors 1002, 1003, 1004 (first TIE cell 1001), as well as transistors 1007, 1008, 1009 (second TIE cell 1002) the electro-thermal relaxations of Y1, Y1N and Y0, Y0N differ usually significantly in their relaxation times (being in the order of some ns up to several 10 ns). As a consequence, the output signals Z1 and Z0 switch to 1 at different times which is indicated by a time difference 1104, denoted as Δtrelax, in
This means that the TIE cells 1212, 1213 are each formed by a p-channel FET 1201, 1207 and a serial connection of n-channel FETs 1202, 1214, 1208, 1215 (instead of the other way round as in
The POC cell 1200 further differs from the POC cell 700 in that there is a first input inverter 1203 which receives the input signal S and outputs SN to the source of the second precharge FET 1205 and the fourth precharge FET 1210 and a second input inverter 1216 which receives SN, inverts it to SD and supplies SD to the gates of the precharge FETs 1204-1210.
The input inverters 1203, 1216 and the precharge FETs 1204, 1205 (for Y1 and Y1N) and 1209, 1210 (for Y0 and Y0N) form the circuitry for enforcing and releasing the non-equilibrium initial condition.
Similarly to
If the control input S is set to 0 (i.e. to VSS level), e.g. by a corresponding controller, e.g. POC module 106) the initial TIE cell constraints
V(Y1)=VDD, V(Y1N)=VDD,
V(Y0)=VDD, V(Y0N)=VDD,
are enforced since then the TIE cells' lower supply voltage (VSS in
This reset state is indicated in
POC access is initiated with the rising edge 1303 of S (S=0->1 of S), whereby first of all SN, the lower supply of the TIE cells 1212, 1213 switches to 0 (VSS level) so that nodes Y1N and Y0N are pulled down via the second precharge FET 1205 and the fourth precharge FET 1210 to voltage levels of approximately |Vth(FET 1205)| and |Vth(FET 1210)|, respectively.
Shortly afterwards SD switches to 1 and disables the precharge FETs 1204, 1205, 1209, 1210 for the TIE cell nodes Y1, Y1N and Y0, Y0N, whereby the latter's node voltages increases a little by ΔVcc and ΔVcc′, respectively, due to capacitive coupling from SD.
Then, the relaxation of node pairs Y1, Y1N and Y0, Y0N takes place, however, compared to that described with
This results first of all in generally smaller relaxation times (since the TIE cells' n-channel FETs 1202, 1214, 1208, 1215 start in a comparatively less deep sub-threshold state).
Moreover and more importantly, there is also realized a negative feedback with respect to temperature variations: since |Vth(FET 1205)| and |Vth(FET 1210)| rise with falling temperature, the start values of the voltages at nodes Y1N and Y0N increase with lower temperatures thereby increasing the relaxation speed and counteracting the decrease in relaxation speed due to higher threshold voltages of the TIE cells' FETs 1201, 1202, 1214, 1207, 1208, 1215.
The extremely non-linear relaxation from the deep sub-threshold non-equilibrium state of nodes Y1, Y1N and Y0, Y0N after the constraints have been released with S=1 (i.e. during the POC access phase 1302) is indicated in
Due to manufacturing variations of the relevant transistors 1201, 1202, 1204 (of first TIE cell 1212), as well as transistors 1207, 1208, 1215 (of second TIE cell 1213) the electro-thermal relaxations of Y1, Y1N and Y0, Y0N differ usually significantly in their relaxation times (being in the order of some ns up to several 10 ns). As a consequence, the output signals Z1 and Z0 switch to 1 at different times which is indicated by a time difference 1304, denoted as Δtrelax, in
In summary, according to various embodiments, a physically obfuscated circuit (POC) circuit is provided as illustrated in
The physically obfuscated circuit 1400 includes a plurality of subcircuits 1401, each subcircuit 1401 including at least one p-channel field effect transistor 1402, at least one n-channel field effect transistor 1403, a first power supply terminal 1404 configured to receive a first supply voltage with an upper supply potential and a second power supply terminal 1405 configured to receive a second supply voltage with a lower supply potential.
The at least one p-channel field effect transistor 1402 and the at least one n-channel field effect transistor 1403 are connected such that the at least one n-channel field effect transistor 1403, if supplied with the upper supply potential at its gate, supplies the lower supply potential to the gate of the at least one p-channel field effect transistor 1402 and the at least one p-channel field effect transistor 1402, if supplied with the lower supply potential at its gate, supplies the upper supply potential to the gate of the at least one n-channel field effect transistor 1403.
Each subcircuit 1401 further includes a precharge circuit 1406 configured to precharge the subcircuit to a first state in which the potential at the gate of the at least one n-channel field effect transistor 1403 is lower than the upper supply potential and the potential at the gate of the at least one p-channel field effect transistor 1402 is higher than the lower supply potential.
The physically obfuscated circuit 1400 further includes a physically obfuscated circuit value bit generation circuit 1407 configured to generate at least one physically obfuscated circuit value bit depending on which of the subcircuits 1401 first enters a second state in which the potential at the gate of the at least one n-channel field effect transistor 1403 is the upper supply potential and the potential at the gate of the at least one p-channel field effect transistor 1402 is the lower supply potential.
The physically obfuscated circuit (POC) circuit 1400 may for example correspond to the POC source 105 together with the POC module 106.
In other words, according to various embodiments, two (or more) TIE cells (denoted as “subcircuit” above) with each at least one p-channel FET and at least n-channel FET which hold each other in a steady state by turning each other on, are each precharged to an inverse state. The inverse state is inverse to the steady state in the sense that the FETs are turned off. A POC bit is generated based on which TIE cell reaches its steady state first. When there are more than two TIE cells, multiple POC bits may be generated by the POC bit generation circuit based on the order the TIE cells reach the steady state.
The first state may be a state when the FETs are turned off and the second state may be a state when the FETs are turned on. It should be noted that there may be a “relaxation state” between the first state and the second state i.e. a state which each subcircuit has when transitioning from the first state to the second state. The first state (possibly together with the relaxation state) may be seen as “non-equilibrium” state.
The relaxation state of a subcircuit for example starts when the precharge circuit finishes precharging the circuit, i.e. releases the subcircuit from the first state (which is enforced by the precharge). For example, in the first state the precharge circuit forces the subcircuit to be (and stay in the first state) and then “releases” the subcircuit to transition into its second state. The subcircuits can then be seen to “race” for the second state and the POC bit generation circuit generates one or more POC bits based on which subcircuit “wins the race” (or in case of more than two TIE cells, possibly on the order in which the TIE cells finish the respective relaxation).
Various Examples are described in the following:
Example 1 is a physically obfuscated circuit as illustrated in
Example 2 is a physically obfuscated circuit according to Example 1, wherein the precharge circuit is configured to let the subcircuits start transitioning from the first state to the second state after precharging the subcircuits to the first state.
Example 3 is a physically obfuscated circuit according to Example 2, wherein the precharge circuit is configured to let the subcircuits start transitioning from the first state to the second state by means of supplying a common input signal to the subcircuits.
Example 4 is a physically obfuscated circuit according to any one of Examples 1 to 3, wherein the precharge circuit is configured to precharge the circuit to the first state in response to the reception of a request for a physically obfuscated circuit value.
Example 5 is a physically obfuscated circuit according to any one of Examples 1 to 4, wherein the second state is a steady state of the subcircuit and the first state is an inverse state of the second state.
Example 6 is a physically obfuscated circuit according to any one of Examples 1 to 5, wherein in the first state the potential at the gate of the at least one n-channel field effect transistor is the lower supply potential and the potential at the gate of the at least one p-channel field effect transistor is the higher supply potential.
Example 7 is a physically obfuscated circuit according to any one of Examples 1 to 6, wherein in the first state the potential at the gate of the at least one n-channel field effect transistor is a potential to turn off the n-channel field effect transistor and the potential at the gate of the at least one p-channel field effect transistor is a potential to turn off the p-channel field effect transistor.
Example 8 is a physically obfuscated circuit according to any one of Examples 1 to 7, wherein the physically obfuscated circuit value bit generation circuit is configured to receive, from each subcircuit, a signal indicating the state of the subcircuit.
Example 9 is a physically obfuscated circuit according to Example 8, wherein the physically obfuscated circuit value bit generation circuit includes a latch circuit supplied with the signal indicating the state of the subcircuit from each subcircuit and configured to be switched in a stable state depending on which of the subcircuits first enters the second state.
Example 10 is a physically obfuscated circuit according to any one of Examples 1 to 9, wherein the plurality of subcircuits includes three or more subcircuits and the physically obfuscated circuit value bit generation circuit is configured to generate a plurality of physically obfuscated circuit value bits depending on an order in which the subcircuits enter the second state.
Example 11 is a physically obfuscated circuit according to any one of Examples 1 to 10, wherein each subcircuit includes: a plurality of p-channel field effect transistors; wherein the p-channel field effect transistors and the at least one n-channel field effect transistor are connected such that the at least one n-channel field effect transistor, if supplied with a upper supply potential at its gate, supplies the lower supply potential to the gates of the p-channel field effect transistors; and the p-channel field effect transistors, if supplied with the lower supply potential at their gates, supply the upper supply potential to the gate of the at last one n-channel field effect transistor.
Example 12 is a physically obfuscated circuit according to any one of Examples 1 to 10, wherein each subcircuit includes: a plurality of n-channel field effect transistors; wherein the n-channel field effect transistors and the at least one p-channel field effect transistor are connected such that the at least one p-channel field effect transistor, if supplied with a lower supply potential at its gate, supplies the higher supply potential to the gates of the n-channel field effect transistors; and the n-channel field effect transistors, if supplied with the higher supply potential at their gates, supply the lower supply potential to the gate of the at last one p-channel field effect transistor.
Example 13 is a physically obfuscated circuit according to any one of Examples 1 to 10, wherein each subcircuit includes: a plurality of p-channel field effect transistors; a plurality of n-channel field effect transistors; wherein the p-channel field effect transistors and the n-channel field effect transistors are connected such that the n-channel field effect transistors, if supplied with a upper supply potential at their gates, supply the lower supply potential to the gates of the p-channel field effect transistors; and the p-channel field effect transistors, if supplied with the lower supply potential at their gates, supply the upper supply potential to the gates of the n-channel field effect transistors.
Example 14 is a physically obfuscated circuit according to Example 13, wherein the p-channel field effect transistors are connected in series and their gates are connected and the n-channel field effect transistors are connected in series and their gates are connected.
Example 15 is a physically obfuscated circuit according to any one of Examples 1 to 14, further including a key generator configured to generate a cryptographic key based on the physically obfuscated circuit value bit.
Example 16 is a physically obfuscated circuit according to any one of Examples 1 to 15, wherein in the first state the potential at the gate of the at least one n-channel field effect transistor depends on a field effect transistor threshold voltage of a field effect transistor of the precharge circuit.
Example 17 is a physically obfuscated circuit according to any one of Examples 1 to 16, Wherein in the first state the potential at the gate of the at least one p-channel field effect transistor depends on a field effect transistor threshold voltage of a field effect transistor of the precharge circuit.
Example 18 is a physically obfuscated circuit according to any one of Examples 1 to 17, wherein in the first state the potential at the gate of the at least one n-channel field effect transistor is the lower supply potential plus a field effect transistor threshold voltage of a field effect transistor of the precharge circuit.
Example 19 is a physically obfuscated circuit according to any one of Examples 1 to 18, wherein in the first state the potential at the gate of the at least one p-channel field effect transistor is the higher supply potential minus a field effect transistor threshold voltage of a field effect transistor of the precharge circuit.
Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that a variety of alternate and/or equivalent implementations may be substituted for the specific embodiments shown and described without departing from the scope of the present invention. This application is intended to cover any adaptations or variations of the specific embodiments discussed herein. Therefore, it is intended that this invention be limited only by the claims and the equivalents thereof.
Number | Date | Country | Kind |
---|---|---|---|
102019123555.3 | Sep 2019 | DE | national |
Number | Name | Date | Kind |
---|---|---|---|
3849673 | Koo | Nov 1974 | A |
4506165 | Gulati et al. | Mar 1985 | A |
5159260 | Yoh et al. | Oct 1992 | A |
5689471 | Voss et al. | Nov 1997 | A |
5982211 | Ko | Nov 1999 | A |
6005797 | Porter et al. | Dec 1999 | A |
6133754 | Olson | Oct 2000 | A |
6621318 | Burr | Sep 2003 | B1 |
7084683 | Nix | Aug 2006 | B1 |
7249109 | Silverbrook et al. | Jul 2007 | B1 |
7916517 | Kuenemund | Mar 2011 | B2 |
8111089 | Cocchi et al. | Feb 2012 | B2 |
8362807 | Upputuri et al. | Jan 2013 | B2 |
8434046 | Marinet | Apr 2013 | B2 |
8710889 | Chromczak | Apr 2014 | B1 |
9070439 | Gammel et al. | Jun 2015 | B2 |
9496872 | Kuenemund | Nov 2016 | B1 |
10347630 | Kuenemund | Jul 2019 | B2 |
20020036577 | Volk | Mar 2002 | A1 |
20020080663 | Kameyama et al. | Jun 2002 | A1 |
20040108873 | Tierno et al. | Jun 2004 | A1 |
20040150052 | Riccardi et al. | Aug 2004 | A1 |
20040196082 | Pacha et al. | Oct 2004 | A1 |
20050093597 | Kwak | May 2005 | A1 |
20060038582 | Peeters | Feb 2006 | A1 |
20060208772 | Nakano | Sep 2006 | A1 |
20070081405 | Yoo et al. | Apr 2007 | A1 |
20080136483 | Sanduleanu et al. | Jun 2008 | A1 |
20100085081 | Ofuji et al. | Apr 2010 | A1 |
20100259301 | Marino et al. | Oct 2010 | A1 |
20110025393 | Sommer | Feb 2011 | A1 |
20110156007 | Otsuji et al. | Jun 2011 | A1 |
20120009207 | Chin et al. | Jan 2012 | A1 |
20130099320 | Lee et al. | Apr 2013 | A1 |
20130320491 | Thacker, III et al. | Dec 2013 | A1 |
20140139262 | Penzes | May 2014 | A1 |
20140327469 | Pfeiffer et al. | Nov 2014 | A1 |
20150071434 | Thacker, III et al. | Mar 2015 | A1 |
20150294843 | Chen et al. | Oct 2015 | A1 |
20150294943 | Kuenemund et al. | Oct 2015 | A1 |
20150294944 | Kuenemund et al. | Oct 2015 | A1 |
20150303927 | Kuenemund et al. | Oct 2015 | A1 |
20150311202 | Kuenemund | Oct 2015 | A1 |
20150381351 | Kuenemund et al. | Dec 2015 | A1 |
20160337123 | Seok et al. | Nov 2016 | A1 |
20170019104 | Kuenemund | Jan 2017 | A1 |
20170110418 | Kuenemund et al. | Apr 2017 | A1 |
20190140643 | Kuenemund | May 2019 | A1 |
20210280536 | Kuenemund | Sep 2021 | A1 |
20210385094 | Yu | Dec 2021 | A1 |
Number | Date | Country |
---|---|---|
1307748 | Aug 2001 | CN |
1362743 | Aug 2002 | CN |
1510837 | Jul 2004 | CN |
1612266 | May 2005 | CN |
1918795 | Feb 2007 | CN |
101501778 | Aug 2009 | CN |
102113114 | Jun 2011 | CN |
103066021 | Apr 2013 | CN |
104978499 | Oct 2015 | CN |
105024686 | Nov 2015 | CN |
106603066 | Apr 2017 | CN |
106357263 | May 2019 | CN |
102015105417 | Oct 2015 | DE |
102016113128 | Jan 2017 | DE |
102016120009 | Apr 2017 | DE |
102017126217 | May 2019 | DE |
1220450 | Jul 2002 | EP |
2320344 | May 2011 | EP |
20030026058 | Mar 2003 | KR |
2005076478 | Aug 2005 | WO |
2007038448 | Apr 2007 | WO |
2018009415 | Jan 2018 | WO |
Entry |
---|
Guajardo, J., “FPGA Intrinsic PUFs and Their Use for IP Protection”, Cryptographic Hardware and Embedded Systems—CHES 2007, Sep. 2007, 18 pages, 9th International Workshop, Vienna, Austria. |
Lim, D., “Extracting Secret Keys from Integrated Circuits”, IEEE Transactions on Very Large Scale Integration (VLSI) Systems, Apr. 25, 2005, 18 pages, vol. 13, issue 10, IEEE. |
German Office Action issued for the corresponding DE application No. 10 2019 123 555.3, dated Jun. 30, 2020, 12 pages (for informational purpose only). |
J. Rajendran et al., “Security Analysis of Integrated Circuit Camouflaging”, CCS '13: Proceedings of the 2013 ACM SIGSAC Conference on Computer & Communications Security, Nov. 2013, 12 pages, Berlin, Germany. |
R. Torrance, “The state-of-the-art in Semiconductor Reverse Engineering at Chipworks”, Chipworks, Sep. 9, 2009, 72 pages. |
“Circuit Camouflage Technology”, SMI IP Protection and Anti-Tamper Technologies, Syphermedia Library,Version 1.9.8j, Mar. 2012, SypherMedia International, 6 pages. |
S. Wayne. “Combinational Logic Circuits”, Electronics Tutorials, Web, Jun. 9, 2018. |
Number | Date | Country | |
---|---|---|---|
20210066216 A1 | Mar 2021 | US |