Tampering, or hacking, of an electronic system can give unauthorized users access to sensitive information. An example of such sensitive information can be secret key information used in cryptography engine implementations, such as AES (Advanced Encryption Standard). An attacker can use characteristics of the electronic system to passively or actively gain knowledge about system operations. Sometimes adversaries attempt to observe the behavior of the circuit to determine sensitive data.
By observing electromagnetic radiation emitted when bits are transmitted to and from memory (or between other components), values of the bits being conveyed across lines on the chip may be identified. Similarly, an adversary may use power analysis and correlate power usage with the sensitive data. For example, differential power analysis, which is a statistical method for analyzing power consumption, may be used to identify data-dependent correlations. For differential power analysis, multiple traces of two sets of data are obtained, and the difference of the average of these traces is computed. If the difference is close to zero, then the two sets are considered not correlated. If the two sets are correlated, then the difference will be a non-zero number and given enough traces, even tiny correlations can be seen, regardless of how much noise is in the system.
Methods and systems for obfuscating data at-transit within an electronic system are provided. The described methods and systems can be suitable for protecting against attacks, such as side channel attacks including electromagnetic radiation analysis and power analysis.
The protection can involve adding more difficulty or complexity to a system to hinder an attacker from being able to trace or analyze the activity occurring within the electronic system. By obfuscating the data at-transit, an attacker cannot gain system knowledge by active probing (e.g., tapping a signal line or power line) or remote side-channel analysis (e.g., noticing power differences and electromagnetic (EM) differences).
A method for obfuscating data at-transit can include receiving a request for communicating data, determining a sequence of data at-transit for a window of time; and providing the sequence of the data at transit for performing communications across interconnect to another component.
When applying the method during reading from or writing to memory, the method for obfuscating data at-transit can begin upon receiving a request for memory access. The obfuscation method can determine a sequence of data at-transit for a window of time. The sequence can include an indication for valid data and an indication for dummy data. When the request for memory access is a request to obtain data stored in the memory, memory requests can be performed according to the determined sequence of data at-transit. The source of the request can then be provided with the valid data and the dummy data can be discarded.
The described method can be performed within a secure element of an electronic system. The secure element can include a processor coupled to receive data input and a clock signal and output requests; a memory coupled to receive requests from the processor and return data to the processor; an interconnect fabric coupling the processor and the memory; and an obfuscation engine coupled to the processor and memory to receive a valid request and output obfuscated data.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Methods and systems for obfuscating data at-transit within an electronic system are provided. The described methods and systems can be suitable for protecting against attacks, such as side-channel attacks including electromagnetic radiation analysis and power analysis.
In side-channel attacks, an adversary can gain information about a system without tampering with the system. This can occur by an adversary scanning the unintentional outputs of the hardware. For example, the power signature of a system can be significantly stronger when accessing memory than when performing other operations. The stronger power signature can be traced more clearly from the outside. Additionally, since these types of attacks lack the ability to determine context, the attacks often rely on the secure element transmitting as much valid data as possible. By diluting the amount of valid data in various ways, the data an adversary does manage to collect can become progressively less useful.
The methods described herein can obscure data at transit such that an attacker cannot easily gain system knowledge by active probing (e.g., tapping a signal line or power line) or remote side-channel analysis (e.g., noticing power differences and EM differences).
An obfuscation system for obscuring data at transit can be incorporated into an electronic system as part of an existing component or as an independent component that performs obfuscation methods on behalf of an existing component.
The application of the described obfuscation systems and methods can be based on areas and communications that may pose the most risk of attack. For example, communications between components such as between a crypto engine and a processor and between the crypto engine or processor and a memory storage may take place over connections such as buses, relays, fabric, interconnects, opto-electronic channels and the like. Many electronic systems are deterministic in nature. That is, the resulting behavior of the system is determined by its initial state and inputs and is not random. Accordingly, it can be beneficial to inject some degree of randomness to a deterministic system to cause indeterministic behavior. There are several ways to inject randomness to the system, including obfuscating the data at-transit. Methods for obscuring data at-transit can be initiated upon introducing data to anything that is functionally and intuitively deterministic within the system, such as relays or memory. Accordingly, the described systems and methods may provide certain countermeasures against attacks.
The memory 120 can include circuitry 122 and memory cells 124. The circuitry 122 can support the addressing of the memory cells 124 and other mechanisms to write and read the data stored in the cells 124. Memory 120 may be any suitable memory type including, but not limited to volatile memories (e.g., random access memory such as DRAM and SRAM) and non-volatile memories (e.g., read only memory such as EEPROM and flash and magnetic memory such as FeRAM and MRAM). In some cases, more than one memory is included and provide volatile and non-volatile storage for the secure element 100.
An obfuscation system can be used within a secure element such as secure element 100 in an electronic system to perform methods of obfuscation for obfuscating data at-transit (e.g., between processor 110 and memory 120). The obfuscation system can further de-obfuscate the data upon completion of secure operations within the secure element in order to enable the electronic system to operate appropriately. In some cases, the obfuscation system may be implemented as control logic using existing hardware within the secure element. In other cases, the obfuscation system may be implemented in software using existing hardware in the secure element.
The obfuscation system can be considered an “obfuscation engine” as its use can be integral for other programs and functions of the electronic system (and secure element). Accordingly, obfuscation system and obfuscation engine are used interchangeably herein.
Referring to
In some cases, such as a read request, the obfuscation engine may obfuscate the data in-transit by sending valid read requests and dummy read requests. In some of such cases, the memory 220 can operate as usual and respond with data as if all requests are valid and the obfuscation engine 215 discards the data provided in response to the dummy read requests. In some cases, dummy requests are to addresses with valid data. In some cases, dummy requests are to addresses with data specifically stored as dummy data in the memory 220.
In some cases, such as during a write request (and even for a read request), the obfuscation engine 215 applies an indicator to the data to indicate whether the data is valid data or dummy data (or whether the request itself is a valid request or a dummy request). In some of such cases, the memory 220 understands to discard/not write data to addresses indicated as part of a dummy write request. The indicator may be a flag or other marker that can be understood to indicate the type of data. Such flags and markers may already be part of an existing protocol used in the secure element (e.g., an available bit in the register, page table, or other data structure used to indicate permissions with respect to a memory location or address or an available bit in the transmission protocol for communication over the interconnect).
In some cases where null data is provided, the request can include no data or incomplete data or a delay can be inserted between valid and/or dummy requests.
In this manner, valid data transiting from the processor 210 to the memory 220 and from the memory 220 to the processor 210 over interconnect 225 is harder to detect.
Referring to
In some cases, such as a read request from processor 250, the obfuscation engine 245 may obfuscate the data in-transit by sending valid data, dummy data, and/or null data in response to the read request. The obfuscation engine 245 can include an indicator with the data being sent in response to the read request such that the processor 250 can determine whether to discard or use the returned data. In some cases, such as during a write request, the obfuscation engine 245 can cause dummy data to be transmitted to the processor 250. As mentioned above, the indicator may be a flag or other marker that can be understood to indicate the type of data.
The obfuscation engine 245 can, in some cases, also modify the data width of the data transmitted to the processor 250 such that extra bits or bytes are transmitted in response to a read request from the processor 250. These extra bits or bytes can be discarded by the processor 250. In some cases, the extra bits are provided before the valid data. In some cases, the extra bits are provided at the end of the valid data. In some cases, extra bits are provided interspersed between valid data in a manner that can be easily identified by the processor 250 (e.g., by a pattern understood by the processor 250 because the processor 250 expects the data in that manner or by a pattern provided to the processor 250 from the obfuscation engine 245 in a message before the data is sent as some examples).
Accordingly, the obfuscation engine can send more and different data to the processor 250 over interconnect 225 in a manner that makes detection of valid information harder to detect.
Referring to
The obfuscation engine 270 can act as an intermediary between the processor 250 and the memory 220. In some cases, the obfuscation engine 270 receives data at-transit from the processor 250, obfuscates the data at-transit using any one of the obfuscation methods, and then sends the obfuscated data at-transit to the memory 220 (e.g., while keeping track of valid and dummy read requests). In some of such cases, in response to receiving data returned from the memory 220, the obfuscation engine 270 can de-obfuscate the data to return only valid data to the processor 250. In other of such cases, in response to receiving the data returned from the memory 220, the obfuscation engine 270 can send obfuscated data to the processor 250 (e.g., such as described with respect to obfuscation engine 245).
There are several methods for obscuring sensitive data at-transit within a secure element. The objective of the methods is to make it very difficult for an attacker to distinguish between a real transaction of passing sensitive, valid data and a dummy (e.g., fake) transaction that passes dummy data. The difference between the valid transactions and the dummy transactions should be difficult to detect from the outside. For example, the dummy data should have similar characteristics to the valid data in order to make it indistinguishable for an attacker to know the actual events.
A clock signal such as clock 130 of
The sequence may be stored at the obfuscation engine in a manner that permits the obfuscation engine to keep track of whether valid data, null data, or dummy data is being sent or received across the interconnect, which is useful when the communications across the interconnect are performed. Valid data is considered data that is useable by the system; null data is considered a clock cycle in which no data is in transit and is used in some scenarios where obfuscation includes timing adjustments; dummy data is considered data that can be discarded by the system. In some cases, valid data, null data, and dummy data are used to obfuscate the data in-transit. In some cases, just valid data and dummy data are used to obfuscate the data in-transit. In yet other cases, just valid data is used to obfuscate the data in-transit and the sequence is used to rearrange the valid data out of order. In some implementations, all three types of cases are possible and may occur. In some implementations, the obfuscation engine uses one or two of the cases out of the three as possible for a particular data request/operation.
When providing (330) the sequence for performing communications across interconnect, the obfuscation engine can directly use the sequence to control the data sent across interconnect or can provide the sequence to another component that then uses the sequence to control the data. As mentioned above, the sequence indicates whether the communication is with valid data or dummy data or even whether a pause/null data is performed. The communications following this sequence may be used to transmit partial portions of valid data or used to transmit consecutive data sets. For example, if a standard data set is 32 bits, the 32 bits may be broken up into 8 bit or 16 bit portions that may be interspersed with dummy data and/or pauses. In other cases, if the standard data set is 32 bits, the 32 bits can be transmitted when the sequence indicates that valid data is to be communicated.
In a specific example, such as when the request for communicating data is a read request for data from memory, the memory requests may be performed according to the sequence of the data at-transit. For example, valid read requests may be communicated interspersed with dummy read requests. The memory may only return data from the valid read requests or may return valid data and dummy data according to the sequence/indicator with the read request. When both dummy data and valid data is returned, the sequence can be used to determine which data is valid and which data is dummy data or there may be a flag on the data that indicates whether the data is valid data or dummy data. The valid data can then be provided to the source of the request for further operations.
As shown in
Referring to
Referring to
Referring to
A method of obscuring data at transit can also use data width modification. Data width modification can be performed at memory or in an engine. The data width of the data from memory can be either smaller or larger than the data width after modification. In the case of the data width after modification being larger than the data width of the data from memory, the valid data can be placed randomly (or pseudorandomly) within the larger width or always placed at the same location within the larger width. For example, if placing the data in the same positions, consider if the data from memory were 0101. If the data width after modification is eight bits, the four-bit sequence could be always at the beginning of the eight bits (0101XXXX), always at the end of the eight bits (XXXX0101), or somewhere in the middle (possibly (XXX0101X). The data after modification that is not the valid data can be bits generated randomly (or pseudorandomly) or have some predefined or generated pattern (or even a repeat of valid data). If data is distributed randomly (or pseudorandomly), the distribution can be based on a predetermined randomized seed to begin a sequence.
In the case of the data width after modification being smaller than the data width of the data from memory, the data could be split up into two or more groups in a variety of ways. The data could be distributed between the groups in a variety of ways, including frontloaded, backloaded, randomly, pseudorandomly, or evenly. If there is more data in total than the data from memory, for instance if six bits of data are sent in four-bit increments, then the remaining data can be any suitable dummy data.
Although the described methods are provided in the context of cryptographic systems, it should be understood that the methods are applicable to other systems in which protection against side channel attacks is desired. Advantageously, certain methods described herein can be implemented using the existing hardware within a cryptographic engine, including, but not limited to, state machines and counters. In some cases, an attack may be identified during operation of the described methods and the computing device can leverage the identification of the attack to increase security by implementing more countermeasures.
Although the subject matter has been described in language specific to structural features and/or acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as examples of implementing the claims and other equivalent features and acts are intended to be within the scope of the claims.
Number | Name | Date | Kind |
---|---|---|---|
9646516 | Chamley | May 2017 | B2 |
9830588 | Davis | Nov 2017 | B2 |
9904814 | Gonzalez | Feb 2018 | B2 |
10678707 | Poeppelmann | Jun 2020 | B2 |
11139971 | Poeppelmann | Oct 2021 | B2 |
11265163 | Poeppelmann | Mar 2022 | B2 |
20010010032 | Ehlers | Jul 2001 | A1 |
20020027988 | Callum | Mar 2002 | A1 |
20020108063 | Lee | Aug 2002 | A1 |
20020152209 | Merugu | Oct 2002 | A1 |
20030137860 | Khatri | Jul 2003 | A1 |
20030236978 | Evans | Dec 2003 | A1 |
20050117578 | Stewart | Jun 2005 | A1 |
20060117122 | Hannah | Jun 2006 | A1 |
20070150953 | Hamid | Jun 2007 | A1 |
20080040520 | Caulkins | Feb 2008 | A1 |
20080040533 | Caulkins | Feb 2008 | A1 |
20080040544 | Caulkins | Feb 2008 | A1 |
20080126766 | Chheda | May 2008 | A1 |
20090182965 | Norman | Jul 2009 | A1 |
20090328003 | Pensak | Dec 2009 | A1 |
20100299538 | Miller | Nov 2010 | A1 |
20110019819 | Bernstein | Jan 2011 | A1 |
20110047630 | Cheng | Feb 2011 | A1 |
20110055592 | Teuwen | Mar 2011 | A1 |
20110138373 | Lane | Jun 2011 | A1 |
20110161217 | Cohen | Jun 2011 | A1 |
20110166972 | Cohen | Jul 2011 | A1 |
20110219173 | Morita | Sep 2011 | A1 |
20120079281 | Lowenstein | Mar 2012 | A1 |
20120079282 | Lowenstein | Mar 2012 | A1 |
20120137119 | Doerr | May 2012 | A1 |
20120260041 | Habusha | Oct 2012 | A1 |
20120324141 | Seong | Dec 2012 | A1 |
20130054933 | Fister | Feb 2013 | A1 |
20130132607 | Sinha | May 2013 | A1 |
20130145177 | Cordelia | Jun 2013 | A1 |
20150012737 | Newell | Jan 2015 | A1 |
20150026451 | Doerr | Jan 2015 | A1 |
20150113594 | Stewart | Apr 2015 | A1 |
20150220431 | Rolandi | Aug 2015 | A1 |
20150229471 | Nair | Aug 2015 | A1 |
20150271677 | Van Nieuwenhuyze | Sep 2015 | A1 |
20160019415 | Ra | Jan 2016 | A1 |
20160134595 | Lavinio | May 2016 | A1 |
20160171228 | Bhagat | Jun 2016 | A1 |
20160232357 | Doerr | Aug 2016 | A1 |
20170034214 | Houser | Feb 2017 | A1 |
20170061138 | Lambert | Mar 2017 | A1 |
20170112577 | Bonutti | Apr 2017 | A1 |
20170155502 | Yanamandra | Jun 2017 | A1 |
20180011995 | Pitu | Jan 2018 | A1 |
20180025150 | Shivanna | Jan 2018 | A1 |
20180060611 | Houser | Mar 2018 | A1 |
20180081818 | Che | Mar 2018 | A1 |
20180081825 | Aschauer | Mar 2018 | A1 |
20180081826 | Gounares | Mar 2018 | A1 |
20180121369 | Poeppelmann | May 2018 | A1 |
20180137310 | Schenk | May 2018 | A1 |
20180167365 | Zarcone | Jun 2018 | A1 |
20180241760 | Stephens | Aug 2018 | A1 |
20180262230 | Jain | Sep 2018 | A1 |
20180262526 | Jain | Sep 2018 | A1 |
20180262527 | Jain | Sep 2018 | A1 |
20180276416 | Doerr | Sep 2018 | A1 |
20180349631 | Illendula | Dec 2018 | A1 |
20190042711 | Parhi | Feb 2019 | A1 |
20190044719 | Poeppelmann | Feb 2019 | A1 |
20190171650 | Botev | Jun 2019 | A1 |
20190196481 | Tay | Jun 2019 | A1 |
20190305927 | Bhunia | Oct 2019 | A1 |
20190306134 | Shanbhogue | Oct 2019 | A1 |
20190312728 | Poeppelmann | Oct 2019 | A1 |
20190371145 | McQueen | Dec 2019 | A1 |
20190371209 | Gou | Dec 2019 | A1 |
20200007319 | Herzerg | Jan 2020 | A1 |
20200074109 | Pieniazek | Mar 2020 | A1 |
20200104891 | Rule | Apr 2020 | A1 |
20200319925 | Clampitt, III | Oct 2020 | A1 |
20200336303 | Sierra | Oct 2020 | A1 |
20200396250 | Nguyen | Dec 2020 | A1 |
20210049309 | Su | Feb 2021 | A1 |
Entry |
---|
Pan etal “Obfuscation Algorithm Design Based on Fully Homomorphism,” 2018, IEEE, pp. 1-3 (Year: 2018). |
Provisional U.S. Appl. No. 62/564,947 (Year: 2017). |
Awad et al. “ObfusMem: A Low-Overhead Access Obfuscation for Trusted Memories,” ACM, pp. 107-119 (Year: 2017). |
Wang et al “Seeing Through Network-Protocol Obfuscation,” ACM, pp. 1-13 (Year: 2015). |
Riboni et al “Obfuscation of Sensitive Data in Network Flows,” IEEE Infocom, Mar. 2012, pp. 1-10 (Year: 2012). |
Dixon et al “Network Traffic Obfuscation and Automated Internet Censorship,” Nov. 14, 2016, pp. 1-9 (Year: 2016). |
Number | Date | Country | |
---|---|---|---|
20210119763 A1 | Apr 2021 | US |