1. Field of the Invention
The invention relates in general to the technical field of memory management in the execution of a program by a portable data carrier having a processor. A portable data carrier of such a kind can be especially a chip card in various constructional forms or a chip module. The invention relates more particularly to the use of two different memory regions of the data carrier in order to store objects generated during program execution.
2. Description of Related Art
In portable data carriers there are generally provided a plurality of memory regions which are constructed in various memory technologies. Typically, the memory is subdivided into a volatile read/write memory (RAM), a non-volatile writable memory (EEPROM) and a mask-programmed fixed value memory (ROM). A write-to-RAM operation requires substantially less time—for example, less by a factor of 30—than a write-to-EEPROM operation. On the other hand, one bit in RAM takes up a substantially greater area on a semiconductor chip of the data carrier than one bit in EEPROM so that usually only relatively little RAM is provided. The problem accordingly exists of utilizing the fast but scarce RAM in the best and most flexible manner possible.
Portable data carriers with complex memory management functions are known, for example, under the trademark Java Card™. The document “Java Card™ 2.2 Runtime Environment (JCRE) Specification”, June 2002, published by the company Sun Microsystems, Inc., Palo Alto, USA, available on the Internet under http://java.sun.com/products/javacard, describes the environment provided in a Java Card for the execution of programs (Java Card Applets). Chapter 5 describes that persistent objects are typically stored in the EEPROM of the data carrier whereas transient objects are typically created in the RAM. For reasons of security, it is not allowed to store transient objects in the EEPROM.
In the memory management of a Java Card just described, special system calls are used for generating transient objects, as described, for example, on pages 81-85 of the document “Java Card™ 2.2 Application Programming Interface”, June 2002, published by the company Sun Microsystems, Inc., Palo Alto, USA, available on the Internet under the above-mentioned address. This limits the extent to which transient objects are utilized in practice. In addition thereto, transient objects as such have a potentially unlimited life; the term “transient” refers merely to the data stored in the objects. Using transient objects therefore brings about only a slight increase in flexibility in memory management.
The customary and recommended practice in programming a Java Card is that all objects required during the entire life of a program (Applet) are statically created on installation of the program. This is carried out in a method having the prespecified name “install”. The said practice results, however, in memory management which is of low flexibility and, therefore, not optimal. When, for example, a transient field is created in a program in order to store temporary data for cryptographic operations, the memory space statically reserved therefor in the RAM is generally unavailable to other programs. Within the program, the extent to which such reserved memory space is also used for other tasks depends on the expertise of the programmer. It would therefore be desirable to improve utilization of the scarce memory space in the RAM and to automate memory management.
An object of the invention is accordingly to avoid, at least in part, the problems of the prior art. A further object of the invention is to make available a technique for memory management in a portable data carrier by means of which technique the utilization of an efficiently writable memory region—typically a RAM memory—is improved. Yet a further object of some embodiments is to make possible flexible utilization of the RAM memory without involving much work for the programmer.
In accordance with the invention, the above problems are solved, in whole or in part, by a process for memory management in the execution of a program by a portable data carrier which has a first and a second memory region for storage of objects generated in program execution, wherein write operations to the second memory region are performed more efficiently than write operations to the first memory region, the process comprising creation of an object generated in program execution, at least in part in the second memory region, and transfer of the object to the first memory region if, in the course of further program execution, a persistent reference to the object is generated.
Further in accordance with the invention, the above problems are solved, in whole or in part, by a process for converting a source program into a program intended for execution by a portable data carrier, wherein the data carrier has a first and a second memory region for storage of objects generated in program execution and wherein write operations to the second memory region are performed more efficiently than write operations to the first memory region, wherein, on conversion of a portion of the source program which contains the generation of an object, it is checked at least approximately whether a persistent reference to the object is generated in the converted portion of the source program; and, depending on the result of that check, either program code is generated which creates the object in the first memory region or program code is generated which creates the object at least in part in the second memory region.
Further in accordance with the invention, the above problems are solved, in whole or in part, by a portable data carrier and/or a computer program product that are adapted for carrying out the above processes.
The basic idea underlying the invention is that certain objects which are generated in the execution of the program by the portable data carrier are automatically created in an efficiently writable memory region—for example, in the RAM. For that purpose there come into consideration, in particular, those objects which have only a short life. Objects of such a kind are referred to in the present document as “local objects”. Local objects as understood by the invention can be, for example, exception objects, as are generated when exceptions occur. The life of an exception object ends as soon as the exception in question has been caught.
By means of the invention, temporarily required memory space can be made available for a short period and dynamically—namely in the form of a local object. The local object is created, in part or in whole, in the RAM or another efficiently writable memory. As a result of the automatic and dynamic memory management of the invention, that memory is utilized especially well, which increases the efficiency of the data carrier both in respect of processing speed and also in respect of the memory space effectively available for the programs executed.
In general, the life of an object is at an end when no more references to the object exist, because access to the object is then no longer possible. In particular, a local object can be defined by the fact that no persistent reference to the object exists. A “persistent reference” is to be understood herein as a reference to the object, which reference is persistently stored, for example, in a field of an object, a static field or a field of an array. As soon as a reference to an object is written into one of the mentioned fields, the object can no longer be a local object. In contrast, non-persistent references to an object, which are contained, for example, in the operand stack or in a local variable, do not influence classification of an object as a local or non-local object.
The distinction as to whether an object is to be treated as a local or non-local object can be made at program compile time or at run time or partly at compile time and partly at run time. In the case of a distinction being made at run time, at least some newly generated objects are created, initially, in the second, efficiently writable memory region. During further program execution, monitoring is performed as to whether a persistent reference to the object is created. As soon as that is the case, the object can no longer be treated as a local object. It is then transferred into the first, non-volatile memory region.
In the case of a distinction being made at compile time, the compiler analyses that portion of the source program which contains the object generation as to whether a persistent reference to the object is created. Depending on the result of the analysis, the compiler then generates program code which creates the object in the first or—in whole or in part—in the second memory region. The term “compiler” is intended in the terminology of the present document to include all programs which execute automatic conversion procedures. Accordingly, besides the Java compiler in the narrower sense, “compilers” are intended also to refer to, for example, converters for the generation of CAP files (Card Application Files) and optimization programs.
A source program analysis at compile time is generally capable of supplying an only approximate result, which is understood to mean that, at least, a certain degree of uncertainty is associated with one of the two classifications of an object as local or non-local. Provision can therefore be made so that only objects which are recognized with certainty as being local are created in the second memory region whereas all other objects are created in the first memory region. In contrast, in an alternative embodiment, only objects which are recognized with certainty as being non-local are created in the first memory region whereas all other objects are created in the second memory region. Then, in addition, at least for objects which it was not possible to classify with certainty as local, the above-described run time monitoring is carried out. In some forms of embodiment, compiler directives (pragmas) are provided by means of which objects can be characterized as local or non-local.
In preferred embodiments, simple criteria are applied—at run time or compile time, as desired—in order to determine whether objects are to be created in the first or, initially, in the second memory region. For example, provision can be made so that objects generated by the install method of the program are created in the first memory region. In different forms of embodiment, either all other objects can be created, initially, in the second memory region, or merely individual kinds of objects. Such kinds of objects can be, for example, exception objects or objects which are required only temporarily for cryptographic operations.
The life of a local object is usually at an end with the termination—either resulting from a return or from an exception—of the method in which the local object was generated, because at that moment the possibly existing local references to the object are erased. The memory space that may still be required for the object in the second memory region can then be freed up. An exception to the rule that has just been mentioned applies when the object is used as a return parameter of the method which has generated the object. In that case, the calling method receives a reference to the object so that the object must not be erased at least until termination of that method.
In order to be able to utilise freed-up memory space in the second memory region for the creation of new objects, memory clean-up (garbage collection) is provided in some forms of embodiment. However, this is time-consuming during program execution and increases the complexity of the run time environment. Preferably, therefore, an especially simple process is used wherein a fill-level indicator shows the occupation of the second memory region. On termination of a method, the fill-level indicator is usually reset to the state it was in when that method was called. An exception to that rule is made in preferred embodiments only when that portion of the second memory region which is freed up by the resetting contains an object which is used as a return parameter of the method.
In order to ensure that, if so required, an object can be transferred from the second to the first memory region, it is checked, preferably already when the object is created in the second memory region, whether sufficient space for the object is also available in the first memory region. It is also preferably ensured during further program execution, when new objects are created, that there is always sufficient space in the first memory region for a potentially necessary transfer of objects.
In preferred embodiments, the first memory region is located in an EEPROM or another non-volatile writable memory of the data carrier whereas the second memory region is arranged in a RAM or another efficiently writable memory. The second memory region can especially be in the form of a local heap and/or in a stack memory. Storage in a stack memory is advantageous especially for objects already identified as local objects at compile time.
The computer program product according to the invention comprises program commands in order to implement the conversion process according to the invention. A computer program product of such a kind can be a physical medium, for example a semiconductor memory or a diskette or a CD-ROM, on which a program is stored for carrying out a process according to the invention. The computer program product can, however, also be a non-physical medium, for example a signal transmitted by way of a computer network. The computer program product is preferably a compiler intended for execution by a customary workstation computer in order to generate programs for portable data carriers.
In preferred embodiments, the data carrier and/or the computer program product has/have features which correspond to the features that are described above and/or that are mentioned in the dependent process claims.
Further features, advantages and functions of the invention will emerge from the following specific description of an exemplifying embodiment and a number of alternative embodiments. Reference is made to the diagrammatic drawings, in which:
The data carrier 10 shown in
System programs 22, which are required for operation of the data carrier 10, are contained in the fixed value memory 16—and also, in part, in the non-volatile memory 18. In a manner known per se, the system programs 22 include an operating system 24 and also program code 26 for implementing a virtual machine 26, which in the present exemplifying embodiment is in the form of a JCVM (Java Card Virtual Machine). Also provided is a class library 28, which makes available application programming interfaces. A program 30, which is in the form of a Java Card Applet, has been loaded into the non-volatile memory 18 on initialization of the data carrier 10; in alternative embodiments, the program 30 can be located, in whole or in part, in the fixed value memory 16. Although only a single program 30 is shown in
A stack memory 32 located in the write/read memory 20 takes up operands, return addresses, local variables and other data values during program execution. The free region of the stack memory 32 is illustrated in
In the non-volatile memory 18 there is reserved a first memory region 34 which, in a manner known per se, is in the form of a persistent heap. In accordance with the customary Java Card architecture, all objects, static data fields and non-transient arrays would be created in this persistent heap. In contrast, in the present exemplifying embodiment, the persistent heap is used only selectively. Local objects which are expected to have only a short life and to which no persistent references refer are created not in the first memory region 34 but rather in a second memory region 36 in the write/read memory 20. The second memory region 36 is also referred to as a local heap because it, similarly to the persistent heap, serves for the storage of objects.
In order to illustrate the situation just described,
When, in execution of the program by the data carrier 10, the creation of a new object is requested by the command “NEW”, the procedure shown in
In the present exemplifying embodiment, provision is made so that objects which are created by the “install” installation method of the program 30 are always considered persistent objects and are therefore taken up into the first memory region 34. In step 52, therefore, it is queried whether program installation is currently being performed. If that is the case, the new object is generated, in step 54, as a persistent object in the first memory region 34. The generation procedure performed in step 54 corresponds to the creation of an object in the persistent heap performed in the case of a customary Java Card.
If it has been ascertained in step 52 that the program execution is outside the installation method, the new object to be created is, in the present exemplifying embodiment, regarded initially as a local object. It is then created in the second memory region 36—the local heap—provided that sufficient memory space is free therein, which is checked in step 56. If sufficient memory space is available in the local heap, the object is, in step 58, created therein at the next free location—immediately adjacent to the region used hitherto—and the fill-level indicator 48 is updated accordingly. If, however, the local heap is already too full, the customary procedure of object creation in the first memory region 34 is carried out in step 54, in which region of course, as checked in step 50, sufficient free memory space is still available.
During the further execution of the program 30 by the data carrier 10 it is checked, each time a persistent reference is generated or modified, whether the reference refers to an object located in the second memory region 36. If this is the case, the object is transferred from the second memory region 36 into the first memory region 34. Because of the query in step 50 it is ensured that this is possible at any time.
In the present exemplifying embodiment, the second memory region 36 is organized similarly to a stack memory in order that, after termination of a method 30.x, the memory space occupied by the local objects generated in that method 30.x can be freed up in simple manner. To illustrate that procedure,
In the present exemplifying embodiment, each stack frame 60.x also has a fill-level field 62.x, which contains the fill-level indicator 48 during execution of the method 30.x in question. In the illustration of
In the exemplifying embodiment presently described, provision is made so that, on termination of a method, the space occupied by that method in the second memory region 36 is generally freed up completely. This occurs without further ado by means of the fact that, on termination of a method, the corresponding stack frame 60.x—including the fill-level field 62.x contained therein—is discarded and the fill-level field 62.(x−1) of the next oldest stack frame 60.(x−1) with its occupying contents stored therein is used as the new fill-level indicator 48. Accordingly, for example, after termination of that method the calling of which gave rise to creation of the stack frame 60.3, the contents of the fill-level field 62.2 are used as the new fill-level indicator 48 so that the entire memory portion 64.3 is freed up.
There is an exception to the rule given in the previous paragraph when the method just terminated returns to the calling method a reference to a local object that it has created in the second memory region 36. In that case, the contents of the current fill-level field 62.x are copied into the next oldest stack frame 60.(x−1) in order to prevent the local object from being overwritten. When, for example, in the memory occupation arrangement of
The just described procedure on termination of a method is illustrated again in
In the case of the process described hitherto, for the purpose of deciding whether an object to be newly created should be generated in the first or second memory region 34, 36, a simple query was performed at run time in step 52. Further run time checks were carried out on creation of and on updating of persistent references. In contrast, in alternative embodiments, provision is made so that the said checks are brought forward, in whole or in part, to the level of the compiler 82.
By means of abstract analysis of the source program 80 or of an intermediate code, the compiler 82 can obtain information as to whether an object to be newly created during later program execution is to be regarded as a local or non-local object. Depending on the result of that analysis, the compiler 82 then generates program code which brings about creation of the object either in the first memory region 34 or in the second memory region 36. In alternative embodiments, objects which have with certainty been recognized as local at compile time, such as local variables, are created in the stack memory 32. Depending on whether a local heap is additionally provided in the write/read memory 20, the stack memory 32 in those embodiments forms the entire second memory region 36 or part of the second memory region 36.
The source program 80 will usually be provided with commands for the generation of objects which at compile time cannot be unambiguously classified as local or non-local objects. Such objects either can be created immediately in the first memory region 34 or, in the manner described hereinbefore, can be initially created as local objects in the second memory region 36 and only transferred to the first memory region 34 when so required.
The particulars contained in the above description of sample embodiments should not be construed as limitations of the scope of the invention, but rather as exemplifications of preferred embodiments thereof. Accordingly, the scope of the invention should be determined not by the embodiments illustrated, but by the appended claims and their legal equivalents.
Number | Date | Country | Kind |
---|---|---|---|
103 20 062.2 | May 2003 | DE | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP04/04723 | 5/4/2004 | WO | 11/3/2005 |