Tamper resistant methods and apparatus
First Claim
1. An apparatus comprising:
- a storage medium having stored therein a plurality of obfuscated cells of programming instructions designed to self-verify whether execution of the plurality of obfuscated programming instructions is being observed, wherein the obfuscated cells are mutated through an inter-cell dependent mutation process; and
an execution unit coupled to the storage medium for executing the programming instructions.
1 Assignment
0 Petitions
Accused Products
Abstract
In one apparatus, a number of obfuscated programming instructions are equipped to self-verify whether execution of the obfuscated programming instructions is being observed. In another apparatus, a number of obfuscated programming instruction are equipped to determine whether the apparatus is being operated in a mode that supports single step execution of the obfuscated programming instructions. In yet another apparatus, a number of obfuscated programming instruction are equipped to verify whether an amount of elapsed execution time has exceeded a threshold. In yet another apparatus, a first and a second group of obfuscated programming instruction are provided to implement a first and a second tamper resistant technique respectively, with the first and the second group of programming instructions sharing a storage location for a first and a second key value corresponding to the first and the second tamper resistant technique.
256 Citations
32 Claims
-
1. An apparatus comprising:
-
a storage medium having stored therein a plurality of obfuscated cells of programming instructions designed to self-verify whether execution of the plurality of obfuscated programming instructions is being observed, wherein the obfuscated cells are mutated through an inter-cell dependent mutation process; and
an execution unit coupled to the storage medium for executing the programming instructions. - View Dependent Claims (2, 3, 4, 5, 6, 7)
-
-
8. A method comprising:
-
a) executing a plurality of obfuscated cells of programming instructions, wherein the obfuscated cells are mutated through an inter-cell dependent mutation process;
b) self-verifying by the plurality of obfuscated cells of programming instructions that the execution is not being observed; and
c) terminating said execution of (a) if (b) verified that the execution is being observed. - View Dependent Claims (9, 10, 11, 12, 13, 14)
-
-
15. An apparatus comprising:
-
a storage medium having stored therein a plurality of obfuscated cells of programming instructions designed to determine whether the apparatus is being operated in a mode that supports single step execution of the obfuscated cells of programming instructions, wherein the obfuscated cells are mutated through an intercell dependent mutation process; and
an execution unit coupled to the storage medium for executing the programming instructions. - View Dependent Claims (16)
-
-
17. A method comprising:
-
a) executing a plurality of obfuscated cells of programming instructions, wherein the obfuscated cells are mutated through an inter-cell dependent mutation process;
b) determining whether the obfuscated cells of programming instructions are being executed in a mode that supports single step execution; and
c) terminating said execution of (a) if (b) verified that the execution is being executed in a mode that supports single step execution. - View Dependent Claims (18)
-
-
19. An apparatus comprising:
-
a storage medium having stored therein a plurality of obfuscated cells of programming instructions designed to verify whether an amount of elapsed execution time has exceeded a threshold, wherein the obfuscated cells are mutated through an inter-cell dependent mutation process; and
an execution unit coupled to the storage medium for executing the programming instructions. - View Dependent Claims (20, 21, 22)
-
-
23. A method comprising:
-
a) executing a plurality of obfuscated cells of programming instructions, wherein the obfuscated cells are mutated through an inter-cell dependent mutation process;
b) verifying whether an amount of elapsed execution time has exceeded a threshold; and
c) terminating said execution of (a) if (b) verified that the execution is being observed. - View Dependent Claims (24, 25, 26)
-
-
27. An apparatus comprising:
-
a storage medium having stored therein a first and a second plurality of obfuscated cells of programming instructions designed to implement a first anti-observation tamper resistant technique and an observation detection tamper resistant technique respectively, with the first and the second plurality of obfuscated cells of programming instructions sharing a storage location for a first and a second key value corresponding to the first anti-observation and the observation detection tamper resistant techniques, wherein the obfuscated cells are mutated through an inter-cell dependent mutation process; and
an execution unit coupled to storage medium for executing the programming instructions. - View Dependent Claims (28, 29, 30)
-
-
31. A method comprising:
-
a) executing a first plurality of obfuscated cells of programming instructions to implement a first anti-observation tamper resistant technique, including storing a first key value corresponding to the first anti-observation tamper resistant technique in a shared storage location, wherein the obfuscated cells are mutated through an intercell dependent mutation process; and
b) executing a second plurality of obfuscated cells of programming instructions to implement an observation detection tamper resistant technique, including storing a second key value corresponding to the observation detection tamper resistant technique in the same shared storage location. - View Dependent Claims (32)
-
Specification