The present disclosure relates to a method and system for improving security in electronically fused encryption keys.
Semiconductor devices may utilize security keys to protect against unauthorized access. The semiconductor industry is making use of electronic fuses that may be blown in a manufacturing environment which may allow unique data to be stored permanently on a per processor basis. Electronic fuses are typically sensed electronically during power-on or each time the data is read. Unauthorized users (e.g., a user without a matching key to an encryption key) may attempt to work around these security schemes by using unnatural voltages, voltage sequences, temperature, and frequency. For instance, an unauthorized user may attempt to lower the voltage and cool the processor during a boot sequence in an effort to malfunction the electronic fuses into a known state—such as all zero or all one—which may be trivial to bypass.
A method for electronically fused encryption key security includes inserting a plurality of inverters between a bank of security fuses and a fuse sense logic module. The method also includes sensing an activated set of the bank of security fuses and the plurality of inverters. The method further includes comparing the sensed activated set of the bank of security fuses and the plurality of inverters with a software key to determine whether at least a substantial match is made.
An electronically fused encryption key security system includes a plurality of security fuses and a plurality of inverters operably coupled between the plurality of security fuses and a fuse sense logic module. The fuse sense logic module is configured for sensing the output of the plurality of security fuses and the plurality of inverters. The system also includes a software key including a preconfigured fuse sense pattern and a comparison module configured to compare the output of the fuse sense logic module and the software key.
An electronically fused encryption key security system includes a plurality of security fuses and an error correction code (ECC) check module operably coupled between the plurality of security fuses and a fuse sense logic module. The fuse sense logic module is configured for sensing the output of the ECC check module. The system also includes a plurality of ECC fuses operably coupled to the ECC check module. The ECC check module is configured to compare an output from the plurality of security fuses and an output from the plurality of ECC fuses to determine whether at least a substantial match is made. The system further includes a software key including a preconfigured fuse sense pattern and a comparison module configured to compare the output of the fuse sense logic module and the software key.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not necessarily restrictive of the present disclosure. The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate subject matter of the disclosure. Together, the descriptions and the drawings serve to explain the principles of the disclosure.
The numerous advantages of the disclosure may be better understood by those skilled in the art by reference to the accompanying figures in which:
Reference will now be made in detail to the subject matter disclosed, which is illustrated in the accompanying drawings.
Referring to
The system 100 may also include a fuse sense logic module 120. Fuse sense logic module 120 may be implemented to sense an activated set of the bank of security fuses 110, such as by receiving an output signal from the bank of security fuses 110. For instance, when a user attempts to access system 100, an output from the bank of security fuses 110 may be sent to the fuse sense logic module 120 for processing, such as via an output signal. Fuse sense logic module 120 may be configured to compare 130 the output of the bank of security fuses 110 to a software key 140. For example, fuse sense logic module 120 may be configured to control a comparison module 130, or alternatively, fuse sense logic module 120 may include a comparison module 130 which may include hardware and/or software configured to support a comparison to be made. Such hardware and/or software may be of a form known in the art.
Software key 140 may include a preconfigured fuse sense pattern, which may provide a key against which the output of the bank of security fuses 110 may be compared. In one embodiment, the software key 140 is stored in a register of system 100. For instance, the software key 140 may be stored in a memory system within system 100, such as in a non-volatile memory component including one or more of ROM (read only memory), PROM (programmable ROM), EPROM (erasable PROM), EEPROM (electronically erasable PROM), flash memory, or other suitable memory technology. Alternatively, the software key 140 may be supplied to system 100 via an external memory device, such as a hard disc drive, an optical disc, a flash memory device, or other suitable portable memory device.
As explained above, fuse sense logic module 120 may be configured to compare 130 the output of the bank of security fuses 110 to a software key 140. In one embodiment, the comparison is made to determine whether at least a substantial match is made. For instance, at least a substantial match may include a majority of the bits of the output of the bank of security fuses 110 matching the bits of the software key, or may include a range of percentiles that indicate a substantial match, such as between 60 and 95%, or the like. However, it may be appreciated that any degree of specificity may be made in determining whether a match is made, including requiring an exact match, wherein the output of the bank of security fuses 110 exactly matches the software key (e.g., the bits of the output of the bank of security fuses 110 exactly matches the bits of the software key). When the fuse sense logic module 120 determines the requisite degree of comparison has been established, the fuse sense logic module 120 may send an unlock control signal 150 to a CPU, computer/device hardware, or the like, which may enable the device or information on the device to be accessed. As will be explained below, a number of techniques may be utilized to help ensure that the device or information on the device will be accessed by a user with the proper authentication key, as opposed to an unauthorized user using bypassing techniques.
The system 100 may include a plurality of inverters 160 to invert the output of selected fuses of the bank of security fuses 110. The plurality of inverters 160 may be operably coupled between the bank of security fuses 110 and the fuse sense logic module 120. In one embodiment, the plurality of inverters 160 may be included in a pseudo-random arrangement between the bank of security fuses 110 and the fuse sense logic module 120. For instance, a pseudo-random arrangement of fuses of the bank of security fuses 110 may have outputs inverted before the output signals are sent to the fuse sense logic module 120. In this manner, the key formed by the bank of security fuses 110 may be made less trivial, even if all the fuses are sensed the same. For example, even if an unauthorized user employed techniques such as utilizing unnatural voltages, voltage sequences, temperatures, and frequencies, and the like to attempt to have all the fuses sensed as an unintended, predictable pattern, the inverters may prevent such techniques from providing a substantial match between the output of the bank of security fuses 110 and the software key 140. In this manner, the inverters may prevent a trivial pattern of all zeroes or all ones from reaching the fuse sense logic module 120 for comparison 130 for which an unauthorized user could provide the corresponding all zero or all one software key. It may be appreciated that any number of inverters may be utilized to provide a desired inversion effect on the outputs of fuses from the bank of security fuses, and that such inverters may be utilized as part of a pattern or as a random or pseudo-random arrangement.
The plurality of inverters 160 may be accounted for during the time of manufacturing, such as when setting the encryption key to be matched in the software key 140. For bit positions where there is an inverter, the key may be stored as inverted in the e-fuse of the bank of security fuses 110. In this manner, an authorized user providing a software key 140 may not need to know about the inversion that occurs in the hardware to obscure the key.
Referring now to
The ECC check module 170 may be configured to compare an output from the bank of security fuses 110 and the plurality of inverters 160 and an output from the plurality of ECC fuses 180 to determine whether at least a substantial match is made. For instance, the plurality of ECC fuses 180 may include a plurality of check-bits against which an output from the bank of security fuses 110 may be compared to determine whether the activated set of the bank of security fuses 110 is a valid key. When the result of comparing an output from the bank of security fuses 110 and the plurality of inverters 160 and an output from the plurality of ECC fuses 180 is determined to not be at least a substantial match, the activated set of the bank of security fuses may be rejected 190 by the ECC check module 170. Thus, the attempted key may be deemed invalid 190, and may fail even before the fuse sense logic module 120 compares the attempted key to the software key 140. In such an instance, no unlock signal 150 would be sent to a CPU, computer/device hardware, or the like, thereby keeping the device or information on the device locked/restricted.
When an attempted key is deemed valid by the ECC check module 170, the fuse sense logic module 120 may then compare 130 the output of the bank of security fuses 110 to a software key 140. When the fuse sense logic module 120 determines the requisite degree of comparison has been established, the fuse sense logic module 120 may send an unlock control signal 150 to a CPU, computer/device hardware, or the like, which may enable the device or information on the device to be accessed.
Additionally, it may be appreciated that the system 100 may be implemented without the plurality of inverters 160, and instead the system may rely on ECC check module 170 and the plurality of ECC fuses 180 to avoid access to a device or information on a device by an unauthorized user.
Referring now to
Operation 310 depicts inserting a plurality of inverters between a bank of security fuses and a fuse sense logic module. For example, as shown in
Operation 330 depicts comparing the sensed activated set of the bank of security fuses and the plurality of inverters with a software key to determine whether at least a substantial match is made. For example, as shown in
In the present disclosure, the methods disclosed may be implemented as sets of instructions or software readable by a device. Further, it is understood that the specific order or hierarchy of steps in the methods disclosed are examples of exemplary approaches. Based upon design preferences, it is understood that the specific order or hierarchy of steps in the method can be rearranged while remaining within the disclosed subject matter. The accompanying method claims present elements of the various steps in a sample order, and are not necessarily meant to be limited to the specific order or hierarchy presented.
It is believed that the present disclosure and many of its attendant advantages will be understood by the foregoing description, and it will be apparent that various changes may be made in the form, construction and arrangement of the components without departing from the disclosed subject matter or without sacrificing all of its material advantages. The form described is merely explanatory, and it is the intention of the following claims to encompass and include such changes.
Number | Name | Date | Kind |
---|---|---|---|
5033084 | Beecher | Jul 1991 | A |
5452355 | Coli | Sep 1995 | A |
5563950 | Easter et al. | Oct 1996 | A |
5799080 | Padmanabhan et al. | Aug 1998 | A |
6292422 | Pitts | Sep 2001 | B1 |
6505324 | Cowan et al. | Jan 2003 | B1 |
6915476 | Morino et al. | Jul 2005 | B2 |
7076699 | Puri et al. | Jul 2006 | B1 |
7120696 | Au et al. | Oct 2006 | B1 |
7268577 | Erickson et al. | Sep 2007 | B2 |
7336095 | Erickson et al. | Feb 2008 | B2 |
7821041 | Chung et al. | Oct 2010 | B2 |
7941769 | Hu | May 2011 | B1 |
20050122800 | Morino et al. | Jun 2005 | A1 |
20050212527 | Wu | Sep 2005 | A1 |
20060025952 | Buhr | Feb 2006 | A1 |
20060131743 | Erickson et al. | Jun 2006 | A1 |
20060136751 | Bonaccio et al. | Jun 2006 | A1 |
20060136858 | Erickson et al. | Jun 2006 | A1 |
20070241768 | Erickson et al. | Oct 2007 | A1 |
20080283963 | Chung et al. | Nov 2008 | A1 |
20090080659 | Elder et al. | Mar 2009 | A1 |
20090290712 | Henry et al. | Nov 2009 | A1 |
20090292929 | Henry et al. | Nov 2009 | A1 |
20090292931 | Henry et al. | Nov 2009 | A1 |
20090293129 | Henry et al. | Nov 2009 | A1 |
20090293130 | Henry et al. | Nov 2009 | A1 |
20090293132 | Henry et al. | Nov 2009 | A1 |
20100085075 | Luzzi et al. | Apr 2010 | A1 |
20100264932 | Marinissen et al. | Oct 2010 | A1 |
Number | Date | Country |
---|---|---|
1003-046501 | Feb 2003 | JP |
Number | Date | Country | |
---|---|---|---|
20100250943 A1 | Sep 2010 | US |