The present disclosure relates to systems and methods for protecting digital circuits, and in particular to a system and method for obfuscating an integrated circuit with camouflaged gates and logic encryption.
Integrated Circuit (IC) designs are vulnerable to IP theft from reverse engineering, unauthorized cloning and over-production, and device corruption due to Trojan insertion. The risks to the IC industry have been steadily increasing as reverse engineering capabilities increase, and as worldwide IC production capabilities consolidate into a small number of foreign entities.
Logic encryption, also called logic obfuscation, is a hardware obfuscation technique that modifies a circuit so that it operates correctly only when a set of newly-introduced key-data inputs is correctly applied. The key is known only to the original circuit designers and can be programmed into the device's non-volatile storage such as one-time-programmable OTP memory at a secure facility after manufacture. Without the key data, unauthorized devices manufactured by the IC fabricator or by a third party will not function correctly. See, for example, A. Roy, F. Koushanfar, and I. L. Markov, “Ending Piracy of Integrated Circuits,” Design, Automation, and Test in Europe 2008, Munich, Germany, Mar. 10-14, 2008; R. S, Chakraborty and S. Bhunia. “Hardware Protection and Authentication through Netlist Level Obfuscation,” IEEE/ACM International Conference on Computer-Aided Design, 2008; and S. Dupuis, P.-S. Ba, G. Di Natale, M.-L. Flottes, and B. Rouzeyre. “A Novel Hardware Logic Encryption Technique for Thwarting illegal Overproduction and Hardware Trojans,” IEEE International On-Line Testing Symposium, 2014, all hereby incorporated by reference herein.
To address the requirements described above, this document discloses a system and method for obfuscating at least a portion of an integrated circuit having a plurality of elements including logic elements and memory elements, the integrated circuit comprising a plurality of nets having two or more interconnected elements. In one embodiment, the method comprises computing a number of observable points (COP) for each net of the portion of the integrated circuit; compute a selection weight (WS) for each net; and selecting one or more nets for insertion of at least one protection element based on the computed selection weights (WS). Another embodiment is evidenced by an apparatus having a processor and a communicatively coupled memory storing processor instructions for performing the foregoing operations.
In one embodiment, the method is used to choose key-gate locations in a circuit based on its topology. The method balances security concerns and logical effectiveness. When compared to unweighted random selection, this method yields higher efficiency in corrupting device outputs, and reduces the risk of clustering key-gates within a small logical region. The method is heuristic, providing one acceptable solution among many, and an attacker cannot utilize his knowledge of the method to pinpoint the obfuscated key-gates. The key-gate location selection method to be presented works equally well on circuits with or without camouflaged gates, but use of camouflaged gates is highly recommended for the reasons described in the Introduction and Background sections of this document.
In another embodiment, the method is also used to choose insertion points for camouflaged micro-circuits in a circuit based on its topology. The method balances security concerns and logical effectiveness. When compared to unweighted random selection, this method yields higher efficiency in corrupting device outputs, and reduces the risk of clustering camouflaged micro-circuits within a small logical region. The method is heuristic, providing one acceptable solution among many, and an attacker cannot utilize his knowledge of the method to pinpoint the camouflaged micro-circuits.
The features, functions, and advantages that have been discussed can be achieved independently in various embodiments of the present invention or may be combined in vet other embodiments, further details of which can be seen with reference to the following description and drawings.
Referring now to the drawings in which like reference numbers represent corresponding parts throughout:
In the following description, reference is made to the accompanying drawings which form a part hereof, and which is shown, by way of illustration, several embodiments. It is understood that other embodiments may be utilized and structural changes may be made without departing from the scope of the present disclosure.
Highly effective protection can be achieved through use of camouflaged gates in conjunction with logic encryption. A camouflaged cell or gate is a logic gate that appears to have one function based on image analysis of the cell layout, but in fact performs a different function. See, for example, L. W. Chow, et al., “Camouflaging a standard cell based integrated circuit,” U.S. Patent Publication No. 2010/0213974, L. W. Chow, et al., “Method and apparatus for camouflaging a standard cell based integrated circuit,” U.S. Patent Publication 2010/0218158, L. W. Chow, et al, “Method and apparatus for camouflaging a standard cell based integrated circuit with micro circuits and post processing,” U.S. Patent Publication 2012/0139582, and L. W. Chow, et al., “Method and apparatus for camouflaging a standard cell based integrated circuit,” U.S. Patent Publication 2013/0191803, all of which are hereby incorporated by reference herein.
Use of camouflaged gates in conjunction with logic encryption protects logic encryption key data against known attacks. Additionally, use of camouflaged gates provides an additional, independent level of security against attackers who are not in possession of the production mask data. If the encryption key is compromised, all camouflaged cells must still be correctly identified and modeled before the circuit can be modeled and duplicated.
Circuit camouflage technology encompasses the design and use of camouflaged logic gates whose logical function is difficult to determine using conventional reverse engineering techniques (see U.S. Patent Publications 2010/0213974, 2010/0218158, 2012/0139582, and 2013/0191803, referenced above) The text and diagrams of this invention utilize a style of camouflaged gate whose apparent physical design mimics that of a conventional logic gate of the standard cell library used to design the IC, but the camouflaged gate's actual logic function differs from that of the mimicked logic gates. This is the most prevalent type of camouflaged gate in use today. The camouflaged circuit contains a number of camouflaged gates among a sea of normal gates, and a netlist extracted with conventional reverse engineering techniques will contain a number of discrepancies proportional to the number of camouflaged gates used in the circuit. The number and location of the camouflaged gates is not apparent to the reverse engineer.
It has been shown that key data in a conventional logic encryption scheme can be determined from the circuit design in linear time with respect to the key length by applying Input vectors to an unlocked fabricated device, observing device outputs, and using satisfiability checking (SAT) software to infer the logic encryption key from the observations and the gate-level netlist. See, for example, P. Subramanyan, S. Ray, and S. Malik, “Evaluating the Security of Logic Encryption Algorithms,” Hardware-Oriented Security and Trust (HOST), 2015, which is hereby incorporated by reference herein. Conventional logic encryption is also vulnerable to other attack models, as shown in J. Rajendran, Y. Pino, O. Sinanoglu, and R. Karri. “Security Analysis of Logic Obfuscation,” Proceedings of the Design Automation Conference, 2012, also hereby incorporated by reference herein. However, an accurate gate-level netlist of the device is required to perform any attack of this class because the state of a device's internal key-gate nodes must be inferred from its primary outputs. When a number of the device's logic gates are obfuscated with circuit camouflage technology, this type of attack becomes much more difficult because a reverse engineer cannot extract a gate-level netlist whose function matches that of the fabricated device. Therefore, it is highly desirable to utilize camouflaged cells in a logic encryption implementation. Camouflaged gates may be used in the logic encryption network as key-gates, control logic, or glue logic, and they may also be used in the core logic of the fabricated circuit itself.
It has been shown that key data in a conventional logic encryption scheme can be determined from the circuit design in linear time with respect to the key length by applying input vectors to an unlocked fabricated device, observing device outputs, and using satisfiability checking (SAT) software to infer the logic encryption key from the observations and the gate-level netlist (see “Evacuating the Security of Logic Encryption Algorithms” cited above). Conventional logic encryption is also vulnerable to other attack models (see “Security Analysis of Logic Obfuscation” cited above). However, an accurate gate-level netlist of the device is required to perform any attack of this class because the state of a device's internal key-gate nodes must be inferred from its primary outputs. When a number of the device's logic gates are obfuscated with circuit camouflage technology, this type of attack becomes much more difficult because a reverse engineer cannot extract a gate level netlist whose function matches that of the fabricated device. Therefore, it is highly desirable to utilize camouflaged cells in a logic encryption implementation. Camouflaged gates may be used in the logic encryption network as key-gates, control logic, or glue logic, and they may also be used in the core logic of the fabricated circuit itself.
Previous work in the subject of key-gate insertion locations involved maximizing the logical impact of the key-gates without regard for their detectability. Rajendran et al. used fault propagation models to choose key-gate locations that were shown to have the most significant impacts on device outputs (see J. Rajendran, H. Zhang, C. Zhang, G. S. Rose, Y. Pino, O. Sinanoglu, and R. “Fault Analysis-Based Logic Encryption,” IEEE Transactions on Computers vol. 64 (2), pp. 410-424, 2013, hereby incorporated by reference herein). The fault propagation method of logic encryption showed considerable improvements over unweighted random key-gate selection. However, since the entire circuit is comprised of conventional standard cells, the entire circuit may be easily extracted by a reverse engineer, enabling him to find all key-gate locations and to attempt to obtain the secret key-data through circuit analysis and simulation (see “Security Analysis of Logic Obfuscation” cited above). So, while this method may key-gates efficiently to corrupt device outputs, it does not effectively prevent reverse engineering of real circuits. The fault analysis method has several other disadvantages:
1) High tool cost/complexity, as it requires fault propagation and analysis software.
2) Long runtime, as it is an iterative method inserting one key-gate at a time before rerunning fault propagation and analysis.
3) The method yields a unique solution fora given circuit, so awareness of the method will lead an attacker directly to the location of each key-gate.
Since gate G1 is a NAND2 gate (camouflaging is indicated by dashed lines) that is camouflaged to looks like a NOR2 gate, it is likely that a reverse engineer will interpret G1 as a NOR2 gate, inferring the incorrect function. With a camouflaged implementation of logic encryption, an attacker cannot use the extracted netlist to determine the key because there is no combination of key inputs that will enable the extracted netlist to behave like the fabricated circuit. Use of camouflaged gates provides an additional level of security. If the encryption key is compromised, all camouflaged cells must be correctly identified and modeled before the circuit will work correctly.
The operations described below and the apparatuses for implementing them enable automated identification of key-gate locations with several advantages over prior methods. In particular:
1) More effective than random selection, circuit topology is considered to determine meaningful locations for key-gates;
2) Avoids clustering key-gates close to each other in the logical network;
3) Heuristic method provides one acceptable solution among many, and an attacker cannot use his knowledge of the method to pinpoint the key-gate locations;
4) Low tool cost, no fault analysis software required;
5) Fast run times, no fault propagation calculations to run.
The described key-gate location selection method works equally well on circuits with or without camouflaged gates, but use of camouflaged gates is highly recommended for the reasons described in the Introduction and Background sections of this document.
Camouflaged micro-circuits are collections of camouflaged and non-camouflaged gates that perform a logical function, including stuck-at-zero or stuck-at-one (see U.S. Patent Publications 2010/0213974, 2010/0218158, 2012/0139582, and 2013/0191803, referenced above). Because camouflaged gates have a different logical function than their physical design suggests, a camouflaged micro-circuit may perform a different logical function than its physical design suggests. When a reverse engineer attempts to extract a netlist from a device containing one or more camouflaged micro-circuits, it is highly probable the extracted netlist will contain logical errors.
Camouflaged micro-circuits may be inserted, or connected to, logical nodes in the design to provide protection against reverse engineering.
The circuit 400B includes a camouflaged micro circuit 402 and a terminal logic gate 406 interposed at the insertion point. In this illustrated example, the camouflaged micro-circuit 402 has an actual logic function of stuck-at-zero (regardless of input) but its physical design suggests that it has a different function. The circuit 400B fabricated with the camouflaged micro-circuit (bottom) will function identically to the un-camouflaged circuit implementation 400A because a logical zero provided by the camouflaged micro-circuit 402 to one of the inputs to the terminal gate 406 having an OR logical function will assure that the protected signal always has the same logical state as the original insertion point. However, a netlist extracted from the device containing a camouflaged micro-circuit will likely contain errors with conventional reverse engineering methodology.
Other work in the subject of camouflaged micro-circuit insertion point selection was limited to pseudo-random selection based on the logical hierarchy of a circuit. With pseudo-random selection, there is the risk that ineffectual nodes (nodes that are unlikely to affect a circuit's primary outputs) may be chosen as an insertion points.
The techniques presented in this specification enables automated identification of camouflaged micro-circuit insertion points with several advantages over prior methods:
1) More effective than random selection, circuit topology is considered to determine meaningful locations for camouflaged micro-circuits
2) Avoids clustering camouflaged micro-circuits close to each other in the logical network
For the purposes of this description, an observable point is the data input of a storage element, or a primary output of the circuit that is to be protected. These points represent logical nodes that are likely to affect primary outputs of the circuit to be protected, either immediately or during a future clock cycle. A launch point is the data output of a storage element, or a primary input of the circuit that is to be protected. These points will define the next state of the circuit.
Logic encryption is highly resistant to brute force attack because the key length of a logic encryption implementation can be arbitrarily long. With at 2n possible key combinations, brute force attack quickly becomes impractical. However, as stated previously, conventional logic encryption has been shown to be weak against a class of attacks that are aimed at inferring the logic encryption key data from an unlocked fabricated device. Once the key data is obtained, the attacker can unlock a locked device, effectively defeating the logic encryption mechanism.
The class of published attacks against logic encryption can be summarized as follows. Note that a gate-level netlist is a necessary component of this class of attack.
1) The attacker obtains two unlocked devices, often purchased on the open market.
2) The attacker extracts the gate-level netlist of the first unlocked device using conventional reverse-engineering techniques.
3) The attacker, using analysis software and the extracted gate-level netlist, develops one or more device input vectors with the goal of determining one or more key bits, which are observable at key-gate input nodes.
4) The attacker applies the input vectors from step 3 to the second unlocked device and observes the device outputs.
5) The attacker, using analysis software and the device's gate-level netlist, attempts to infer one or more key bits using the results obtained in step 4.
6) The attacker repeats step 3-5 until all key bits have been determined.
The use of circuit camouflage technology in the device prevents extraction of an accurate gate-level netlist of the device, This introduces a number of functional discrepancies between the attacker's gate-level netlist and unlocked device, which greatly complicates the attack procedure. The number of functional discrepancies is proportional to the number of camouflaged gates used in the circuit. Since conventional reverse-engineering techniques cannot effectively differentiate a camouflaged gate from a normal gate, the attacker is unable to readily determine either the locations or the number of functional discrepancies. Without an accurate gate-level netlist with which to analyze the device's behavior, it is not possible to determine the key-data from inferring the state of key-gate input nodes.
Camouflaged gates may be used effectively in the circuit's logic encryption network. While camouflaged gates in the logic encryption network have no effect on the core functions of the circuit, they prevent an attacker from inferring the logic encryption network's key data through application of Boolean logic on an extracted netlist.
Camouflaged gates in the core region of the circuit will cause functional discrepancies between an extracted netlist and the original fabricated circuit even if the correct key-data is applied to the logic encryption network. Additionally, they will prevent an attacker inferring the logic encryption network's key data through application of Boolean logic on an extracted netlist.
A technique for selecting key-gate locations using circuit topology is now presented. First, the number of observable points (as defined above) are computed for each net. Then, selection weights (WS) for each net are computed, while avoiding launch point bias. Finally, the nets for insertion of protection elements are selected based on selection weights WS. Such protection elements may include key gates and/or camouflaged micro-circuits. The use of key gates as protection elements is described first, then the analogous case of the use of camouflaged micro-circuits is described. These operations are further described below with respect to inserting key gate protection elements with reference the exemplary circuit of
This section discusses one embodiment of how to compute the number of COP for each net. An analysis of circuit topology produces a count of observable points in the downstream logic cone for each net in the circuit that is to be protected. A net whose downstream logic cone connects to a large number of observable points has a high likelihood of corrupting device outputs when incorrect key-data is present. This count, which shall be referred to as COP, is an integer value that is considered when choosing key-gate locations. The calculation of COP is the first step in the topological method for selecting key-gate locations. One embodiment of operations that can be used to compute a number of observable points COP for each net in the circuit to be protected is summarized below. As described above, the launch points of this circuit include points (n1, n2, n3, n5) (which are register outputs (n5) and the block primary inputs (n1, n2, and n3)). Further, the observable points include (n4, n6, n7, n8) (which are register inputs (n4) and block primary outputs (n6, n7, and n8)).
I. Calculate COP for each net in the circuit to be protected.
This section describes on embodiment of how to compute a selection weight (WS) for each net. This selection process avoids launch point bias. It is noted that for nets along any given logic path, COP of each net increases as its separation from a launch point decreases. This generally leads to a situation where the majority of high COP values are at or near launch points, and low COP values are at or near observable points. Therefore, choosing key-gate locations based on COP alone may have the undesirable effect of reducing an attacker's workload if he infers that a high percentage of key-gates be located at or near launch points. It is desirable to compensate for this launch point bias.
One possible method to compensate for launch point bias is to de-weight nets that are at or very close to launch points, therefore granting highest weights to nets that are neither at the very beginning nor the very end of a logic path. This optimization is desirable to prevent a large number of key-gate locations at the beginning of a logic path, which could become a detectable signature to reverse engineers.
In one implementation, selection weights (WS) are computed by multiplying the previously-computed COP counts by launch point adjustment factors FLPA that are computed for each net(WS=COP*FLPA). FLPA is a real number between 0 and 1 inclusive, and is computed based on circuit connectivity and two pre-determined constant values, NLPA and NL. NLPA is a real number between 0 and 1 inclusive representing the most significant launch point adjustment factor, which is the factor applied directly to launch points. NL is an integer of at least 1 representing the number of logic levels over which to apply the launch point adjustment factor. The launch point adjustment factor yields the largest adjustment (FLPA=NLPA) when the given net is a launch point, with the factor yielding decreasing adjustments (1>FLPA>NLPA) the further the given net is away from launch points. The factor yields no adjustment (FLPA=1) when the given net is at least NL logic levels away from a launch point. The constants NLPA and NL can either be set by designers or dynamically computed based on analyzing the circuit to be protected. Unless otherwise noted, examples provided in this paper will use the values and NLPA=0.4 and NL=2, which will be acceptable for most circuits.
The following steps show the calculation of launch point adjustment factors (FLPA) and selection weights (WS). They are performed after the previously-described calculation of COP in Step I.
II. Initialize a launch point adjustment vector VLPA such that it has NL elements and ranges from FLPA to 1−(1−NLPA)/FL. This will later be used to convert a net's distance from a launch point to a launch point adjustment factor.
III. Determine each net's distance from a launch point (DLP).
IV. Calculate selection weight WS for each net by using the net's distance from a launch point to look up FLPA in the launch point adjustment vector VLPA.
Table 1 below illustrates example launch point adjustment vectors (VLPA) for various values of NLPA and NL. NLPA is a real number between 0 and 1 inclusive, and NL is an integer of at least 1. Grayed boxes indicate that the index is out of bounds.
The final step of the key-gate location selection method involves using previously-calculated selection weights (WS) to select the nets for key-gate insertion. The weighted selection algorithm presented below features pseudorandom selection.
It is desirable to avoid a purely deterministic selection process. As an example of an algorithm to avoid, a “greedy” method that selects nets based only on picking the highest selection weights would yield a predictable and repeatable result, and may guide an attacker to discover the key-gate locations. An alternative method is the one described below, which avoids the aforementioned pitfalls.
V. Sort the nets based on ascending selection weights (WS).
VI. Group sorted nets into to NB separate bins B[0] to B[NB−1] such that each bin contains nets with similar selection weights (WS).
VII. Determine the desired number of nets to select from each bin NN[0] to NN[NV−1]. In general, more nets should be chosen from bins with high selection weights than from bins with low selection weights.
VIII. For each bin index (x=0 to x=NB−1), pseudorandomly select NN[x] nets from bin B[x].
To provide additional explanation for Step VII, two possible selection distributions are illustrated in
After completing steps I-VIII as described above, all key-gate locations have been determined. The designer may then proceed with insertion of logic encryption circuitry.
The topological method described above that is used to select key-gate locations for logic encryption purposes is also usable to select camouflaged micro-circuit insertion points using circuit topology. The technique fix choosing insertion points for camouflaged micro-circuits is analogous to the technique for choosing key gate insertion points.
In block 1102, a set of first logical nodes (nodes between interconnected logic or memory elements) in a portion of the integrated circuit to be protected through the insertion of key-gates are identified. These logical nodes are accordingly identified as insertion points. This process can be performed using the techniques described above. In block 1102, for each logical node of the set of logical nodes of the identified first set of logical nodes, a key grate is inserted such that an output value of the key gated first logical node equals an output value of an un-key-gated logical first logical node only when a correct key data value is provided to a key input of the key-gate. An example of this technique is shown in
Next, programming logic 302 is inserted for programming key data signals to the key inputs from a non-volatile memory 304, as shown in block 1106 and illustrated in
In block 1202, the first logical node is disconnected from its load pins. For example, referring to
In block 1310 one of the terminal gates logical inputs are connected to the output 408 of the camouflaged micro circuit 402 (in the embodiment illustrated in
In one embodiment, the camouflaged micro-circuit 402 has an output value having a fixed logical value of zero and the terminal gate 406 performs a logical OR function. In another embodiment, the camouflaged micro-circuit 402 has an output value having a fixed logical value of one and the terminal gate 406 performs an AND function. Other combinations of gates may be used to achieve analogous results.
Generally, the computer 1402 operates under control of an operating system 1408 stored in the memory 1406, and interfaces with the user to accept inputs and commands and to present results through a graphical user interface (GUI) module 1418A. Although the GUI module 1418B is depicted as a separate module, the instructions performing the GUI functions can be resident or distributed in the operating system 1408, the computer program 1410, or implemented with special purpose memory and processors. The computer 1402 also implements a compiler 1412 which allows an application program 1410 written in a programming language such as COBOL, C++, FORTRAN, or other language to be translated into processor 1404 readable code. After completion, the application 1410 accesses and manipulates data stored in the memory 1406 of the computer 1402 using the relationships and logic that was generated using the compiler 1412. The computer 1402 also optionally comprises an external communication device such as a modem, satellite link, Ethernet card, or other device for communicating with other computers.
In one embodiment, instructions implementing the operating system 1408, the computer program 1410, and the compiler 1412 are tangibly embodied in a computer-readable medium, e.g., data storage device 1420, which could include one or more fixed or removable data storage devices, such as a zip drive, floppy disc drive 1424, hard drive, CD-ROM drive, tape drive, etc. Further, the operating system 1408 and the computer program 1410 are comprised of instructions which, when read and executed by the computer 1402, causes the computer 1402 to perform the operations herein described. Computer program 1410 and/or operating instructions may also be tangibly embodied in memory 1406 and/or data communications devices 1430, thereby making a computer program product or article of manufacture. As such, the terms “article of manufacture,” “program storage device” and “computer program product” as used herein are intended to encompass a computer program accessible from any computer readable device or media.
Those skilled in the art will recognize many modifications may be made to this configuration without departing from the scope of the present disclosure. For example, those skilled in the art will recognize that any combination of the above components, or any number of different components, peripherals, and other devices, may be used.
This concludes the description of the preferred embodiments of the present disclosure. The foregoing description of the preferred embodiment has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the disclosure to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. It is intended that the scope of rights be limited not by this detailed description, but rather by the claims appended hereto.
This application claims benefit of U.S. Provisional Patent Application No. 62/397,231, entitled “METHOD FOR OBFUSCATING AN INTEGRATED CIRCUIT WITH CAMOUFLAGED GATES AND LOGIC ENCRYPTION,” by Bryan J. Wang, Lap Wai Chow, Ronald P. Cocchi, and James P. Baukus, filed Sep. 20, 2016, which application is hereby incorporated by reference herein. This application is also related to the following co-pending and commonly assigned patent application(s), all of which applications are incorporated by reference herein: U.S. patent application Ser. No. 15/675,418, entitled “PHYSICALLY UNCLONABLE CAMOUFLAGE STRUCTURE AND METHODS FOR FABRICATING SAME,” by Ronald P. Cocchi, Lap Wai Chow, James P. Baukus, and Bryan J. Wang, filed Aug. 11, 2017; which application is a continuation of U.S. patent application Ser. No. 14/985,270, entitled “PHYSICALLY UNCLONABLE CAMOUFLAGE STRUCTURE AND METHODS FOR FABRICATING SAME,” by Ronald P. Cocchi, Lap W. Chow, James P. Baukus, and Bryan J. Wang, filed Dec. 30, 2015, issued Aug. 15, 2017 as U.S. Pat. No. 9,735,781, which application: Claims benefit of U.S. Provisional Patent Application No. 62/098,108, entitled “METHOD AND APPARATUS FOR BUILDING AN UNCLONABLE ELECTRONICS SYSTEM WITH CIRCUIT CAMOUFLAGE,” by Ronald P. Cocchi, Lap W. Chow, James P. Baukus, and Bryan Wang, filed Dec. 30, 2014, both of which application is hereby incorporated by reference herein. Is a continuation-in-part of U.S. patent application Ser. No. 13/940,585, entitled “METHOD AND APPARATUS FOR CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT WITH MICRO CIRCUITS AND POST PROCESSING,” by Bryan I. Wang, Lap Wai Chow, James P. Baukus, and Ronald P. Cocchi, filed Jul. 12, 2013, which application is a divisional of U.S. patent application Ser. No. 13/370,118, filed Feb. 9, 2012 and entitled “METHOD AND APPARATUS FOR CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT WITH MICRO CIRCUITS AND POST PROCESSING,” by Ronald P. Cocchi et al. and issued Aug. 13, 2013 as U.S. Pat. No. 8,510,700, which application is: a continuation-in-part of U.S. patent application Ser. No. 12/380,094, filed Feb. 24, 2009 and entitled “CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT,” by Lap Wai Chow, James P. Baukus, Bryan J. Wang, and Ronald P. Cocchi, issued Apr. 3, 2012 as U.S. Pat. No. 8,151,235; and a continuation-in-part of U.S. patent application Ser. No. 12/578,441 filed Oct. 13, 2009 entitled “METHOD AND APPARATUS FOR CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT,” by Lap Wai Chow, James P. Baukus, Bryan J. Wang, and Ronald P. Cocchi, issued Apr. 9, 2013 as U.S. Pat. No. 8,418,091, which is a continuation-in-part of U.S. patent application Ser. No. 12/380,094, filed Feb. 24, 2009 and entitled “CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT,” by Lap Wai Chow, James P. Baukus, Bryan J. Wang, and Ronald P. Cocchi, issued Apr. 3, 2012 as U.S. Pat. No 8,151,235; Is also a continuation-in-part of U.S. patent application Ser. No. 13/789,267, filed Mar. 7, 2013, entitled “METHOD AND APPARATUS FOR CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT,” by Lap Wai Chow, James P. Baukus, Bryan J. Wang, and Ronald P. Cocchi, which application is a continuation of U.S. patent application Ser. No. 12/578,441, filed Oct. 13, 2009, entitled “METHOD AND APPARATUS FOR CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT,” by Lap Wai Chow, James P. Baukus, Bryan J. Wang, and Ronald P. Cocchi and issued Apr. 9, 2013 as U.S. Pat. No. 8,4118,0911, which application is a continuation-in-part of U.S. patent application Ser. No. 12/380,094, filed Feb. 24, 2009, entitled “CAMOUFLAGING A STANDARD CELL BASED INTEGRATED CIRCUIT,” by Lap Wai Chow, James P. Baukus, Bryan J. Wang, and Ronald P. Cocchi, issued Apr. 3, 2012 as U.S. Pat. No. 8,151,235.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2017/052304 | 9/19/2017 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
62397231 | Sep 2016 | US |