This invention relates in general to the field of programming, and more particularly to using a high level programming language with a smart card or a microcontroller.
Software applications written in the Java high-level programming language have been so designed that an application written in Java can be run on many different computer brands or computer platforms without change. This is accomplished by the following procedure. When a Java application is written, it is compiled into “Class” files containing byte codes that are instructions for a hypothetical computer called a Java Virtual Machine. An implementation of this virtual machine is written for each platform that is supported. When a user wishes to run a particular Java application on a selected platform, the class files compiled from the desired application is loaded onto the selected platform. The Java virtual machine for the selected platform is run, and interprets the byte codes in the class file, thus effectively running the Java application.
Java is described in the following references which are hereby incorporated by reference: (1) Arnold, Ken, and James Gosling, “The Java Programming Language,” Addison-Wesley, 1996; (2) James Gosling, Bill Joy, and Guy Steele, “The Java Language Specification,” Sun Microsystems, 1996, (web site: http://java.sun.com/doc/language_specification); (3) James Gosling and Henry McGilton, “The Java Language Environment: A White Paper,” Sun Microsystems, 1995 (web site: http://java.sun.com/doc/language_environment/); and (4) Tim Lindholm and Frank Yellin, “The Java Virtual Machine Specification,” Addison-Wesley, 1997. These texts among many others describe how to program using Java.
In order for a Java application to run on a specific platform, a Java virtual machine implementation must be written that will run within the constraints of the platform, and a mechanism must be provided for loading the desired Java application on the platform, again keeping within the constraints of this platform.
Conventional platforms that support Java are typically microprocessor-based computers, with access to relatively large amounts of memory and hard disk storage space. Such microprocessor implementations frequently are used in desktop and personal computers. However, there are no conventional Java implementations on microcontrollers, as would typically be used in a smart card.
Microcontrollers differ from microprocessors in many ways. For example, a microprocessor typically has a central processing unit that requires certain external components (e.g., memory, input controls and output controls) to function properly. A typical microprocessor can access from a megabyte to a gigabyte of memory, and is capable of processing 16, 32, or 64 bits of information or more with a single instruction. In contrast to the microprocessor, a microcontroller includes a central processing unit, memory and other functional elements, all on a single semiconductor substrate, or integrated circuit (e.g., a “chip”). As compared to the relatively large external memory accessed by the microprocessor, the typical microcontroller accesses a much smaller memory. A typical microcontroller can access one to sixty-four kilobytes of built-in memory, with sixteen kilobytes being very common.
There are generally three different types of memory used: random access memory (RAM), read only memory (ROM), and electrically erasable programmable read only memory (EEPROM). In a microcontroller, the amount of each kind of memory available is constrained by the amount of space on the integrated circuit used for each kind of memory. Typically, RAM takes the most space, and is in shortest supply. ROM takes the least space, and is abundant. EEPROM is more abundant than RAM, but less than ROM.
Each kind of memory is suitable for different purposes. Although ROM is the least expensive, it is suitable only for data that is unchanging, such as operating system code. EEPROM is useful for storing data that must be retained when power is removed, but is extremely slow to write. RAM can be written and read at high speed, but is expensive and data in RAM is lost when power is removed. A microprocessor system typically has relatively little ROM and EEPROM, and has 1 to 128 megabytes of RAM, since it is not constrained by what will fit on a single integrated circuit device, and often has access to an external disk memory system that serves as a large writable, non-volatile storage area at a lower cost than EEPROM. However, a microcontroller typically has a small RAM of 0.1 to 2.0 K, 2K to 8K of EEPROM, and 8K-56K of ROM.
Due to the small number of external components required and their small size, microcontrollers frequently are used in integrated circuit cards, such as smart cards. Such smart cards come in a variety of forms, including contact-based cards, which must be inserted into a reader to be used, and contactless cards, which need not be inserted. In fact, microcontrollers with contactless communication are often embedded into specialized forms, such as watches and rings, effectively integrating the functionality of a smart card in an ergonomically attractive manner.
Because of the constrained environment, applications for smart cards are typically written in a low level programming language (e.g., assembly language) to conserve memory.
The integrated circuit card is a secure, robust, tamper-resistant and portable device for storing data. The integrated circuit card is the most personal of personal computers because of its small size and because of the hardware and software data security features unique to the integrated circuit card.
The primary task of the integrated circuit card and the microcontroller on the card is to protect the data stored on the card. Consequently, since its invention in 1974, integrated circuit card technology has been closely guarded on these same security grounds. The cards were first used by French banks as debit cards. In this application, before a financial transaction based on the card is authorized, the card user must demonstrate knowledge of a 4-digit personal identification number (PIN) stored in the card in addition to being in possession of the card. Any information that might contribute to discovering the PIN number on a lost or stolen card was blocked from public distribution. In fact, since nobody could tell what information might be useful in this regard, virtually all information about integrated circuit cards was withheld.
Due to the concern for security, applications written for integrated circuit cards have unique properties. For example, each application typically is identified with a particular owner or identity. Because applications typically are written in a low-level programming language, such as assembly language, the applications are written for a particular type of microcontroller. Due to the nature of low level programming languages, unauthorized applications may access data on the integrated circuit card. Programs written for an integrated circuit card are identified with a particular identity so that if two identities want to perform the same programming function there must be two copies of some portions of the application on the microcontroller of the integrated circuit card.
Integrated circuit card systems have historically been closed systems. An integrated circuit card contained a dedicated application that was handcrafted to work with a specific terminal application. Security checking when an integrated circuit card was used consisted primarily of making sure that the card application and the terminal application were a matched pair and that the data on the card was valid.
As the popularity of integrated circuit cards grew, it became clear that integrated circuit card users would be averse to carrying a different integrated circuit card for each integrated circuit card application. Therefore, multiple cooperating applications began to be provided on single provider integrated circuit cards. Thus, for example, an automated teller machine (ATM) access card and a debit card may coexist on a single integrated circuit card platform. Nevertheless, this was still a closed system since all the applications in the terminal and the card were built by one provider having explicit knowledge of the other providers.
The paucity of information about integrated circuit cards—particularly information about how to communicate with them and how to program them—has impeded the general application of the integrated circuit card. However, the advent of public digital networking (e.g., the Internet and the World Wide Web) has opened new domains of application for integrated circuit cards. In particular, this has lead to a need to load new applications on the card that do not have explicit knowledge of the other providers, but without the possibility of compromising the security of the card. However, typically, this is not practical with conventional cards that are programmed using low level languages.
In general, in one aspect, the invention features an integrated circuit card for use with a terminal. The integrated circuit card includes a memory that stores an interpreter and an application that has a high level programming language format. A processor of the card is configured to use the interpreter to interpret the application for execution and to use a communicator of the card to communicate with the terminal.
Among the advantages of the invention are one or more of the following. New applications may be downloaded to a smart card without compromising the security of the smart card. These applications may be provided by different companies loaded at different times using different terminals. Security is not compromised since the applications are protected against unauthorized access of any application code or data by the security features provided by the Java virtual machine. Smart card applications can be created in high level languages such as Java and Eiffel, using powerful mainstream program development tools. New applications can be quickly prototyped and downloaded to a smart card in a matter of hours without resorting to soft masks. Embedded systems using microcontrollers can also gain many of these advantages for downloading new applications, high level program development, and rapid prototyping by making use of this invention.
Implementations of the invention may include one or more of the following. The high level programming language format of the application may have a class file format and may have a Java programming language format. The processor may be a microcontroller. At least a portion of the memory may be located in the processor.
The application may have been processed from a second application that has a string of characters, and the string of characters may be represented in the first application by an identifier (e.g., an integer).
The processor may be also configured to receive a request from a requester (e.g., a processor or a terminal) to access an element (e.g., an application stored in the memory, data stored in the memory or the communicator) of the card, after receipt of the request, interact with the requester to authenticate an identity of the requester, and based on the identity, selectively grant access to the element.
The memory may also store an access control list for the element. The access control list furnishes an indication of types of access to be granted to the identity, and based on the access control list, the processor selectively grants specific types of access (e.g., reading data, writing data, appending data, creating data, deleting data or executing an application) to the requester.
The application may be one of a several applications stored in the memory. The processor may be further configured to receive a request from a requester to access one of the plurality of applications; after receipt of the request, determine whether said one of the plurality of applications complies with a predetermined set of rules; and based on the determination, selectively grant access to the requester to said one of the plurality of applications. The predetermined rules provide a guide for determining whether said one of the plurality of applications accesses a predetermined region of the memory. The processor may be further configured to authenticate an identity of the requester and grant access to said one of the plurality of applications based on the identity.
The processor may be also configured to interact with the terminal via the communicator to authenticate an identity; determine if the identity has been authenticated; and based on the determination, selectively allow communication between the terminal and the integrated circuit card.
The communicator and the terminal may communicate via communication channels. The processor may also be configured to assign one of the communication channels to the identity when the processor allows the communication between the terminal and the integrated circuit card. The processor may also be configured to assign a session key to the assigned communication channel and use the session key when the processor and the terminal communicate via the assigned communication channel.
The terminal may have a card reader, and the communicator may include a contact for communicating with the card reader. The terminal may have a wireless communication device, and the communicator may include a wireless transceiver for communicating with the wireless communication device. The terminal may have a wireless communication device, and the communicator may include a wireless transmitter for communicating with the wireless communication device.
In general, in another aspect, the invention features a method for use with an integrated circuit card and a terminal. The method includes storing an interpreter and at least one application having a high level programming language format in a memory of the integrated circuit card. A processor of the integrated circuit card uses the interpreter to interpret the at least one application for execution, and the processor uses a communicator of the card when communicating between the processor and the terminal.
In general, in another aspect, the invention features a smart card. The smart card includes a memory that stores a Java interpreter and a processor that is configured to use the interpreter to interpret a Java application for execution.
In general, in another aspect, the invention features a microcontroller that has a semiconductor substrate and a memory located in the substrate. A programming language interpreter is stored in the memory and is configured to implement security checks. A central processing unit is located in the substrate and is coupled to the memory.
Implementations of the invention may include one or more of the following. The interpreter may be a Java byte code interpreter. The security checks may include establishing firewalls and may include enforcing a sandbox security model.
In general, in another aspect, the invention features a smart card that has a programming language interpreter stored in a memory of the card. The interpreter is configured to implement security check. A central processing unit of the card is coupled to the memory.
In general, in another aspect, the invention features an integrated circuit card that is used with a terminal. The card includes a communicator and a memory that stores an interpreter and first instructions of a first application. The first instructions have been converted from second instructions of a second application. The integrated circuit card includes a processor that is coupled to the memory and is configured to use the interpreter to execute the first instructions and to communicate with the terminal via the communicator.
Implementations of the invention may include one or more of the following. The first and/or second applications may have class file format(s). The first and/or second applications may include byte codes, such as Java byte codes. The first instructions may be generalized or renumbered versions of the second instructions. The second instructions may include constant references, and the first instructions may include constants that replace the constant references of the second instructions. The second instructions may include references, and the references may shift location during the conversion of the second instructions to the first instructions. The first instructions may be relinked to the references after the shifting. The first instructions may include byte codes for a first type of virtual machine, and the second instructions may include byte codes for a second type of virtual machine. The first type is different from the second type.
In general, in another aspect, the invention features a method for use with an integrated circuit card. The method includes converting second instructions of a second application to first instructions of a first application; storing the first instructions in a memory of the integrated circuit card; and using an interpreter of the integrated circuit card to execute the first instructions.
In general, in another aspect, the invention features an integrated circuit for use with a terminal. The integrated circuit card has a communicator that is configured to communicate with the terminal and a memory that stores a first application that has been processed from a second application having a string of characters. The string of characters are represented in the first application by an identifier. The integrated circuit card includes a processor that is coupled to the memory. The processor is configured to use the interpreter to interpret the first application for execution and to use the communicator to communicate with the terminal.
In general, in another aspect, the invention features a method for use with an integrated circuit card and a terminal. The method includes processing a second application to create a first application. The second application has a string of characters. The string of characters is represented by an identifier in the second application. An interpreter and the first application are stored in a memory of the integrated circuit card. A processor uses an interpreter to interpret the first application for execution.
In general, in another aspect, the invention features a microcontroller that includes a memory which stores an application and an interpreter. The application has a class file format. A processor of the microcontroller is coupled to the memory and is configured to use the interpreter to interpret the application for execution.
In implementations of the invention, the microcontroller may also include a communicator that is configured to communicate with a terminal.
In general, in another aspect, the invention features a method for use with an integrated circuit card. The method includes storing a first application in a memory of the integrated circuit card, storing a second application in the memory of the integrated circuit card, and creating a firewall that isolates the first and second applications so that the second application cannot access either the first application or data associated with the first application.
In general, in another aspect, the invention features an integrated circuit card for use with a terminal. The integrated circuit card includes a communicator that is configured to communicate with the terminal, a memory and a processor. The memory stores applications, and each application has a high level programming language format. The memory also stores an interpreter. The processor is coupled to the memory and is configured to: a.) use the interpreter to interpret the applications for execution, b.) use the interpreter to create a firewall to isolate the applications from each other, and c.) use the communicator to communicate with the terminal.
Other advantages and features will become apparent from the following description and from the claims.
Referring to
In some embodiments, the microcontroller, memory and communicator are embedded in a plastic card that has substantially the same dimensions as a typical credit card. In other embodiments, the microcontroller, memory and communicator are mounted within bases other than a plastic card, such as jewelry (e.g., watches, rings or bracelets), automotive equipment, telecommunication equipment (e.g., subscriber identity module (SIM) cards), security devices (e.g., cryptographic modules) and appliances.
The terminal 14 prepares and downloads Java applications to the integrated circuit card 10 using the terminal communicator 12b. The terminal communicator 12b is a communications device capable of establishing a communications channel between the integrated circuit card 10 and the terminal 14. Some communication options include contact card readers, wireless communications via radio frequency or infrared techniques, serial communication protocols, packet communication protocols, ISO 7816 communication protocol, to name a few.
The terminal 14 can also interact with applications running in the integrated circuit card 10. In some cases, different terminals may be used for these purposes. For example, one kind of terminal may be used to prepare applications, different terminals could be used to download the applications, and yet other terminals could be used to run the various applications. Terminals can be automated teller machines (ATMs), point-of-sale terminals, door security systems, toll payment systems, access control systems, or any other system that communicates with an integrated circuit card or microcontroller.
The integrated circuit card 10 contains a card Java virtual machine (Card JVM) 16, which is used to interpret applications which are contained on the card 10.
Referring to
Referring to
In some embodiments, in order for the string to ID mapping to be consistent with a previously generated card class file (in the case where multiple class files reference the same strings), the card class file converter 26 can accept previously defined string to ID mappings from a string to ID input map file 30. In the absence of such a file, the IDs are generated by the card class file converter 26. Appendix B, which is hereby incorporated by reference, describes one possible way of implementing and producing the string to ID input map file 30 and string to ID output map file 32 and illustrates this mapping via an example.
Referring to
To avoid dynamic linking in the card, all the information that is distributed across several Java class files 24a, 24b, and 24c that form the application 24, are coalesced into one card class file 27 by the process shown in the flowchart in
Next, the card class file converter 26 checks for unsupported features 51c in the Code attribute of the input Java class file 24a. The Card JVM 16 only supports a subset of the full Java byte codes as described in Appendix C, which is hereby incorporated by reference. Hence, the card class file converter 26 checks for unsupported byte codes in the Code attribute of the Java class file 24a. If any unsupported byte codes are found 52, the card class file converter flags an error and stops conversion 53. The program code fragment marked “A” in APPENDIX D shows how these spurious byte codes are apprehended. Another level of checking can be performed by requiring the standard Java development environment 22 to compile the application 20 with a ‘-g’ flag. Based on the aforementioned Java virtual machine specification, this option requires the Java compiler to place information about the variables used in a Java application 20 in the LocalVariableTable attribute of the class file 24a. The card class file converter 26 uses this information to check if the Java class file 24a references data types not supported by the Java card.
Next, the card class file converter 26 discards all the unnecessary parts 51c of the Java class file 24a not required for interpretation. A Java class file 24a stores information pertaining to the byte codes in the class file in the Attributes section 44 of the Java class file. Attributes that are not required for interpretation by the card JVM 16, such as SourceFile, ConstantValue, Exceptions, LineNumberTable, and LocalvariableTable may be safely discarded 45. The only attribute that is retained is the Code attribute. The Code attribute contains the byte codes that correspond to the methods in the Java class file 24a.
Modifying the byte codes 54 involves examining the Code attribute information 44 for each method in the class file, and modifying the operands of byte codes that refer to entries in the Java class file constant pool 42 to reflect the entries in the card class file constant pool 47. In some embodiments, the byte codes are also modified, as described below.
Modifying the byte codes 54 involves five passes (with two optional passes) as described by the flowchart in
Once the jumps are recorded, if the optional byte code translation is not being performed 62, the card class file converter 26 may proceed to the third pass 64.
Otherwise, the card class file converter converts specific byte codes into generic byte codes. Typically, the translated byte codes are not interpreted in the Card JVM 16 but are supported by converting the byte codes into equivalent byte codes that can be interpreted by the Card JVM 16 (see
In the third pass 64, the card class file converter rebuilds constant references via elimination of the strings used to denote these constants.
Once the constant references are relinked, if the optional byte code modification is not being performed, the card class file converter may proceed to the fifth and final pass 67.
Otherwise, the card class file converter modifies the original byte codes into a different set of byte codes supported by the particular Card JVM 16 being used. One potential modification renumbers the original byte codes 60 into Card JVM 16 byte codes (see
In some embodiments, the card class file converter modifies the original byte codes 60 into a different set of byte codes designed for a different virtual machine architecture, as shown in
Since the previous steps 63, 64 or 66 may have changed the size of the byte codes 60 the card class file converter 26 has to relink 67 any jumps which have been effected.
Since the jumps were recorded in the first step 61 of the card class file converter 26, this adjustment is carried out by fixing the jump destinations to their appropriate values. The program code fragment marked “F” in Appendix D shows how these jumps are fixed.
The card class file converter now has modified byte codes 68 that is equivalent to the original byte codes 60 ready for loading. The translation from the Java class file 24a to the card class file 27 is now complete.
Referring back to
Referring to
Referring to
The selected Java card application 126z communicates with an appropriate application in the terminal 14 using the communicator 12a to establish a communication channel to the terminal 14. Data from the communicator 12a to the terminal 14 passes through a communicator driver 132 in the terminal, which is specifically written to handle the communications protocol used by the communicator 12a. The data then passes to an integrated circuit card driver 134, which is specifically written to address the capabilities of the particular integrated circuit card 10 being used, and provides high level software services to the terminal application 136. In the preferred embodiment, this driver would be appropriate PC/SC Smartcard Service Provider (SSP) software. The data then passes to the terminal application 136, which must handle the capabilities provided by the particular card application 126z being run. In this manner, commands and responses pass back and forth between the terminal application 136 and the selected card application 126z. The terminal application interacts with the user, receiving commands from the user, some of which are passed to the selected Java card application 126z, and receiving responses from the Java card application 126z, which are processed and passed back to the user.
Referring to
All of the heap manipulated by the Card JVM 16 may be stored in the Card RAM 141 as a RAM Heap 144c, or it may be distributed across to the Card EEPROM 142 as a EEPROM Heap 146a. Card RAM 141 is also used for recording the state of the system stack 148 that is used by routines written in the native code of the microcontroller. The Card JVM 16 uses the Card EEPROM 142 to store application data either in the EEPROM heap 146a or in the file system 147. Application data stored in a file may be manipulated via an interface to the card operating system 122. This interface is provided by a class library 140b stored in Card ROM 140, by a loadable class library 141c stored in Card EEPROM 142. One such interface is described in Appendix F. Applications and data in the card are isolated by a firewall mechanism 149.
To cope with the limited resources available on microcontrollers, the Card JVM 16 implements a strict subset of the Java programming language. Consequently, a Java application 20 compiles into a class file that contains a strict subset of Java byte codes. This enables application programmers to program in this strict subset of Java and still maintain compatibility with existing Java Virtual Machines. The semantics of the Java byte codes interpreted by the Card JVM 16 are described in the aforementioned Java Virtual Machine Specification. The subset of byte codes interpreted by the Card JVM 16 can be found in Appendix C. The card class file converter 26 checks the Java application 20 to ensure use of only the features available in this subset and converts into a form that is understood and interpreted by the Card JVM 16.
In other embodiments, the Card JVM 16 is designed to interpret a different set or augmented set of byte codes 116. Although a different byte code set might lead to some performance improvements, departing from a strict Java subset may not be desirable from the point of view of security that is present in the original Java byte codes or compatibility with mainstream Java development tools.
All Card JVM 16 applications 126 have a defined entry point denoted by a class and a method in the class. This entry point is mapped in the string to ID input map 30 and assigned by the card class file converter 26. Classes, methods and fields within a Java application 20 are assigned IDs by the card class file converter 26. For example, the ID corresponding to the main application class may be defined as F001 and the ID corresponding to its main method, such as “main( )V” could be defined as F002.
The overall execution architecture of the Card JVM is described by the flowchart in
An essential part of the Card JVM 16 is a subroutine that handles the execution of the byte codes. This subroutine is described by the flowchart in
Next, the method flags are checked 162. If the method is flagged native, then the method is actually a call to native method code (subroutine written in the microcontroller's native processor code). In this case, the Card JVM 16 prepares for an efficient call 163 and return to the native code subroutine. The parameters to the native method may be passed on the VM stack 144a or via the System stack 148. The appropriate security checks are made and the native method subroutine is called. On return, the result (if any) of the native method subroutine is placed on the VM stack 144a so that it may be accessed by the next byte code to be executed.
The dispatch loop 164 of the Card JVM 16 is then entered. The byte code dispatch loop is responsible for preparing, executing, and retiring each byte code. The loop terminates when it finishes interpreting the byte codes in the method 160, or when the Card JVM 16 encounters a resource limitation or a security violation.
If a previous byte code caused a branch to be taken 165 the Card JVM prepares for the branch 165a. The next byte code is retrieved 165b. In order to keep the cost of processing each byte code down, as many common elements such as the byte code arguments, length, type are extracted and stored.
To provide the security offered by the security model of the programming language, byte codes in the class file must be verified and determined conformant to this model. These checks are typically carried out in prior art by a program referred to as the byte code verifier, which operates in four passes as described in the Java Virtual Machine Specification. To offer the run-time security that is guaranteed by the byte code verifier, the Card JVM 16 must perform the checks that pertain to the Pass 3 and Pass 4 of the verifier. This checking can be bypassed by the Card JVM 16 if it can be guaranteed (which is almost impossible to do) that the byte codes 60 interpreted by the Card JVM 16 are secure. At the minimum, code security can be maintained as long as object references cannot be faked and the VM stack 144a and local variable bounds are observed. This requires checking the state of the VM stack 144a with respect to the byte code being executed.
To enforce the security model of the programming language, a 256-byte table is created as shown in Appendix G which is hereby incorporated by reference. This table is indexed by the byte code number. This table contains the type and length information associated with the indexing byte code. It is encoded with the first 5 bits representing type, and the last 3 bits representing length. The type and length of the byte code is indexed directly from the table by the byte code number. This type and length is then used for checking as shown in Appendix H which is hereby incorporated by reference. In Appendix H, the checking process begins by decoding the length and type from the table in Appendix G which is hereby incorporated by reference. The length is used to increment the program counter. The type is used first for pre-execution checking, to insure that the data types on the VM stack 144a are correct for the byte code that is about to be executed. The 256 bytes of ROM for table storage allows the original Java byte codes to be run in the Card JVM 16 and minimizes the changes required to the Java class file to be loaded in the card. Additional Java byte codes can be easily supported since it is relatively easy to update the appropriate table entries.
In other embodiments, as shown in
In another embodiment, the Card JVM 16 chooses not to perform any security checks in favor of Card JVM 16 execution speed. This is illustrated in the flowchart in
The Card JVM 16 may enforce other security checks as well. If the byte code may reference a local variable, the Card JVM 16 checks if this reference is valid, throwing an error if it is not. If the reference is valid, the Card JVM 16 stores the type of the local variable for future checking. The VM stack 144a pointer is checked to see if it is still in a valid range. If not an exception is thrown. The byte code number is checked. If it is not supported, an exception is thrown.
Finally, the byte code itself is dispatched 165d. The byte codes translated by the Card JVM 16 are listed in Appendix C. The semantics of the byte codes are described in the aforementioned Java Virtual Machine Specification with regard to the state of the VM stack 144a before and after the dispatch of the byte code. Note also that some byte codes (the byte codes, INVOKESTATIC, INVOKESPECIAL, INVOKENONVIRTUAL and INVOKEVIRTUAL) may cause reentry into the Card JVM 16, requiring processing to begin at the entry of the subroutine 161.
After execution, the type of the result is used to set the VM stack 144a state correctly 165e, properly flagging the data types on the VM stack 144a. The byte code information gathered previously 165b from the byte code info table is used to set the state of the VM stack 144a in accordance with the byte code that just executed.
In other embodiments, setting the output state of the VM stack 144a with respect to the byte code executed is simplified if the byte code is renumbered. This is shown in Appendix I which is hereby incorporated by reference.
In yet another embodiment, the Card JVM 16 may bypass setting the output state of the VM stack 144a in favor of Card JVM 16 execution speed. This option is not desirable from the point of view of security, unless it can be guaranteed that the byte codes are secure.
After the byte code has been executed, the byte code is retired 165f. This involves popping arguments off the VM stack 144a. Once byte code processing is completed, the loop 164 is repeated for the next byte code for the method.
Once the dispatch loop 164 terminates, the VM stack 144a is emptied 166. This prevents any object references filtering down to other Card JVM 16 invocations and breaking the Card JVM's 16 security. Termination 167 of the byte code dispatch loop 164 indicates that the Card JVM 16 has completed executing the requested method.
To isolate data and applications in the integrated circuit card 10 from each other, the integrated circuit card 10 relies on the firewall mechanism 149 provided by the Card JVM 16. Because the Card JVM implements the standard pass 3 and pass 4 verifier checks, it detects any attempt by an application to reference the data or code space used by another application, and flag a security error 156. For example, conventional low level applications can cast non-reference data types into references, thereby enabling access to unauthorized memory space, and violating security. With this invention, such an attempt by a card application 126z to use a non-reference data type as a reference will trigger a security violation 156. In conventional Java, this protected application environment is referred to as the sandbox application-interpretation environment.
However, these firewall facilities do not work independently. In fact, the facilities are overlapping and mutually reinforcing with conventional access control lists and encryption mechanisms shown in the following table:
Taken together, these facilities isolate both data and applications on the integrated circuit card 10 and ensure that each card application 126 can access only the authorized resources of the integrated circuit card 10.
Referring to
The integrated circuit card 10 uses cryptographic identification verification methods to associate an identity 190 (e.g., identities 190a, 190b and 190c) and hence, a set of privileges to the execution of the card application 126. The association of the specific identity 190c to the card application 126z is made when the card application 126z begins execution, thus creating a specific running application 200, as shown in
Referring to
One way to demonstrate possession of an encryption key is simply to expose the key itself. PIN verification is an example of this form of authentication. Another way to demonstrate the possession of an encryption key without actually exposing the key itself is to show the ability to encrypt or decrypt plain text with the key.
Thus, a specific running application 200 on the integrated circuit card 10 includes a card application 126z plus an authenticated identity 190c. No card application 126 can be run without both of these elements being in place. The card application 126z defines data processing operations to be performed, and the authenticated identity 190c determines on what computational objects those operations may be performed. For example, a specific application 126z can only access identity C's files 202 in the file system 147 associated with the specific identity 190c, and the specific card application 126z cannot access other files 204 that are associated with identities other than the specific identity 190c.
The integrated circuit card 10 may take additional steps to ensure application and data isolation. The integrated circuit card 10 furnishes three software features sets: authenticated-identity access control lists; a Java-based virtual machine; and one-time session encryption keys to protect data files, application execution, and communication channels, respectively. Collectively, for one embodiment, these features sets provide the application data firewalls 149 for one embodiment. The following discusses each software feature set and then shows how the three sets work together to insure application and data isolation on the integrated circuit card 10.
An access control list (ACL) is associated with every computational object (e.g., a data file or a communication channel) on the integrated circuit card 10 that is be protected, i.e., to which access is to be controlled. An entry on an ACL (for a particular computational object) is in a data format referred to as an e-tuple:
type:identity:permissions
The type field indicates the type of the following identity (in the identity field), e.g., a user (e.g., “John Smith”), or a group. The permissions field indicates a list of operations (e.g., read, append and update) that can be performed by the identity on the computational object.
As an example, for a data file that has the ACL entry:
USER:AcmeAirlines:RAU,
any application whose identity is “AcmeAirlines” can read (“R”), append (“A”) and update (“U”) the data file. In addition, the ACL may be used selectively to permit the creation and deletion of data files. Furthermore, the ACL may be used selectively to permit execution of an application.
Whenever a computational object is accessed by a running application 200, the access is intercepted by the Card JVM 16 and passed to the card operating system 122, which determines if there is an ACL associated with the object. If there is an associated ACL, then the identity 190c associated with the running application 200 is matched on the ACL. If the identity is not found or if the identity is not permitted for the type of access that is being requested, then the access is denied. Otherwise, the access is allowed to proceed.
Referring to
Encryption and decryption of card/terminal traffic can be handled either by the card operating system 122 or by the card application itself 126z. In the former case, the communication with the terminal 14 is being encrypted transparently to the application, and message traffic arrives decrypted in the data space of the application. In the latter case, the card application 126z elects to perform encryption and decryption to provide an extra layer of security since the application could encrypt data as soon as it was created and would decrypt data only when it was about to be used. Otherwise, the data would remain encrypted with the session key 209.
Thus, the application firewall includes three mutually reinforcing software sets. Data files are protected by authenticated-identity access control lists. Application execution spaces are protected by the Card JVM 16. Communication channels are protected with one-time session encryption keys 209.
In other embodiments, the above-described techniques are used with a microcontroller (such as the processor 12) may control devices (e.g., part of an automobile engine) other than an integrated circuit card. In these applications, the microcontroller provides a small platform (i.e., a central processing unit, and a memory, both of which are located on a semiconductor substrate) for storing and executing high level programming languages. Most existing devices and new designs that utilize a microcontroller could use this invention to provide the ability to program the microcontroller using a high level language, and application of this invention to such devices is specifically included.
The term application includes any program, such as Java applications, Java applets, Java aglets, Java servlets, Java commlets, Java components, and other non-Java programs that can result in class files as described below.
Class files may have a source other than Java program files. Several programming languages other than Java also have compilers or assemblers for generating class files from their respective source files. For example, the programming language Eiffel can be used to generate class files using Pirmin Kalberer's “J-Eiffel”, an Eiffel compiler with JVM byte code generation (web site: http://www.spin.ch/.about.kalberer/jive/index.htm). An Ada 95 to Java byte code translator is described in the following reference (incorporated herein by reference): Taft, S. Tucker, “Programming the Internet in Ada 95”, proceedings of Ada Europe '96, 1996. Jasmin is a Java byte code assembler that can be used to generate class files, as described in the following reference (incorporated herein by reference): Meyer, Jon and Troy Downing, “Java Virtual Machine”, O'Reilly, 1997. Regardless of the source of the class files, the above description applies to languages other than Java to generate codes to be interpreted.
In other embodiments, a microcontroller 210 is mounted into a mobile or fixed telephone 220, effectively adding smart card capabilities to the telephone, as shown in
In other embodiments, a microcontroller 210 is added to a key ring 230 as shown in
Jewelry such as a watch or ring 240 can also house a microcontroller 210 in an ergonomic manner, as shown in
While specific embodiments of the present invention have been described, various modifications and substitutions will become apparent to one skilled in the art by this disclosure. Such modifications and substitutions are within the scope of the present invention, and are intended to be covered by the appended claims.
This application is a continuation application, under 35 U.S.C. §120, of application Ser. No. 11/537,156, filed Sep. 29, 2006, now U.S. Pat. No. 7,818,727, which is a continuation application of application Ser. No. 10/037,390, filed Oct. 23, 2001, now U.S. Pat. No. 7,117,485, which is a continuation of application Ser. No. 08/957,512, filed Oct. 24, 1997, now U.S. Pat. No. 6,308,317, and which, under 35 U.S.C. §119(e), claims benefit of prior U.S. provisional application Ser. No. 60/029,057, filed Oct. 25, 1996. The entire disclosures of these prior applications are incorporated herein in their entireties by reference. A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
Number | Name | Date | Kind |
---|---|---|---|
4256955 | Giraud et al. | Mar 1981 | A |
4650975 | Kitchener | Mar 1987 | A |
4667290 | Goss et al. | May 1987 | A |
4777355 | Takahira | Oct 1988 | A |
4791558 | Chaitin et al. | Dec 1988 | A |
4797543 | Watanabe | Jan 1989 | A |
4874935 | Younger | Oct 1989 | A |
4877947 | Mori | Oct 1989 | A |
4905138 | Bourne | Feb 1990 | A |
4928001 | Masada | May 1990 | A |
5014312 | Lisimaque et al. | May 1991 | A |
5064999 | Okamoto et al. | Nov 1991 | A |
5133072 | Buzbee | Jul 1992 | A |
5195130 | Weiss et al. | Mar 1993 | A |
5210876 | Uchida | May 1993 | A |
5307492 | Benson | Apr 1994 | A |
5367685 | Gosling | Nov 1994 | A |
5406380 | Teter | Apr 1995 | A |
5450575 | Sites | Sep 1995 | A |
5457799 | Srivastava | Oct 1995 | A |
5469572 | Taylor | Nov 1995 | A |
5500517 | Cagliostro | Mar 1996 | A |
5519866 | Lawrence et al. | May 1996 | A |
5537474 | Brown et al. | Jul 1996 | A |
5544086 | Davis et al. | Aug 1996 | A |
5550919 | Kowalski | Aug 1996 | A |
5551015 | Goettelmann et al. | Aug 1996 | A |
5590197 | Chen et al. | Dec 1996 | A |
5590331 | Lewis et al. | Dec 1996 | A |
5604802 | Holloway | Feb 1997 | A |
5613012 | Hoffman et al. | Mar 1997 | A |
5613120 | Palay et al. | Mar 1997 | A |
5650761 | Gomm et al. | Jul 1997 | A |
5663553 | Aucsmith | Sep 1997 | A |
5668999 | Gosling | Sep 1997 | A |
5675804 | Sidik et al. | Oct 1997 | A |
5679945 | Renner et al. | Oct 1997 | A |
5689565 | Spies et al. | Nov 1997 | A |
5692132 | Hogan | Nov 1997 | A |
5734150 | Brown et al. | Mar 1998 | A |
5742756 | Dillaway et al. | Apr 1998 | A |
5748964 | Gosling | May 1998 | A |
5761306 | Lewis | Jun 1998 | A |
5764989 | Gustafsson et al. | Jun 1998 | A |
5768419 | Gundlach et al. | Jun 1998 | A |
5794049 | Lindholm | Aug 1998 | A |
5799138 | Yoshida | Aug 1998 | A |
5811771 | Dethloff | Sep 1998 | A |
5815657 | Williams et al. | Sep 1998 | A |
5826088 | Sitbon et al. | Oct 1998 | A |
5835772 | Thurlo | Nov 1998 | A |
5841866 | Bruwer et al. | Nov 1998 | A |
5844218 | Kawan et al. | Dec 1998 | A |
5848274 | Hamby et al. | Dec 1998 | A |
5860008 | Bradley | Jan 1999 | A |
5889941 | Tushie et al. | Mar 1999 | A |
5896530 | White | Apr 1999 | A |
5905895 | Halter | May 1999 | A |
5912453 | Gungl | Jun 1999 | A |
5915226 | Martineau | Jun 1999 | A |
5923884 | Peyret et al. | Jul 1999 | A |
5940516 | Mason et al. | Aug 1999 | A |
5946487 | Dangelo | Aug 1999 | A |
5956716 | Kenner et al. | Sep 1999 | A |
5963980 | Coulier et al. | Oct 1999 | A |
5966536 | Ravichandran | Oct 1999 | A |
5987256 | Wu et al. | Nov 1999 | A |
6061520 | Yellin et al. | May 2000 | A |
6075863 | Krishnan et al. | Jun 2000 | A |
6078744 | Wolczko et al. | Jun 2000 | A |
6094528 | Jordan | Jul 2000 | A |
6151703 | Crelier | Nov 2000 | A |
6223984 | Renner et al. | May 2001 | B1 |
6226789 | Tye et al. | May 2001 | B1 |
6233733 | Ghosh | May 2001 | B1 |
6438573 | Nilsen | Aug 2002 | B1 |
6526565 | Nally | Feb 2003 | B1 |
6535903 | Yates et al. | Mar 2003 | B2 |
20050097550 | Schwab et al. | May 2005 | A1 |
20080282238 | Meijer et al. | Nov 2008 | A1 |
Number | Date | Country |
---|---|---|
0427465 | May 1991 | EP |
0718760 | Jun 1996 | EP |
0829828 | Mar 1998 | EP |
0889393 | Jan 1999 | EP |
2667171 | Mar 1992 | FR |
2191029 | Dec 1987 | GB |
2261973 | Jun 1993 | GB |
204741 | Sep 1986 | JP |
63156254 | Jun 1988 | JP |
63156255 | Jun 1988 | JP |
WO9504328 | Feb 1995 | WO |
WO9504328 | Feb 1995 | WO |
WO9625724 | Aug 1996 | WO |
WO9720281 | Jun 1997 | WO |
WO9750063 | Dec 1997 | WO |
9819237 | May 1998 | WO |
Entry |
---|
Defendant Google Inc.'s Answer to Plaintiff's Complaint for Patent Infringement and Counterclaims, Gemalto V. HTC, Civil Action No. 6:10-cv-561(LED) (E.D.Tex. Feb. 25, 2011). |
HTC Defendants' Answer to Plaintiff's Complaint for Patent Infringement and Counterclaims, Gemalto V. HTC, Civil Action No. 6:10-cv-561(LED) (E.D.Tex. Feb. 25, 2011). |
Amended Complaint for Patent Infringement, Gemalto V. HTC, Civil Action No. 6:10-cv-561(LED) (E.D.Tex. Jan. 26, 2011). |
Samsung Electronics Co., Ltd and Samsung Telecommunications America LLC's Answer to Plaintiff's Amended Complaint for Patent Infringement, Gemalto V. HTC, Civil Action No. 6:10-cv-561(LED) (E.D.Tex. Feb. 25, 2011). |
Motorola Mobility's Answer to Plaintiff's Amended Complaint for Patent Infringement and Counterclaims, Gemalto V. HTC, Civil Action No. 6:10-cv-561(LED) (E.D.Tex. Feb. 25, 2011). |
Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Exhibit A of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-1 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-2 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-3 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-4 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-5 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-6 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-7 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-8 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-9 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-10 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-11 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-12 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-13 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-14 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-15 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-16 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-17 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-18 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-19 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-20 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-21 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-22 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-23 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-24 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-25 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-26 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-27 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-28 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-29 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-30 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-31 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-32 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-33 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-34 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-35 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-36 of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Exhibit B of: Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 31, 2011 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Michal Cierniak, et al., Briki: a Fexible Java Compiler, Technical Report 621, May 1996, Department of Computer Science, University of Rochester, Rochester, NY. |
Michal Cierniak, et al., Briki: an Optimizing Java Compiler, 1997, IEEE, p. 179-184. |
Adl-Tabatabai, Ali-Reza, et al., Efficient and Language-Independent Mobile Programs, Extended Abstract, School of Computer Science, Carnegie Mellon University, Pittsburgh, PA., Oct. 22, 1995. |
Lucco, et al., Colusa Software White Paper, Omniware: A Universal Substrate for Mobile Code, 1995. |
Steven Lucco, et al., Omniware: A Universal Substrate for Web Programming, 1995. |
Walter R. Smith, The Newton Application Architecture, Proceedings of the 39th IEEE Computer Society International Conference, pp. 156-161, San Francisco, 1994. |
Jonathan C. Hardwick, et al., Java as an Intermediate Language, Aug. 12, 1996, School of Computer Science, Carnegie Mellon University, Pittsburgh, PA. |
Pierre Paradinas, et al., A Personal and Portable Database Server: the CQL Card, Lecture Notes in Computer Science (Applications of Databases), 1994, vol. 819, pp. 444-457. |
Pieter H. Hartel, et al., Towards testability in smart card operating system design, CARDIS 94, Lille, France, 1994, p. 1-16. |
Olivier Caron, et al., New architectures for smart cards: the OCEAN approach, IEEE, 1994, p. 148-155. |
Brian T. Lewis, et al., Clarity MCode: A Retargetable Intermediate Representation for Compilation, ACM, May 1995, p. 119-128. |
Jack W. Davidson, et al., Cint: A RISC Interpreter for the C Programming Language, 1987, p. 189-198, Association for Computing Machinery. |
Richard P. Gabriel, Performance and Evaluation of Lisp Systems, The MIT Press in their Computer System Series. (ISBN 0-262-07093-6), Aug. 14, 1985, whole document, The Massachusetts Institute of Technology, Cambridge, Massachusetts. |
David Gries, Compiler Construction for Digital Computers, 1971, John Wiley & Sons, Inc., Toronto, Canada. |
General Magic, Inc., Telescript Language Reference, Oct. 1995., Sunnyvale, CA. |
General Magic, Inc., Telescript Programming Guide V0.5, Oct. 19, 1995, Sunnyvale, CA. |
Gregory John Michaelson, Interpreter prototypers from formal language definitions, Apr. 1993, Thesis submitted for the degree of Doctor of Philosophy, Heriot-Watt University, Edinburgh, Scotland. |
J. Bradley Chen, et al., Morph: A Framework for Platform-Specific Optimization, Technical Report 04-96, Center for Research in Computing Technology, Harvard University, Cambridge, MA, Mar. 12, 1996. |
Scott Draves, Compiler Generation for Interactive Graphics using Intermediate Code, Lecture Notes in Computer Science, vol. 1110/1996, 1996. |
Frederick Colville Knabe, Language Support for Mobile Agents, CMU-CS-95-223, School of Computer Science Carnegie Mellon University, Pittsburgh, PA 15213, Submitted in partial fulfillment of the requirements for the degree of Doctor of Philosophy, Dec. 1995. |
Henry M. Wu, Scheme86 An Architecture for Microcoding a Scheme Interpreter, Aug. 1988, Artificial Intelligence Laboratory and Department of Electrical Engineering and Computer Science, Massachusetts Institute of Technology, Cambridge, MA. |
Christopher W. Fraser, et al., Custom Instruction Sets for Code Compression, Oct. 19, 1995. |
David F. Bacon, et al., Compiler Transformations for High-Performance Computing, ACM Computing Surveys, vol. 26, No. 4, Dec. 1994. |
David S. Blickstein, et al., The GEM Optimizing Compiler System, Digital Technical Journal, vol. 4, No. 4, Special Issue 1992. |
CASL Programmers Reference, publication date unknown, possibly before 1997. |
Enrico Ballarin, et al., Making a Compiler Easily Portable, May 1988, IEEE Software, IEEE, pp. 30-38. |
James Gosling, Java Intermediate Bytecodes, ACM SIGPLAN Workshop on Intermediate Representations, ACM, 1995. |
Greg Hewgill, Jump User's Manual Version 1.0 Beta 4, Oct. 1997 (earlier version 1996). |
David G. Messerschmitt, Important future technologies—Java,—CORBA, Department of Electrical Engineering and Computer Sciences, Lecture Mar. 30, 1997. |
Daniel P. Miranker, et al., The Organization and Performance of a TREAT-Based Production System Compiler, IEEE Transactions on Knowledge and Data Engineering, vol. 3, No. 1, Mar. 1991, IEEE, p. 3-10. |
Dave Birch, et al., Multi-Application Smartcard Platforms The third way, Hyperion Systems Limited, Nov. 14, 1998, p. 1-5. |
Kin-Man Chung, et al., A “Tiny” Pascal Compiler, Part 1: The P-Code Interpreter, Sep. 1978, BYTE Publications Inc. |
Thomas Gustafsson, Control, et al, Regsim: A Software Tool for Real Time Control and Simulation, 1995 Proceedings of the 4th IEEE Conference on Control Applications, Piscataway, NJ, IEEE, 1995, p. 168-173. |
William Rowan, A LISP Compiler Producing Compact Code, LPF '80 Proceedings of the 1980 ACM Conference on LISP and Functional Languages, ACM, pp. 216-222. |
Stefano Crespi-Reghizzi, et al., A Survey of Microprocessor Languages, Computer, Jan. 1980, p. 48-66, IEEE Computer Society Press, Los Alamitos, CA. |
Kemal Ebcioglu, et al., VLIW Compilation Techniques in a Superscalar Environment, ACM SIG Plan Notices, vol. 29, No. 6, Proceedings of the ACM SIGLAN '94 Conference on Programming Language Design and Implementation (PLDI) Jun. 20-24, 1994, pp. 36-48. |
John Banning, The XDOS Binary Code Conversion System, IEEE, 1989, p. 282-287. |
Cheng-Hsueh A. Hsieh, et al., Java Bytecode to Native Code Translation: The Caffeine Prototype and Preliminary Results, Published in the Proceedings of the 29th Annual International Symposium on Microarchitecture, p. 1-8, Dec. 2-4, 1996, Paris, France, IEEE, 1996. |
Paul Tarau, et al., The Power of Partial Translation: An Experiment With the C-Ification of Binary Prolog, ACM, p. 152-156, 1995. |
Frank Yellin, The JIT Compiler API, Sun Microsystems Inc., Oct. 4, 1996, p. 1-23. |
James Gosling, et al., The JavaTM Language Environment, A White Paper, JAVASOFT, Sun Microsystems Inc., Mountain View, CA, May 1996. |
Olin Shivers, Supporting dynamic languages on the Java virtual machine, A.I. Memo No. 1576, Apr. 1996, Massachusetts Institute of Technology Artificial Intelligence Laboratory, Cambridge, MA. |
Craig Chambers, et al., Whole-Program Optimization of Object-Oriented Languages, Department of Computer Science and Engineering, University of Washington, Seattle, Washington, Technical Report Jun. 2, 1996, Jun. 6, 1996. |
Bjarne Steensgaard, et al., Object and Native Code Thread Mobility Among Heterogeneous Computers, ACM, 1995. |
T.L. Harris, A just-in-time Java byte-code compiler, Oct. 22, 1996, Churchill College, p. 1-6, Churchill College. |
BASIC stamp user manual, Parallax, Inc., 1993. |
BASIC stamp I—Instruction List, Parallax, Inc., 1993. |
BASIC stamp—Syntax Description, Parallax, Inc., 1993. |
Chuck McManis, Decoding The BASIC Stamp, 1994 (http://www.mcmanis.com/chuck/robotics/stamp-decode.html, accessed on Mar. 6, 2012). |
Clark Lindsey, et al., Javelin Stamp, JAVATECH: An Introduction to Scientific and Technical Computing with JAVA, chapter 24, Dec. 14, 2004 (web version at http://www.particle.kth.se/˜lindsey/JavaCourse/Book/Part3/Chapter24/Javelin.html accessed on Mar. 6, 2012). |
Al Williams, Scaling Java, Embedded Systems Programming Magazine, Jun. 2001, http://www.eetimes.com/design/embedded/4023339/Scaling-Java (accessed on Mar. 6, 2012). |
Manuel E. Benitez, et al., A Portable Global Optimizer and Linker, Proceedings of the SIGPLAN '88 Conference on Programming Language Design and Implementation, Atlanta, Georgia, Jun. 22-24, ACM, 1988, p. 329-338. |
Parallax Inc: Origins, http://www.parallax.com/tabid/791/Default.aspx (accessed on Mar. 6, 2012). |
p-System: Description, Background, Utilities, Education Technology Center, Dept. of Information and Computer Science, University of California, Irvine, CA, http://www.ics.uci.edu/˜archive/documentation/p-system/p-system.html (accessed on Mar. 6, 2012). |
Stephen Pelc, The Evolution of SENDIT Into EPIC, Proceedings of the 1996 Rochester Conference on Open Systems, Jun. 19-22, 1996, Ryerson Polytechnic University, Toronto, Ontario, Canada, Jun. 19-22, 1996, p. 63-67. |
Peter Johannes, et al., A Platform-Independent Token System for Payment rerminals, Forth Dimensions, vol. XIX, No. 2, Jul.-Aug. 1997, pp. 7-11. |
Open Terminal Architecture System Overview, Europay International SA, Waterloo, Belgium, Version 2.1, May 19, 1997. |
Europay International, Open Terminal Architecture (OTA) for Multi-application Smart Card Terminals, Waterloo, Belgium, p. 1-6, whole document, 1996. |
E. D. Rather and D.A. Ruffer, A Platform-independent Token System for Payment Terminals (V1), Forth, Inc., pp. 1-7, 1996. |
E. D. Rather, S.F. Pelc, and P. Johannes, A Platform-independent Token System for Payment Terminals (V2), pp. 1-6, 1996. |
E. D. Rather, et al., A Platform-independent Token System for Payment Terminals, Forth Dimensions XIX/2, No. 2, Jul.-Aug. 1997, Forth Interest Group, Carmel, CA, p. 7-11. |
E. D. Rather, et al., The Europay Open Terminal Architecture, A Forth-based Token System for Payment Terminals, Proceedings of the 1996 Rochester Conference on Open Systems, Jun. 1996. |
Peter Wayner, State of the Art Sun Gambles on Java Chips, BYTE, Nov. 1996, p. 79, 80, 82, 84, 86 and 88. |
Claus M. Muller, Java—mehr als eine programmiersprache, Heidelberg, Germany, 1996 (in German, Translation not available). |
Europay Announces OTA, Smart Card News, ISSN: 0967-196X, Brighton, England, Jul. 1996, p. 125. |
E. D. Rather, et al., The Europay Open Terminal Archetecture A Forth-based Token System for Payment Terminals (2nd of 3 papers on OTA), Proceedings of the 1996 Rochester Conference on Open Systems, Jun. 1996, pp. 73-77. |
Europay International S.A., Open Terminal Architecture (OTA) Specification, vol. 1: Virtual Machine Specification, Waterloo, Belgium, Version 3.3, Dec. 15, 1998. |
Europay International S.A., Open Terminal Architecture (OTA) Specification, vol. 2: Forth Language Programming Interface, Waterloo, Belgium, Version 3.0, Feb. 11, 1999. |
Europay International S.A., Open Terminal Architecture (OTA) Specification, vol. 3: C Language Programming Interface, Waterloo, Belgium, Version 3.2, Dec. 9, 1998. |
Europay International S.A., Open Terminal Architecture (OTA) Specification, vol. 4: Mixed Language Programming, Waterloo, Belgium, Version 1.1, Jul. 1, 1997. |
Europay International S.A., TKTP Reference Manual, Version 4.4, Mar. 10, 1999. |
E. D. Rather, et al., The Europay Open Terminal Archetecture A Forth-based Token System for Payment Terminals 1st of 3 papers on OTA), Proceedings of the 1996 Rochester Conference on Open Systems, Jun. 1996, pp. 27-29. |
Pierre Paradinas, et al., New Directions for Integrated Circuit Cards Operating Systems, Operating Systems Review, 29(1):56-61, 1995 (Accessed from http://cedric.cnam.fr/%7Eparadinas/presentation/OSR.pdf on Mar. 6, 2012). |
Defendants 3-3 and 3-6 Invalidity Contentions: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Exhibit A of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-1 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-2 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-3 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-4 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-5 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-6 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-7 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-8 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-9 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-10 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-11 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-12 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-13 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-14 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-15 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-16 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-17 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-18 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-19 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-30 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-32 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-33 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-34 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-35 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-36 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-37 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Chart A-38 of: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Exhibit B: List of Prior Art: Amended Invalidity Contentions filed with the US District Court for the Eastern District of Texas, Tyler Division, by a Defendant on Oct. 23, 2012 in which arguments are presented that claims in US 6,308,317, US 7,117,485 and US 7,818,727 are invalid or unenforceable in Gemalto S.A. v. HTC Corporation, Civil Action No. 6:10-CV-561-LED. |
Gemalto S.A. vs. HTC Corporation, et al., Case No. 6:10-CV-561 LED-JDL, Report and Recommendation of United States Magistrate Judge, Jun. 28, 2012, United States District Court for the Eastern District of Texas, Tyler Division, whole Document. |
Gemalto S.A. vs. HTC Corporation, et al., Case No. 6:10-CV-561 LED-JDL, Memorandum Opinion and Order, Jun. 28, 2012, United States District Court for the Eastern District of Texas, Tyler Division, whole Document and Appendix A. |
Palsberg Expert Report on Invalidity filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Exhibit A—to the Expert Report of Jens Palsberg, Ph.D.: List of Materials Considered, filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Exhibit B—Curriculum Vitae of Jens Palsberg, Ph.D.: List of Materials Considered, filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 6, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Exhibit C—filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Supplimental Expert Report of Dr. Jens Palsberg, Ph.D. filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 7, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Chart C-1 filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Chart C-2 filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Chart C-3 filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Chart C-4 filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Chart C-5 filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A. v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Chart C-6 filed with the US District Court for the Eastern District of Texas, Tyler Division, on Dec. 5, 2012. Gemalto S.A v. HTC Corporation Case 6:10-CV-561-LED relating to claims in U.S. Patent 6,308,317, 7,117,485, and 7,818,727. |
Number | Date | Country | |
---|---|---|---|
20110126178 A1 | May 2011 | US |
Number | Date | Country | |
---|---|---|---|
60029057 | Oct 1996 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11537156 | Sep 2006 | US |
Child | 12907949 | US | |
Parent | 10037390 | Oct 2001 | US |
Child | 11537156 | US | |
Parent | 08957512 | Oct 1997 | US |
Child | 10037390 | US |