FR3120718A1 - Process for executing a computer program by an electronic device - Google Patents

Process for executing a computer program by an electronic device Download PDF

Info

Publication number
FR3120718A1
FR3120718A1 FR2102263A FR2102263A FR3120718A1 FR 3120718 A1 FR3120718 A1 FR 3120718A1 FR 2102263 A FR2102263 A FR 2102263A FR 2102263 A FR2102263 A FR 2102263A FR 3120718 A1 FR3120718 A1 FR 3120718A1
Authority
FR
France
Prior art keywords
code
block
pointer
lines
line
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
FR2102263A
Other languages
French (fr)
Other versions
FR3120718B1 (en
Inventor
Olivier Savry
Thomas HISCOCK
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Commissariat a lEnergie Atomique et aux Energies Alternatives CEA
Original Assignee
Commissariat a lEnergie Atomique CEA
Commissariat a lEnergie Atomique et aux Energies Alternatives CEA
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Commissariat a lEnergie Atomique CEA, Commissariat a lEnergie Atomique et aux Energies Alternatives CEA filed Critical Commissariat a lEnergie Atomique CEA
Priority to FR2102263A priority Critical patent/FR3120718B1/en
Priority to US17/650,861 priority patent/US20220294634A1/en
Priority to EP22157119.3A priority patent/EP4057168B1/en
Publication of FR3120718A1 publication Critical patent/FR3120718A1/en
Application granted granted Critical
Publication of FR3120718B1 publication Critical patent/FR3120718B1/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3234Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving additional secure or trusted devices, e.g. TPM, smartcard, USB or software token
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/52Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow
    • G06F21/54Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow by adding security routines or objects to programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/70Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer
    • G06F21/71Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure computing or processing of information
    • G06F21/72Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure computing or processing of information in cryptographic circuits
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • H04L9/065Encryption by serially and continuously modifying data stream elements, e.g. stream cipher systems, RC4, SEAL or A5/3

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Storage Device Security (AREA)

Abstract

Ce procédé d’exécution d’un programme d'ordinateur comporte : - l'incorporation (408), dans des métadonnées d'un bloc contenant une ligne de code à accéder à l'aide d'un pointeur, d'un premier identifiant de pointeur associé à la ligne de code à accéder, puis - l'obtention (166) d'un pointeur comprenant : - une première plage de bits contenant l’adresse de la ligne de code à accéder, et - une seconde plage différente de bits contenant un second identifiant de pointeur, puis - la vérification (176) que le second identifiant de pointeur contenu dans le pointeur obtenu correspond au premier identifiant de pointeur associé à la ligne de code à accéder et contenu dans les métadonnées du bloc chargé, et lorsque les premier et second identifiants de pointeur ne correspondent pas, alors le module de sécurisation déclenche (180) le signalement d'une faute d'exécution. Fig. 6This method of executing a computer program comprises: - the incorporation (408), in metadata of a block containing a line of code to be accessed using a pointer, of a first identifier pointer associated with the line of code to be accessed, then - obtaining (166) a pointer comprising: - a first range of bits containing the address of the line of code to be accessed, and - a second range different from bits containing a second pointer identifier, then - checking (176) that the second pointer identifier contained in the pointer obtained corresponds to the first pointer identifier associated with the line of code to be accessed and contained in the metadata of the loaded block, and when the first and second pointer identifiers do not match, then the security module triggers (180) the signaling of an execution fault. Fig. 6

Description

Procédé d’exécution d’un programme d’ordinateur par un appareil électroniqueProcess for executing a computer program by an electronic device

L’invention concerne un procédé d’exécution d’un programme d’ordinateur par un appareil électronique comportant un microprocesseur, une mémoire déchiffrée, une mémoire chiffrée et un module matériel de sécurisation.The invention relates to a method for executing a computer program by an electronic device comprising a microprocessor, a decrypted memory, an encrypted memory and a hardware security module.

L’invention concerne également :
- un programme d'ordinateur apte à être exécuté par un microprocesseur en mettant en œuvre ce procédé, et
- un module matériel de sécurisation pour la mise en œuvre de ce procédé.
The invention also relates to:
- a computer program capable of being executed by a microprocessor by implementing this method, and
- a security hardware module for the implementation of this method.

Pour des raisons de sécurité, il est connu d’enregistrer les données traitées, lors de l’exécution d’un programme d’ordinateur, sous forme chiffrée dans une mémoire. Par la suite, la mémoire ou partie de mémoire qui contient ces données chiffrées est appelée « mémoire chiffrée ». Dans ce cas, à chaque fois qu’une donnée doit être chargée dans le microprocesseur pour y être traitée, la donnée chiffrée est d’abord transférée de la mémoire chiffrée vers une mémoire déchiffrée. Par la suite, on appelle « mémoire déchiffrée », une mémoire dans laquelle les données sont enregistrées sous forme déchiffrée. Lors de ce transfert, l’intégrité de la donnée à charger est d’abord vérifiée. Seulement si l’intégrité de la donnée est confirmée, alors la donnée est déchiffrée puis enregistrée dans la mémoire déchiffrée.For security reasons, it is known to record the data processed, during the execution of a computer program, in encrypted form in a memory. Hereafter, the memory or part of memory which contains this encrypted data is called “encrypted memory”. In this case, each time that a piece of data must be loaded into the microprocessor to be processed there, the encrypted data is first transferred from the encrypted memory to a decrypted memory. Thereafter, we call "decrypted memory", a memory in which the data is stored in decrypted form. During this transfer, the integrity of the data to be loaded is first checked. Only if the integrity of the data is confirmed, then the data is decrypted and then saved in the decrypted memory.

Dans ce contexte, des données sont également transférées, en sens inverse, de la mémoire déchiffrée vers la mémoire chiffrée pour y être enregistrées. Lors de ce transfert, la donnée est chiffrée, puis le code d’authentification permettant de vérifier son intégrité est calculé. Enfin, la donnée chiffrée et son code d’authentification sont enregistrés dans la mémoire chiffrée.In this context, data is also transferred, in the reverse direction, from the decrypted memory to the encrypted memory in order to be recorded there. During this transfer, the data is encrypted, then the authentication code used to verify its integrity is calculated. Finally, the encrypted data and its authentication code are stored in the encrypted memory.

Les opérations de vérification de l’intégrité d’une donnée et de déchiffrement de cette donnée sont relativement longues. De même, les opérations de chiffrement et de calcul d’un code d’authentification sont aussi relativement longues. Ainsi, pour accélérer les transferts de données entre la mémoire déchiffrée et la mémoire chiffrée, il a déjà été proposé de faire ces transferts par bloc de plusieurs données, plutôt qu’individuellement pour chaque donnée. Dans ce cas, le bloc de données est enregistré dans la mémoire chiffrée sous la forme d’un bloc de données chiffrées et authentifiées.The operations of checking the integrity of a data and decrypting this data are relatively long. Similarly, the operations of encryption and calculation of an authentication code are also relatively long. Thus, to accelerate the data transfers between the decrypted memory and the encrypted memory, it has already been proposed to make these transfers by block of several data, rather than individually for each data. In this case, the block of data is stored in the encrypted memory as an encrypted and authenticated data block.

Un tel bloc de données chiffrées et authentifiées comprend notamment :
- un cryptogramme du bloc de données en clair, et
- un code d’authentification de ce cryptogramme.
Such a block of encrypted and authenticated data includes in particular:
- a cryptogram of the data block in plain text, and
- an authentication code for this cryptogram.

Le cryptogramme du bloc de données en clair est obtenu en traitant le bloc de données comme un seul bloc de bits et sans distinguer les données les unes des autres. Ainsi, pour obtenir ce cryptogramme, une seule opération de chiffrement est exécutée au lieu d’une opération de chiffrement pour chaque donnée de ce bloc de données. Ceci accélère l’opération de chiffrement des données. En contrepartie, le cryptogramme ne peut être déchiffré qu’en une seule opération de déchiffrement. En particulier, il n’est pas possible de déchiffrer qu’une partie seulement des données sans déchiffrer la totalité du cryptogramme.The cryptogram of the clear data block is obtained by treating the data block as a single block of bits and without distinguishing the data from each other. Thus, to obtain this ciphertext, a single encryption operation is performed instead of one encryption operation for each piece of data in this data block. This speeds up the data encryption operation. In return, the cryptogram can only be decrypted in a single decryption operation. In particular, it is not possible to decrypt only part of the data without decrypting the entire cryptogram.

De façon similaire, le code d’authentification est commun à l’ensemble des données du bloc de données. Il est donc calculé en une seule opération et en traitant le bloc de données comme un seul bloc. Ainsi, on évite de construire un code d’authentification pour chaque donnée de ce bloc de données. Cela accélère aussi la construction du code d’authentification.Similarly, the authentication code is common to all the data in the data block. It is therefore calculated in a single operation and by treating the block of data as a single block. Thus, we avoid constructing an authentication code for each piece of data in this data block. It also speeds up the construction of the authentication code.

Par ailleurs, pour obtenir des informations sur un programme d'ordinateur ou provoquer un fonctionnement inattendu de ce programme d'ordinateur, de nombreuses attaques sont possibles. Certaines de ces attaques sont basées sur un usage erroné d’un pointeur de donnée. On rappelle ici qu’un pointeur de donnée est une donnée qui contient l’adresse de la donnée à traiter et non pas directement la valeur de la donnée traitée.Furthermore, to obtain information about a computer program or cause an unexpected operation of this computer program, many attacks are possible. Some of these attacks are based on the erroneous use of a data pointer. We recall here that a data pointer is data that contains the address of the data to be processed and not directly the value of the processed data.

L’usage de tels pointeurs de données est fréquent dans un programme d'ordinateur. Par exemple, un tel pointeur est utilisé pour pointer vers la première cellule d’un tableau de plusieurs cellules. Ensuite, pour traiter la cellule suivante de ce tableau, il suffit simplement d’incrémenter l’adresse contenue dans le pointeur d’un pas prédéterminé.The use of such data pointers is frequent in a computer program. For example, such a pointer is used to point to the first cell of an array of multiple cells. Then, to process the next cell of this table, simply increment the address contained in the pointer by a predetermined step.

Lors de la conception du programme d'ordinateur, le pointeur est prévu pour manipuler et traiter un groupe de données d’une taille prédéterminée. Toutefois, lors de l’exécution du programme d'ordinateur, il est parfois possible de s’arranger pour que ce pointeur pointe sur une donnée située en dehors de ce groupe de données. Par exemple, un tel usage erroné de ce pointeur est provoqué en saisissant, dans un champ de saisie, une donnée dont la taille est bien plus grande que celle prévue initialement par les développeurs du programme d'ordinateur. Grâce à cela, il est possible d’écrire des données dans des plages d’adresses où cela ne devrait pas être fait. Autrement dit, le pointeur est utilisé pour pointer vers des adresses invalides. Un exemple de ce premier type d’attaque est connu sous le terme de « attaque par dépassement de tampon» ou « stack overflow attack », lorsque cette attaque vise la pile utilisée par une fonction du programme d'ordinateur. Lorsque le pointeur est utilisé pour écrire des données avant la plage d’adresses prévue à cet effet dans la pile, l’attaque est également connue sous le terme de « stack underflow attack ».When designing the computer program, the pointer is intended to manipulate and process a group of data of a predetermined size. However, when executing the computer program, it is sometimes possible to arrange for this pointer to point to data located outside this data group. For example, such an erroneous use of this pointer is caused by entering, in an input field, a datum whose size is much larger than that initially planned by the developers of the computer program. Thanks to this, it is possible to write data to address ranges where it should not be done. That is, the pointer is used to point to invalid addresses. An example of this first type of attack is known as a "buffer overflow attack" or "stack overflow attack", when this attack targets the stack used by a function of the computer program. When the pointer is used to write data before the intended address range in the stack, the attack is also known as a "stack underflow attack".

Ce premier type d’attaque peut être mis en œuvre de façon assez similaire pour écrire des données à des adresses invalides dans d’autres parties de la mémoire que la pile, comme par exemple, dans une partie connue sous le terme de « tas » (« heap » en anglais).This first type of attack can be implemented in a fairly similar way to write data at invalid addresses in other parts of the memory than the stack, such as, for example, in a part known as the "heap". (“heap” in English).

Ces premiers types d’attaques ont en commun d’utiliser un pointeur valide pour pointer sur des adresses invalides. On dit alors qu’elles concernent ce qui touche au domaine de la « sécurité spatiale » (« spatial safety » en anglais).These first types of attacks have in common to use a valid pointer to point to invalid addresses. We then say that they relate to matters relating to the field of “spatial safety”.

Il existe aussi des usages erronés des pointeurs qui touchent au domaine de la sécurité temporelle (« temporal safety » en anglais). Dans ce cas, un pointeur invalide est utilisé pour pointer sur une adresse valide. Un pointeur invalide est un pointeur qui a été utilisé de façon valide pour traiter des données dans un contexte limité, et qui est ensuite utilisé à nouveau en dehors de ce contexte limité. Cela peut se produire si, par exemple, ce pointeur n’a pas correctement été réinitialisé ou initialisé. Ce type de pointeur invalide est connu sous le terme anglais de « dangling pointer ».There are also erroneous uses of pointers that affect the field of temporal safety. In this case, an invalid pointer is used to point to a valid address. An invalid pointer is a pointer that has been validly used to process data in a bounded context, and is then used again outside of that bounded context. This can happen if, for example, this pointer was not properly reset or initialized. This type of invalid pointer is known as a “dangling pointer”.

Certaines attaques repèrent donc ces pointeurs invalides, puis les utilisent pour lire ou écrire des données à des instants où ils ne devraient pas être utilisés pour cela. À titre d’illustration de ce second type d’attaque, on peut citer l’attaque connue sous l’expression anglaise de « use-after-free ».Some attacks therefore locate these invalid pointers, then use them to read or write data at times when they should not be used for this. As an illustration of this second type of attack, we can cite the attack known as “use-after-free”.

On notera aussi que les attaques basées sur des usages erronés de pointeurs ne concernent pas que les pointeurs de données, c’est-à-dire, les pointeurs qui pointent vers une donnée à traiter par le microprocesseur. Ce type d’attaque concerne également les pointeurs appelés ici « pointeurs de fonctions », c’est-à-dire, un pointeur qui contient l’adresse non pas d’une donnée, mais d’une instruction à exécuter par le microprocesseur.It should also be noted that attacks based on erroneous use of pointers do not only concern data pointers, that is to say, pointers that point to data to be processed by the microprocessor. This type of attack also concerns pointers called here "function pointers", that is to say, a pointer which contains the address not of a piece of data, but of an instruction to be executed by the microprocessor.

Plusieurs solutions ont déjà été proposées pour rendre plus difficile un usage erroné d’un pointeur. Par exemple, une solution est décrite dans la demande US2021-0004456. Cette solution est intéressante mais n'est pas applicable dans un contexte où les données sont chiffrées et déchiffrées par bloc. En effet, comme expliqué ci-dessus les avantages du chiffrement/déchiffrement par bloc découlent du fait, notamment, qu'il n'y a qu'un seul code d'authentification commun à toutes les données du bloc. A l'inverse, le procédé décrit dans la demande US2021-0004456 impose d'utiliser un code d'authentification pour chaque donnée accédée avec un pointeur. Cette dernière condition est donc incompatible avec un chiffrement/déchiffrement pas bloc des données.Several solutions have already been proposed to make the erroneous use of a pointer more difficult. For example, a solution is described in application US2021-0004456. This solution is interesting but is not applicable in a context where the data is encrypted and decrypted by block. Indeed, as explained above, the advantages of block encryption/decryption stem from the fact, in particular, that there is only one authentication code common to all the data in the block. Conversely, the method described in application US2021-0004456 requires the use of an authentication code for each data item accessed with a pointer. This last condition is therefore incompatible with block encryption/decryption of the data.

L’invention vise donc à proposer un procédé d’exécution d’un programme d'ordinateur, robuste vis-à-vis d’un large spectre d’attaques basées sur un usage erroné d’un pointeur tout en étant compatible avec un chiffrement/déchiffrement par bloc des données.The invention therefore aims to propose a method of executing a computer program, robust vis-à-vis a wide spectrum of attacks based on erroneous use of a pointer while being compatible with encryption /block decryption of data.

L’invention a donc pour objet un tel procédé d’exécution d’un programme d'ordinateur par un appareil électronique comportant un microprocesseur, une mémoire déchiffrée, une mémoire chiffrée et un module matériel de sécurisation, dans lequel, lors de l'exécution du programme d'ordinateur, le transfert des lignes de code entre la mémoire déchiffrée et la mémoire chiffrée se fait par bloc entier de plusieurs lignes de code chiffrées et authentifiées, ce procédé comportant les étapes suivantes:
a) l'enregistrement dans la mémoire chiffrée d'un bloc de lignes de code chiffrées et authentifiées contenant une ligne de code à accéder à l'aide d'un pointeur, ce bloc de lignes de code chiffrées et authentifiées contenant :
- un cryptogramme de l'ensemble des lignes de code de ce bloc, ce cryptogramme pouvant uniquement être déchiffré dans sa totalité pour obtenir un bloc de lignes de code en clair et non pas ligne de code par ligne de code,
- un code d'authentification calculé à partir du bloc de lignes de code en clair ou à partir du cryptogramme du bloc de lignes de code en clair, et
-des métadonnées,
b) l’obtention, par le microprocesseur, d’un pointeur contenant l’adresse à laquelle est enregistrée la ligne de code à accéder, puis
c) le chargement du bloc contenant la ligne de code à accéder depuis la mémoire chiffrée vers le microprocesseur, puis
d) la vérification, par le module matériel de sécurisation et à l'aide du code d'authentification contenu dans le bloc chargé, de l'intégrité :
- du bloc de lignes de codes en clair obtenu à partir du cryptogramme contenu dans le bloc chargé, ou
- du cryptogramme contenu dans le bloc chargé,
e) lorsque cette vérification échoue, l'inhibition du traitement, par le microprocesseur, des lignes de code de ce bloc chargé et, lorsque cette vérification réussie :
- le déchiffrement du cryptogramme contenu dans le bloc chargé pour obtenir le bloc de lignes de code en clair, et
- l'enregistrement du bloc de lignes de code en clair obtenu dans la mémoire déchiffrée et l'enregistrement des métadonnées du bloc chargé,
dans lequel :
- l'étape a) comporte l'incorporation, dans les métadonnées du bloc contenant la ligne de code à accéder, d'un premier identifiant de pointeur associé à la ligne de code à accéder, ce premier identifiant de pointeur permettant à lui seul d’identifier de façon unique un pointeur parmi un ensemble contenant plusieurs pointeurs différents mis en œuvre lors de la même exécution du programme d'ordinateur par le microprocesseur,
- l'étape b) d'obtention du pointeur comporte l'obtention d'un pointeur comprenant :
- une première plage de bits contenant l’adresse de la ligne de code à accéder, et
- une seconde plage différente de bits contenant un second identifiant de pointeur,
- après l'étape c), le procédé comporte une étape f) de vérification, par le module matériel de sécurisation, que le second identifiant de pointeur contenu dans le pointeur obtenu lors de l'étape b) correspond au premier identifiant de pointeur associé à la ligne de code à accéder et contenu dans les métadonnées du bloc chargé, et lorsque les premier et second identifiants de pointeur ne correspondent pas, alors le module de sécurisation déclenche le signalement d'une faute d'exécution et, dans le cas contraire, le module de sécurisation inhibe le déclenchement du signalement d'une faute d'exécution et le microprocesseur traite la ligne de code à accéder.
The subject of the invention is therefore such a method for executing a computer program by an electronic device comprising a microprocessor, a decrypted memory, an encrypted memory and a hardware security module, in which, during the execution of the computer program, the transfer of the lines of code between the decrypted memory and the encrypted memory is done by whole block of several encrypted and authenticated lines of code, this method comprising the following steps:
a) the recording in the encrypted memory of a block of encrypted and authenticated lines of code containing a line of code to be accessed using a pointer, this block of encrypted and authenticated lines of code containing:
- a cryptogram of all the lines of code of this block, this cryptogram can only be deciphered in its entirety to obtain a block of lines of code in plain text and not line of code by line of code,
- an authentication code calculated from the block of plaintext lines of code or from the cryptogram of the block of plaintext lines of code, and
- metadata,
b) obtaining, by the microprocessor, a pointer containing the address at which the line of code to be accessed is stored, then
c) loading the block containing the line of code to be accessed from the encrypted memory to the microprocessor, then
d) verification, by the hardware security module and using the authentication code contained in the loaded block, of the integrity:
- the block of plain code lines obtained from the cryptogram contained in the loaded block, or
- the cryptogram contained in the loaded block,
e) when this verification fails, the inhibition of the processing, by the microprocessor, of the lines of code of this loaded block and, when this verification succeeds:
- the decryption of the cryptogram contained in the loaded block to obtain the block of lines of code in clear, and
- the recording of the block of plain code lines obtained in the decrypted memory and the recording of the metadata of the loaded block,
in which :
- step a) includes the incorporation, in the metadata of the block containing the line of code to be accessed, of a first pointer identifier associated with the line of code to be accessed, this first pointer identifier alone making it possible to uniquely identify a pointer among a set containing several different pointers implemented during the same execution of the computer program by the microprocessor,
- step b) for obtaining the pointer includes obtaining a pointer comprising:
- a first range of bits containing the address of the line of code to be accessed, and
- a second different range of bits containing a second pointer identifier,
- after step c), the method comprises a step f) of verification, by the hardware security module, that the second pointer identifier contained in the pointer obtained during step b) corresponds to the first associated pointer identifier to the line of code to be accessed and contained in the metadata of the loaded block, and when the first and second pointer identifiers do not correspond, then the security module triggers the signaling of an execution fault and, in the opposite case , the security module inhibits the triggering of the signaling of an execution fault and the microprocessor processes the line of code to be accessed.

Les modes de réalisation de ce procédé d'exécution peuvent comporter une ou plusieurs des caractéristiques suivantes :
1) l'étape e) comporte l'enregistrement du premier identifiant de pointeur contenu dans les métadonnées du bloc chargé dans une mémoire uniquement accessible par le module matériel de sécurisation.
2) avant l'étape a), le code d'authentification du bloc de lignes de code chiffrées et authentifiées à enregistrer, est aussi calculé à partir des métadonnées.
3) avant l'étape a), le procédé comporte :
- le chiffrement du bloc de lignes de code en clair en utilisant un vecteur d'initialisation et la génération d'un nouveau vecteur d'initialisation avant chaque chiffrement du bloc de lignes de code en clair, et
- l'incorporation dans les métadonnées du bloc de lignes de code chiffrées et authentifiées, du vecteur d'initialisation utilisé pour obtenir le cryptogramme de ce bloc de lignes de code chiffrées et authentifiées, et
- lors du déchiffrement du cryptogramme, le module matériel de sécurisation extrait des métadonnées du bloc de lignes de code chiffrées et authentifiées, le vecteur d'initialisation à utiliser pour réaliser ce déchiffrement.
4) lors de l'étape a), l'adresse à laquelle est enregistrée le bloc de lignes de code chiffrées et authentifiées est reliée, par une fonction bijective, à une adresse @BDCidéfinie par la relation suivante : @BDCi= @BDi.Tb/TBD, où :
- @BDiest l'adresse où débute, dans l'espace d'adressage du programme d'ordinateur, le bloc de lignes de code en clair,
- Tbest la taille, en nombre d'octets, du bloc de lignes de code chiffrées et authentifiées,
- TBDest la taille, en nombre d'octets, du bloc de lignes de code en clair.
5)
- après l'étape b) et avant l'étape c), le module matériel de sécurisation détermine l'adresse @BDCià l'aide de la première relation suivante : @BDCi= E(@Di,j/TBD).Tb, où
- E() est la fonction qui retourne la partie entière du nombre situé entre les parenthèses, et
- @Di,jest l'adressecontenue dans le pointeur obtenu à l'étape b),
- T b et T BD sont tous les deux des puissances de deux,
lors de cette détermination, la division et la multiplication de la première relation sont exécutées par des registres à décalage du module matériel de sécurisation,puis
- lors de l'étape c), le bloc contenant la ligne de code à accéder est chargé, depuis la mémoire chiffrée, à partir de l'adresse reliée, par la fonction bijective, à l'adresse @BDCidéterminée.
6)
- après l'étape b) et avant l'étape c), le module matériel de sécurisation détermine l'adresse @BDCià l'aide de la seconde relation suivante :@ BDCi = E(@ Di,j /T BD ).T BD + E(@ Di,j /T BD ).(T b -T BD ), où
- E() est la fonction qui retourne la partie entière du nombre situé entre les parenthèses, et
- @Di,jest l'adressecontenue dans le pointeur obtenu à l'étape b),
- (Tb-TBD) et TBDsont tous les deux des puissances de deux,
lors de cette détermination, chaque division et chaque multiplication de la seconde relation sont exécutées par des registres à décalage du module matériel de sécurisation, et
- lors de l'étape c), le bloc contenant la ligne de code à accéder est chargé, depuis la mémoire chiffrée, à partir de l'adresse reliée, par la fonction bijective, à l'adresse @BDCidéterminée.
Embodiments of this method of execution may include one or more of the following features:
1) step e) comprises the recording of the first pointer identifier contained in the metadata of the block loaded in a memory only accessible by the hardware security module.
2) before step a), the authentication code of the block of encrypted and authenticated lines of code to be recorded is also calculated from the metadata.
3) before step a), the method comprises:
- encrypting the block of plaintext lines of code using an initialization vector and generating a new initialization vector before each encryption of the block of plaintext lines of code, and
- the incorporation in the metadata of the block of encrypted and authenticated lines of code, of the initialization vector used to obtain the cryptogram of this block of encrypted and authenticated lines of code, and
- During the decryption of the cryptogram, the hardware security module extracts metadata from the block of encrypted and authenticated lines of code, the initialization vector to be used to perform this decryption.
4) during step a), the address at which the block of encrypted and authenticated lines of code is stored is linked, by a one-to-one function, to an address @ BDCi defined by the following relationship: @ BDCi = @ BDi .T b /T BD , where:
- @ BDi is the address where the block of lines of plain code begins, in the address space of the computer program,
- T b is the size, in number of bytes, of the block of encrypted and authenticated lines of code,
- T BD is the size, in number of bytes, of the block of plain code lines.
5)
- after step b) and before step c), the hardware security module determines the address @ BDCi using the following first relation: @ BDCi = E(@ Di,j /T BD ). T b , where
- E() is the function that returns the integer part of the number located between the parentheses, and
- @ Di,j is the address contained in the pointer obtained in step b),
- T b and T BD are both powers of two,
during this determination, the division and the multiplication of the first relation are executed by shift registers of the security hardware module, then
- During step c), the block containing the line of code to be accessed is loaded, from the encrypted memory, from the address connected, by the one-to-one function, to the determined address @BDCi .
6)
- after step b) and before step c), the hardware security module determines the address @ BDCi using the following second relationship: @ BDCi = E(@ Di,j /T BD ). T BD + E(@ Di,j /T BD ).(T b -T BD ) , where
- E() is the function that returns the integer part of the number located between the parentheses, and
- @ Di,j is the address contained in the pointer obtained in step b),
- (T b -T BD ) and T BD are both powers of two,
during this determination, each division and each multiplication of the second relation are executed by shift registers of the security hardware module, and
- During step c), the block containing the line of code to be accessed is loaded, from the encrypted memory, from the address connected, by the one-to-one function, to the determined address @BDCi .

L’invention a également pour objet un programme d'ordinateur apte à être exécuté par un microprocesseur en mettant en œuvre le procédé ci-dessus, dans lequel le code binaire du programme d'ordinateur comporte :
- un bloc de lignes de code chiffrées et authentifiées contenant une ligne de code à accéder à l'aide d'un pointeur respectif, ce bloc de lignes de code chiffrées et authentifiées contenant :
- un cryptogramme de l'ensemble des lignes de code de ce bloc, ce cryptogramme pouvant uniquement être déchiffré dans sa totalité pour obtenir un bloc de lignes de code en clair et non pas ligne de code par ligne de code,
- un code d'authentification calculé à partir du bloc de lignes de code en clair ou à partir du cryptogramme du bloc de lignes de code en clair, et
-des métadonnées,
- un pointeur contenant l’adresse à laquelle est enregistrée la ligne de code à accéder
dans lequel:
- les métadonnées comporte un premier identifiant de pointeur associé à la ligne de code à accéder, ce premier identifiant de pointeur permettant à lui seul d’identifier de façon unique un pointeur parmi un ensemble contenant plusieurs pointeurs différents mis en œuvre lors de la même exécution du programme d'ordinateur par le microprocesseur, et
- le pointeur comprend :
- une première plage de bits contenant l’adresse de la ligne de code à accéder, et
- une seconde plage différente de bits contenant un second identifiant de pointeur, ce second identifiant de pointeur étant égal au premier identifiant de pointeur.
The invention also relates to a computer program capable of being executed by a microprocessor by implementing the above method, in which the binary code of the computer program comprises:
- a block of encrypted and authenticated lines of code containing a line of code to be accessed using a respective pointer, this block of encrypted and authenticated lines of code containing:
- a cryptogram of all the lines of code of this block, this cryptogram can only be deciphered in its entirety to obtain a block of lines of code in plain text and not line of code by line of code,
- an authentication code calculated from the block of plaintext lines of code or from the cryptogram of the block of plaintext lines of code, and
- metadata,
- a pointer containing the address at which the line of code to be accessed is stored
in which:
- the metadata includes a first pointer identifier associated with the line of code to be accessed, this first pointer identifier alone making it possible to uniquely identify a pointer from among a set containing several different pointers implemented during the same execution of the computer program by the microprocessor, and
- the pointer includes:
- a first range of bits containing the address of the line of code to be accessed, and
- a second different range of bits containing a second pointer identifier, this second pointer identifier being equal to the first pointer identifier.

L’invention a également pour objet un module matériel de sécurisation pour la mise en œuvre du procédé d'exécution ci-dessus, dans lequel le module matériel est configuré pour :
a) déclencher l'enregistrement dans la mémoire chiffrée d'un bloc de lignes de code chiffrées et authentifiées contenant une ligne de code à accéder à l'aide d'un pointeur, ce bloc de lignes de code chiffrées et authentifiées contenant :
- un cryptogramme de l'ensemble des lignes de code de ce bloc, ce cryptogramme pouvant uniquement être déchiffré dans sa totalité pour obtenir un bloc de lignes de code en clair et non pas ligne de code par ligne de code,
- un code d'authentification calculé à partir du bloc de lignes de code en clair ou à partir du cryptogramme du bloc de lignes de code en clair, et
-des métadonnées,
b) recevoir un pointeur contenant l’adresse à laquelle est enregistrée la ligne de code à accéder, puis
c) déclencher le chargement du bloc contenant la ligne de code à accéder depuis la mémoire chiffrée vers le microprocesseur, puis
d) vérifier, à l'aide du code d'authentification contenu dans le bloc chargé, l'intégrité :
- du bloc de lignes de codes en clair obtenu à partir du cryptogramme contenu dans le bloc chargé, ou
- du cryptogramme contenu dans le bloc chargé,
e) lorsque cette vérification échoue, inhiber le traitement, par le microprocesseur, des lignes de code de ce bloc chargé et, lorsque cette vérification réussie :
- déchiffrer le cryptogramme contenu dans le bloc chargé pour obtenir le bloc de lignes de code en clair, et
- déclencher l'enregistrement du bloc de lignes de code en clair obtenu dans la mémoire déchiffrée et l'enregistrement des métadonnées du bloc chargé,
dans lequel le module de sécurisation est également configuré :
- pour incorporer, dans les métadonnées du bloc contenant la ligne de code à accéder, un premier identifiant de pointeur associé à la ligne de code à accéder, ce premier identifiant de pointeur permettant à lui seul d’identifier de façon unique un pointeur parmi un ensemble contenant plusieurs pointeurs différents mis en œuvre lors de la même exécution du programme d'ordinateur par le microprocesseur,
- en réponse à l'exécution d'une instruction d'accès à la ligne de code à accéder à l'aide d'un pointeur, pour extraire un second identifiant de pointeur dans une plage de bits de ce pointeur, puis
- pour vérifier que le second identifiant de pointeur correspond au premier identifiant de pointeur associé à la ligne de code à accéder et contenu dans les métadonnées du bloc chargé, et si les premier et second identifiants de pointeur ne correspondent pas, alors déclencher le signalement d'une faute d'exécution et, dans le cas contraire, inhiber le déclenchement du signalement d'une faute d'exécution et autoriser le microprocesseur à traiter la ligne de code à accéder.
The invention also relates to a hardware security module for implementing the above execution method, in which the hardware module is configured to:
a) triggering the recording in the encrypted memory of a block of encrypted and authenticated lines of code containing a line of code to be accessed using a pointer, this block of encrypted and authenticated lines of code containing:
- a cryptogram of all the lines of code of this block, this cryptogram can only be deciphered in its entirety to obtain a block of lines of code in plain text and not line of code by line of code,
- an authentication code calculated from the block of plaintext lines of code or from the cryptogram of the block of plaintext lines of code, and
- metadata,
b) receive a pointer containing the address at which the line of code to be accessed is stored, then
c) trigger the loading of the block containing the line of code to be accessed from the encrypted memory to the microprocessor, then
d) verify, using the authentication code contained in the loaded block, the integrity:
- the block of plain code lines obtained from the cryptogram contained in the loaded block, or
- the cryptogram contained in the loaded block,
e) when this verification fails, inhibit the processing, by the microprocessor, of the lines of code of this loaded block and, when this verification succeeds:
- decrypt the cryptogram contained in the loaded block to obtain the block of lines of code in clear, and
- trigger the recording of the block of plain code lines obtained in the decrypted memory and the recording of the metadata of the loaded block,
in which the security module is also configured:
- to incorporate, in the metadata of the block containing the line of code to be accessed, a first pointer identifier associated with the line of code to be accessed, this first pointer identifier alone making it possible to uniquely identify a pointer among a set containing several different pointers implemented during the same execution of the computer program by the microprocessor,
- in response to executing an instruction to access the line of code to be accessed using a pointer, to extract a second pointer identifier within a bit range of that pointer, then
- to verify that the second pointer identifier matches the first pointer identifier associated with the line of code to be accessed and contained in the metadata of the loaded block, and if the first and second pointer identifiers do not match, then trigger the flag d an execution fault and, in the contrary case, inhibit the triggering of the signaling of an execution fault and authorize the microprocessor to process the line of code to be accessed.

L'invention sera mieux comprise à la lecture de la description qui va suivre, donnée uniquement à titre d'exemple non limitatif et faite en se référant aux dessins sur lesquels :
- la est une illustration schématique de l'architecture d'un appareil électronique apte à exécuter un code binaire d'un programme d'ordinateur,
- la est une illustration schématique d'une partie d'une mémoire principale de l'appareil de la ,
- la est une illustration schématique de la structure d'un bloc de données chiffrées et authentifiées contenu dans la partie de la mémoire de la ,
- la est une illustration schématique de la structure d'un pointeur enrichi utilisé lors de l'exécution du code binaire par l'appareil de la ,
- la est un organigramme d'un procédé d'exécution du code binaire par l'appareil de la ,
- la est un organigramme d'un procédé détaillant les opérations réalisées lorsque l'instruction exécutée du code binaire est une instruction de chargement ou d'écriture d'une donnée,
- la est une illustration schématique d'un compilateur apte à générer le code binaire exécuté par l'appareil de la .
The invention will be better understood on reading the following description, given solely by way of non-limiting example and made with reference to the drawings in which:
- the is a schematic illustration of the architecture of an electronic device capable of executing a binary code of a computer program,
- the is a schematic illustration of part of a main device memory of the ,
- the is a schematic illustration of the structure of a block of encrypted and authenticated data contained in the memory portion of the ,
- the is a schematic illustration of the structure of a rich pointer used when executing binary code by the device of the ,
- the is a flowchart of a method of executing binary code by the apparatus of the ,
- the is a flowchart of a process detailing the operations carried out when the binary code instruction executed is a data loading or writing instruction,
- the is a schematic illustration of a compiler able to generate the binary code executed by the apparatus of the .

Les conventions, notations et définitions utilisées dans cette description sont données dans le chapitre I. Ensuite, un exemple détaillé de mode de réalisation est décrit dans le chapitre II à l'aide des figures. Dans un chapitre III suivant, des variantes de ce mode de réalisation détaillé sont présentées. Enfin, les avantages des différents modes de réalisation sont présentés dans un chapitre IV.The conventions, notations and definitions used in this description are given in chapter I. Next, a detailed example of an embodiment is described in chapter II using the figures. In a following chapter III, variants of this detailed embodiment are presented. Finally, the advantages of the various embodiments are presented in a chapter IV.

Chapitre I : Conventions, notations et définitions :Chapter I: Conventions, notations and definitions:

Dans les figures, les mêmes références sont utilisées pour désigner les mêmes éléments. Dans la suite de cette description, les caractéristiques et fonctions bien connues de l’homme du métier ne sont pas décrites en détails.In the figures, the same references are used to designate the same elements. In the rest of this description, the characteristics and functions well known to those skilled in the art are not described in detail.

Dans cette description, les définitions suivantes sont adoptées.In this description, the following definitions are adopted.

Un « programme » désigne un ensemble d'une ou de plusieurs fonctions prédéterminées que l'on souhaite faire exécuter par un microprocesseur.A “program” designates a set of one or more predetermined functions that one wishes to have executed by a microprocessor.

Un « code source » est une représentation du programme dans un langage informatique. Le code source n'est pas directement exécutable par un microprocesseur. Le code source est destiné à être transformé par un compilateur en un code binaire directement exécutable par le microprocesseur.A “source code” is a representation of the program in a computer language. The source code is not directly executable by a microprocessor. The source code is intended to be transformed by a compiler into a binary code directly executable by the microprocessor.

Un programme ou un code est dit être « directement exécutable » lorsqu'il est apte à être exécuté par un microprocesseur sans que ce microprocesseur n'ait besoin au préalable de le compiler au moyen d'un compilateur ou de l'interpréter au moyen d'un interpréteur.A program or a code is said to be "directly executable" when it is able to be executed by a microprocessor without this microprocessor needing to compile it beforehand by means of a compiler or to interpret it by means of an interpreter.

Une « instruction » désigne une instruction machine exécutable par un microprocesseur. Une telle instruction est constituée :
- d'un opcode, ou code d'opération, codant la nature de l'opération à exécuter, et
-d'un ou plusieurs opérandes définissant la ou les valeurs des paramètres de cette opération.
An "instruction" means a machine instruction executable by a microprocessor. Such an instruction consists of:
- an opcode, or operation code, encoding the nature of the operation to be performed, and
-one or more operands defining the value or values of the parameters of this operation.

Le jeu d'instructions machines d'un microprocesseur est formé par l'ensemble des opcodes utilisables pour former des instructions exécutables par le microprocesseur. Le jeu d'instructions machines peut être différent d'un microprocesseur à un autre.The machine instruction set of a microprocessor is formed by the set of opcodes that can be used to form instructions that can be executed by the microprocessor. The machine instruction set may be different from one microprocessor to another.

Un « code machine » est un ensemble d'instructions machines. Il s'agit typiquement d'un fichier contenant une succession de bits portant la valeur « 0 » ou « 1 », ces bits codant les instructions à exécuter par le microprocesseur. Le code machine est directement exécutable par le microprocesseur, c'est-à-dire sans nécessiter une compilation ou une interprétation préalable.A “machine code” is a set of machine instructions. It is typically a file containing a succession of bits carrying the value “0” or “1”, these bits encoding the instructions to be executed by the microprocessor. The machine code is directly executable by the microprocessor, that is to say without requiring prior compilation or interpretation.

Un « code binaire » est un fichier contenant une succession de bits portant la valeur « 0 » ou « 1 ». Ces bits codent des données et des instructions à exécuter par le microprocesseur. Ainsi, le code binaire comprend au moins un code machine et en plus, généralement, des données numériques traitées par ce code machine.A “binary code” is a file containing a succession of bits carrying the value “0” or “1”. These bits encode data and instructions to be executed by the microprocessor. Thus, the binary code comprises at least one machine code and in addition, generally, digital data processed by this machine code.

Pour être exécuté par un microprocesseur, le code binaire est enregistré dans des lignes d'une mémoire principale. Typiquement, le code binaire comporte plusieurs centaines ou milliers de lignes. Ici, chacune de ces lignes est appelée "ligne de code". Chaque ligne de code est enregistrées à une adresse qui lui est propre dans la mémoire principale. Chaque ligne de code contient une seule instruction ou une seule donnée. Par la suite, lorsque le code contenu dans la ligne de code correspond à une instruction, cette ligne de code est simplement appelée "instruction". Lorsque le code contenu dans la ligne de code correspond une donnée, la ligne de code est simplement appelée "donnée". Le terme "ligne de code" est utilisé pour désigner aussi bien une donnée qu'une instruction.To be executed by a microprocessor, the binary code is stored in lines of a main memory. Typically, the binary code has several hundreds or thousands of lines. Here, each of these lines is referred to as a "line of code". Each line of code is stored at its own address in the main memory. Each line of code contains a single instruction or data. Thereafter, when the code contained in the line of code corresponds to an instruction, this line of code is simply called "instruction". When the code contained in the line of code matches a data, the line of code is simply called "data". The term "line of code" is used to designate both a data item and an instruction.

Au niveau du code binaire, une instruction et une donnée correspondent tous les deux à des bits. Toutefois, les instructions et les données ne sont pas traitées de la même façon par un microprocesseur. Par exemple, une instruction est seulement chargée puis exécutée par le microprocesseur lorsque le compteur ordinal pointe sur cette instruction. Une donnée est chargée par le microprocesseur seulement en réponse à l'exécution par ce microprocesseur d'une instruction de chargement de cette donnée.At the binary code level, an instruction and a data both correspond to bits. However, instructions and data are not treated in the same way by a microprocessor. For example, an instruction is only loaded and then executed by the microprocessor when the ordinal counter points to this instruction. A datum is loaded by the microprocessor only in response to the execution by this microprocessor of an instruction for loading this datum.

On parle d'exécution d'une fonction pour désigner l'exécution des instructions réalisant cette fonction.One speaks of execution of a function to designate the execution of the instructions carrying out this function.

Chapitre II : Exemple de mode de réalisation détaillé :Chapter II: Example of detailed embodiment:

La représente un appareil électronique 1 comportant un microprocesseur 2, un ensemble 4 de mémoires et un support 6 de stockage de masse. Par exemple, l'appareil 1 est un ordinateur, un smartphone, une tablette électronique ou similaire.The represents an electronic device 1 comprising a microprocessor 2, a set of memories 4 and a medium 6 for mass storage. For example, device 1 is a computer, smartphone, tablet computer or the like.

Le microprocesseur 2 comporte ici :
- une unité arithmétique et logique 10 ;
- un ensemble 12 de registres ;
- un tampon 14 de données ;
- une interface 16 d'entrée/sortie de lignes de code,
- un chargeur 18 d'instructions comportant un compteur ordinal 26,
- une file 22 d'instructions à exécuter, et
- un module matériel 28 de sécurisation comportant une mémoire non-volatile sécurisée 29.
The microprocessor 2 comprises here:
- an arithmetic and logic unit 10;
- A set 12 of registers;
- A data buffer 14;
- a 16 lines of code input/output interface,
- an instruction loader 18 comprising an ordinal counter 26,
- a queue 22 of instructions to be executed, and
- a security hardware module 28 comprising a secure non-volatile memory 29.

L'ensemble 4 est configuré pour stocker les lignes de code d'un code binaire 30 d'un programme devant être exécuté par le microprocesseur 2. L'ensemble 4 est une mémoire à accès aléatoire. Typiquement, l'ensemble 4 est une mémoire volatile. Chaque ligne de code est associée à une adresse physique qui est utilisée pour la charger ou l'écrire sans modifier les autres lignes de code. Ainsi, par la suite, on dit que ces lignes de code sont adressables individuellement. A titre d'illustration, dans ce mode de réalisation, les lignes de code sont chacune codées sur 64 bits et sont donc chacune formée par huit octets. Par la suite, la taille d'une ligne de code, en nombre d'octets, est notée Td.Set 4 is configured to store the lines of code of a binary code 30 of a program to be executed by microprocessor 2. Set 4 is a random access memory. Typically, set 4 is volatile memory. Each line of code is associated with a physical address which is used to load or write it without modifying the other lines of code. Thus, in the following, these lines of code are said to be individually addressable. By way of illustration, in this embodiment, the lines of code are each coded on 64 bits and are therefore each formed by eight bytes. Subsequently, the size of a line of code, in number of bytes, is denoted T d .

Ici, chaque ligne de code est aussi associée à une adresse virtuelle dans l'espace d'adressage du programme d'ordinateur. Il existe une relation bijective qui relie chaque adresse virtuelle d'une ligne de code à l'adresse physique de cette même ligne de code. La conversion d'une adresse virtuelle en adresse physique est typiquement réalisée par une unité de management de mémoire connue sous l'acronyme MMU ("Management Memory Unit").Here, each line of code is also associated with a virtual address in the computer program's address space. There is a one-to-one relation that connects each virtual address of a line of code to the physical address of this same line of code. The conversion of a virtual address into a physical address is typically carried out by a memory management unit known by the acronym MMU (“Management Memory Unit”).

Par exemple, l'ensemble 4 comporte :
- trois niveaux de mémoires caches, et
- une mémoire principale MP.
For example, set 4 includes:
- three levels of cache memories, and
- a main MP memory.

Les mémoires caches permettent d'accélérer le transfert de données entre la mémoire principale MP et le microprocesseur 2. Les trois niveaux de mémoire cache sont appelés habituellement L1, L2 et L3. Sur la , les symboles "L1", "L2" et "L3" sont utilisés pour désigner, respectivement, les trois mémoires caches L1, L2 et L3. Ici, pour simplifier la , la mémoire cache L1 est représentée à l'extérieur du microprocesseur 2 alors que, souvent, elle est intégrée à l'intérieur du microprocesseur 2. Les mémoires L1 à L3 sont classées par ordre de rapidité de lecture, la mémoire L1 étant la plus rapide. Généralement, la taille des mémoires cache est inversement proportionnelle à leur rapidité.The cache memories make it possible to accelerate the transfer of data between the main memory MP and the microprocessor 2. The three levels of cache memory are usually called L1, L2 and L3. On the , the symbols "L1", "L2" and "L3" are used to designate, respectively, the three cache memories L1, L2 and L3. Here, to simplify the , the cache memory L1 is represented outside the microprocessor 2 whereas, often, it is integrated inside the microprocessor 2. The memories L1 to L3 are classified in order of speed of reading, the memory L1 being the most fast. Generally, the size of cache memories is inversely proportional to their speed.

Classiquement, après le chargement du code binaire 30 dans la mémoire MP, la mémoire MP comporte notamment les parties suivantes :
- une première partie 42 contenant les instructions à exécuter,
- une deuxième partie 44 contenant des données à traiter,
- une troisième partie 46 utilisée pour sauvegarder le contexte d'exécution d'une fonction lorsqu'elle appelle une autre fonction, et
- une quatrième partie 48 utilisée pour allouer dynamiquement de la mémoire au programme en cours d'exécution afin d'y enregistrer des données.
Conventionally, after the loading of the binary code 30 into the memory MP, the memory MP comprises in particular the following parts:
- a first part 42 containing the instructions to be executed,
- a second part 44 containing data to be processed,
- a third part 46 used to save the execution context of a function when it calls another function, and
- a fourth part 48 used to dynamically allocate memory to the program being executed in order to save data therein.

La partie 42 est connue sous le terme de "segment de code" ("code segment" ou "text segment" en anglais).Part 42 is known by the term "code segment" ("code segment" or "text segment" in English).

La partie 44 contient typiquement les variables statiques et globales du programme exécuté. La partie 44 est elle-même classiquement divisée en une première et une seconde sections. La première section contient les variables statiques est globales qui ont été initialisées lors de la compilation. Cette première section est connue sous le terme de segment de données et souvent notée ".data". La seconde section comporte les variables statiques et globales qui n'ont pas été initialisées lors de la compilation du code binaire 30. Cette seconde section est également connue sous le terme de "segment bss" et souvent notée ".bss". Généralement, ces deux sections sont contiguës.Part 44 typically contains the static and global variables of the executed program. Part 44 is itself conventionally divided into a first and a second section. The first section contains static and global variables that were initialized during compilation. This first section is known as the data segment and is often denoted ".data". The second section comprises the static and global variables which were not initialized during the compilation of the binary code 30. This second section is also known by the term "bss segment" and often denoted ".bss". Generally, these two sections are contiguous.

La partie 46 est connue sous le terme de "pile d'exécution" ("call stack" en anglais). Par conséquent, par la suite, la partie 46 est également appelée "pile 46". Enfin la partie 48 est connue sous le terme de "tas" ("heap" en anglais). Ainsi, par la suite, la partie 48 est également appelée "tas 48".Part 46 is known as the "call stack". Hence, in the following, part 46 is also referred to as "battery 46". Finally part 48 is known by the term "heap" ("heap" in English). Thus, in the following, part 48 is also called "heap 48".

Le code binaire 30 comporte notamment un code machine 32 et un bloc 34 de données nécessaires à l'exécution du code binaire 30. Le code machine 32 et le bloc 34 sont enregistrés dans, respectivement, les parties 42 et 44.The binary code 30 notably comprises a machine code 32 and a block 34 of data necessary for the execution of the binary code 30. The machine code 32 and the block 34 are recorded in, respectively, the parts 42 and 44.

L'exécution du code binaire 30 débute par le chargement et le traitement de données du bloc 34. Ici, en particulier, le bloc 34 comporte un cryptogramme ka* obtenu en chiffrant une clé secrète ka à l'aide d'une clé publique pkCPUdu microprocesseur 2.The execution of the binary code 30 begins with the loading and processing of data from block 34. Here, in particular, block 34 comprises a cryptogram ka* obtained by encrypting a secret key ka using a public key pk Microprocessor CPU 2.

L'ensemble 4 de mémoire est raccordé au microprocesseur 2 par un bus de données et un bus d'adresses. Pour simplifier la , ces deux bus sont représentés par une double flèche 50 et désignés collectivement dans la suite de cette description par le terme "bus 50".The memory assembly 4 is connected to the microprocessor 2 by a data bus and an address bus. To simplify the , these two buses are represented by a double arrow 50 and collectively designated in the remainder of this description by the term "bus 50".

La taille du bus d'adresses détermine la taille N@, en nombre de bits, des adresses utilisées pour accéder à la mémoire 4. Typiquement, la taille N@est supérieure ou égale à 8, 16, 32 ou 64 bits. Par exemple, dans ce mode de réalisation, la taille N@est égale à 64 bits.The size of the address bus determines the size N @ , in number of bits, of the addresses used to access memory 4. Typically, the size N @ is greater than or equal to 8, 16, 32 or 64 bits. For example, in this embodiment, the size N @ is equal to 64 bits.

L'ensemble 4 est un ensemble de mémoires chiffrées, c'est-à-dire un ensemble dans lequel les lignes de code sont enregistrées sous forme chiffrée. Par la suite, la description est faite dans le cas particulier où les lignes de code chiffrées sont des données contenues dans la partie 44.Set 4 is a set of encrypted memories, that is to say a set in which the lines of code are recorded in encrypted form. Subsequently, the description is made in the particular case where the encrypted lines of code are data contained in the part 44.

Un découpage en blocs de données chiffrées et authentifiées de la partie 44 est représenté sur la . Dans cette figure et dans la suite de la description, on note "BDCi" un bloc de données chiffrées et authentifiées, enregistré dans la mémoire MP à l'adresse @BDCi, où l'indice i est un identifiant de ce bloc BDCi. Ici, l'indice i est le numéro d'ordre du bloc de données compté à partir du premier bloc BDC1, c'est-à-dire celui situé au début de la partie 44. L'adresse @BDCi est ici égale à l'adresse à laquelle débute le bloc BDCi. Dans cet exemple, l'indice i varie de 1 à n de sorte que la partie 44 est divisée en n blocs BDCi distincts. Sur la et les suivantes, le symbole "..." indique qu'une partie des éléments n'a pas été représentée.A division into blocks of encrypted and authenticated data of part 44 is represented on the . In this figure and in the rest of the description, “BDCi” denotes a block of encrypted and authenticated data, recorded in the memory MP at the address @BDCi, where the index i is an identifier of this block BDCi. Here, the index i is the sequence number of the data block counted from the first block BDC1, that is to say the one located at the beginning of part 44. The address @BDCi is here equal to l address at which the BDCi block begins. In this example, the index i varies from 1 to n so that the part 44 is divided into n distinct blocks BDCi. On the and the following, the symbol "..." indicates that some of the elements have not been represented.

Ici, tous les blocs BDCi sont structurellement identiques. Ainsi, seul le bloc BDCi représenté sur la est décrit en détail. La taille du bloc BDCi en nombre d'octets est noté Tb par la suite. La taille Tb est supérieure à huit ou seize et, généralement supérieur ou égale à 32 ou 64 octets. Généralement, la taille Tb est inférieure à 1 ko ou 1 Mo. Dans ce premier mode de réalisation, à titre d'illustration la taille Tb est égal à 128 octets.Here, all BDCi blocks are structurally identical. Thus, only the BDCi block represented on the is described in detail. The size of the block BDCi in number of bytes is denoted Tb thereafter. The size Tb is greater than eight or sixteen and generally greater than or equal to 32 or 64 bytes. Generally, the size Tb is less than 1 KB or 1 MB. In this first embodiment, by way of illustration the size Tb is equal to 128 bytes.

Le bloc BDCicomporte, dans l'ordre en partant de son adresse @BDCide début :
- un cryptogramme BDi*,
- des métadonnées MDi, et
- un code d'authentification MACi,
Block BDC i comprises, in order starting from its start address @ BDCi :
- a BD i * cryptogram,
- MD i metadata, and
- a MAC i authentication code,

Le cryptogramme BDi* est obtenu en chiffrant un bloc BDide Nddonnées Di,jen clair à l'aide de la clé cryptographique ka, où Ndest un nombre entier supérieur à un ou deux ou quatre. Ici, le nombre Ndest égal à huit. L'indice j est un identifiant de la donnée Di,jqui permet de la distinguer des autres données contenues dans le même bloc BDi. Ici, l'indice j est le numéro d'ordre de la donnée Di,jcompté à partir de la première donnée Di,1du bloc BDi, c'est-à-dire à partir de la donnée Di,1situé à l'adresse @BDi à laquelle débute le bloc BD i.The cryptogram BD i * is obtained by encrypting a block BD i of N d data D i,j in clear using the cryptographic key ka, where N d is an integer greater than one or two or four. Here, the number N d is equal to eight. The index j is an identifier of the data D i,j which makes it possible to distinguish it from the other data contained in the same block BD i . Here, the index j is the sequence number of the data D i,j counted from the first data D i,1 of the block BD i , that is to say from the data D i, 1 located at the address @ BDi at which the block BD i begins.

Plus précisément, le cryptogramme BDi* est obtenu à l’aide de la relation suivante : BDi* = fka(BDi; ivi), où :
- fkaest une fonction de chiffrement, correspondant à une fonction de déchiffrement fka -1 , et
- iv i est un vecteur d'initialisation également connu sous le nom de "nonce".
More precisely, the cryptogram BD i * is obtained using the following relationship: BD i * = f ka (BD i ; iv i ), where:
- f ka is an encryption function, corresponding to a decryption function f ka -1 , and
- iv i is an initialization vector also known as a "nonce".

Les fonctions fkaet fka -1sont préprogrammées dans le module 28. Typiquement, la fonction fkaest une fonction de chiffrement symétrique.Functions f ka and f ka -1 are preprogrammed in module 28. Typically, function f ka is a symmetric encryption function.

Le vecteur iviest un vecteur d'initialisation dont la valeur est modifiée à chaque fois que la fonction fkaest utilisée pour chiffrer un bloc BDide données en clair. A l'inverse, la clé ka est toujours la même. Dès lors, la clé ka permettant de déchiffrer le cryptogramme BDi* est préenregistrée dans la mémoire 29 afin de permettre au module 28 de déchiffrer chaque cryptogramme BDi*.The vector iv i is an initialization vector whose value is modified each time the function f ka is used to encrypt a block BD i of plain data. Conversely, the key ka is always the same. Therefore, the key ka allowing decryption of the cryptogram BD i * is prerecorded in the memory 29 in order to allow the module 28 to decrypt each cryptogram BD i *.

Dans ce mode de réalisation, chaque bloc BDicontient Nddonnées Di,jassociées à des adresses virtuelles respectives et consécutives. Par la suite, l'adresse virtuelle d'une donnée Di,jest notée @Di,j. Chaque bloc BDicorrespond donc à une plage continue de Ndadresses virtuelles consécutives. Ces plages d'adresses virtuelles sont distinctes les unes des autres. En particulier, elles ne se chevauchent pas de sorte qu'une même donnée Di,jne peut pas être contenue dans plusieurs blocs BDidifférents. De plus, ces plages d'adresses sont contiguës les unes aux autres de sorte qu'il n'existe pas, entre un premier bloc BDiet un second bloc BDi+1contigus, des données qui n'appartiennent ni au bloc BDini au bloc BDi+1. Ainsi, les blocs BDiforment, dans l'espace d'adressage du programme d'ordinateur, une succession de blocs de données consécutifs. A l'intérieur d'un même bloc BDi, les Nddonnées Di,jsont, par exemple, classées par ordre d'adresses croissantes de sorte que la donnée Di,1est la première donnée du bloc BDi. Dans ces conditions, l'adresse @BDide début du bloc BDiest égale à l'adresse @Di,1de la donnée Di,1.In this embodiment, each block BD i contains N d data D i,j associated with respective and consecutive virtual addresses. Subsequently, the virtual address of a data item D i,j is denoted @ Di,j . Each block BD i therefore corresponds to a continuous range of N consecutive virtual addresses. These virtual address ranges are distinct from each other. In particular, they do not overlap so that the same data D i,j cannot be contained in several different blocks BD i . Moreover, these address ranges are contiguous to each other so that there does not exist, between a first block BD i and a second contiguous block BD i+1 , data which does not belong either to the block BD i ni to block BD i+1 . Thus, the blocks BD i form, in the address space of the computer program, a succession of consecutive data blocks. Within the same block BD i , the N d data items D i,j are, for example, classified in order of increasing addresses so that the data item D i,1 is the first data item of the block BD i . Under these conditions, the start address @ BDi of the block BD i is equal to the address @ Di,1 of the data item D i,1 .

La taille TBDdu bloc BDiest égale à NdTd, où Tdest la taille d'une donnée Di,jen nombre d'octets. Ici, la taille du cryptogramme BDi *est égale à la taille du bloc BDi.The size T BD of the block BD i is equal to N d T d , where T d is the size of a datum D i,j in number of bytes. Here, the size of the cryptogram BD i * is equal to the size of the block BD i .

Les métadonnées MDicontiennent ici:
- pour chaque donnée Di,j, un emplacement réservé pour y enregistrer les bits d'un identifiant de pointeur IPi,j associé spécifiquement à cette donnée D i,j, et
- le vecteur iviutilisé pour obtenir le cryptogramme BDi*.
MD i metadata contains here:
- for each datum D i,j , a space reserved for storing the bits of an IP pointer identifier i,j specifically associated with this datum D i,j , and
- the vector iv i used to obtain the cryptogram BD i *.

Dans les métadonnées MDi, il y a autant d'emplacements réservés pour y enregistrer un identifiant de pointeur qu'il y a de données Di,j dans le bloc BDi. Sur la , chacun de ces emplacements est désignés par la référence "IPi,j" de l'identifiant IPi,j qu'il est destiné à contenir. Ici, la taille de chaque identifiant IPi,j, et donc la taille de chaque emplacement réservé, est égale à 8 bits.In the metadata MDi, there are as many places reserved for recording a pointer identifier there as there are data Di,j in the block BDi. On the , each of these locations is designated by the reference "IPi,j" of the identifier IPi,j that it is intended to contain. Here, the size of each identifier IPi,j, and therefore the size of each reserved slot, is equal to 8 bits.

L'identifiant IPi,jest un identifiant qui permet d'identifier de façon unique un pointeur PDi,jparmi un ensemble d'autres pointeurs utilisés lors de la même exécution du code binaire 30. Le pointeur PDi,jest un pointeur qui contient l'adresse de la donnée Di,jet qui permet d'accéder à cette donnée.The identifier IP i,j is an identifier which makes it possible to uniquely identify a pointer PD i,j among a set of other pointers used during the same execution of the binary code 30. The pointer PD i,j is a pointer which contains the address of data D i,j and which allows access to this data.

L'identifiant IPi,jest construit de manière à limiter la probabilité que deux pointeurs différents aient le même identifiant de pointeur. Par exemple, les identifiants de pointeurs sont construits pour que cette probabilité soit inférieure à une chance sur dix et, de préférence, une chance sur cinquante ou une chance sur cent ou une chance sur mille.The IP identifier i,j is constructed in such a way as to limit the probability that two different pointers have the same pointer identifier. For example, pointer identifiers are constructed so that this probability is less than one chance in ten and, preferably, one chance in fifty or one chance in one hundred or one chance in one thousand.

L'identifiant IPi,jpeut être généré soit lors de la compilation du code source pour obtenir le code binaire 30 soit dynamiquement lors de l'exécution du code binaire 30.The IP identifier i,j can be generated either during the compilation of the source code to obtain the binary code 30 or dynamically during the execution of the binary code 30.

Par exemple, lorsque le pointeur PDi,jest déclaré dans le code source, l'identifiant IPi,jest généré lors de la compilation. Dans ce cas, classiquement, un tel pointeur pointe sur un variable globale ou une variable statique ou une variable locale. Lors de la compilation du code source, pour minimiser la probabilité que deux pointeurs différents aient le même identifiant de pointeur, par exemple, le compilateur génère l'identifiant IPi,jdu pointeur par tirage aléatoire ou pseudo-aléatoire de cet identifiant dans un ensemble EIP. L'ensemble EIP contient toutes les valeurs possibles pour un identifiant de pointeur sauf les valeurs déjà attribuées à un identifiant de pointeur. Dans un autre mode de réalisation, l'identifiant IPi,jest à chaque fois tirée de façon aléatoire ou pseudo-aléatoire dans l'ensemble EIP. A titre d'illustration, pour faire cela, dans le cas d'un compilateur utilisant LLVM ("Low Level Virtual Machine"), l'instruction "Alloca" est modifiée pour générer en même temps le pointeur PDi,jet l'identifiant IPi,jde ce pointeur. L'instruction "Alloca" génère un pointeur qui pointe typiquement sur une variable locale enregistrée dans la pile 46.For example, when the pointer PD i,j is declared in the source code, the identifier IP i,j is generated during compilation. In this case, conventionally, such a pointer points to a global variable or a static variable or a local variable. When compiling the source code, to minimize the probability that two different pointers have the same pointer identifier, for example, the compiler generates the IP identifier i,j of the pointer by randomly or pseudo-randomly drawing this identifier from a EIP set. The EIP set contains all possible values for a pointer ID except values already assigned to a pointer ID. In another embodiment, the identifier IP i,j is randomly or pseudo-randomly drawn each time from the set EIP. By way of illustration, to do this, in the case of a compiler using LLVM ("Low Level Virtual Machine"), the "Alloca" instruction is modified to generate at the same time the PD pointer i,j and the IP identifier i,j of this pointer. The "Alloca" instruction generates a pointer that typically points to a local variable stored in stack 46.

Lorsque le code binaire comporte des instructions qui, lorsqu'elles sont exécutées par le microprocesseur 2, alloue dynamiquement une zone de mémoire libre pour y enregistrer des données, alors le pointeur PDi,jet son identifiant IPi,jsont générés lors de l'exécution du code binaire 30. Plus précisément, lorsque de telles instructions sont exécutées, elles génèrent un pointeur qui pointe vers la zone de mémoire allouée dynamiquement. De telles instructions sont fréquemment utilisées pour allouer une zone de mémoire dans le tas 48. Par exemple, dans un code source utilisant les librairies standards du langage C, de telles instructions correspondent aux fonctions "malloc()", "calloc()", "realloc()", ...etc. Dans ce cas, ces fonctions "malloc()", "calloc()", "realloc()", ...etc sont modifiées pour générer l'identifiant IPi,jen même temps qu'elle génère le pointeur PDi,j. De préférence, chaque exécution d'une telle fonction doit générer un identifiant IPi,jaussi différent que possible de l'identifiant IPi,jgénéré lors de la précédente exécution de cette même fonction. Pour cela, par exemple, à chaque exécution d'une telle fonction :
- l'identifiant IPi,jest tirée, de façon aléatoire ou pseudo-aléatoire, dans l'ensemble EIP, ou
- l'identifiant IPi,jest pris égale à l'empreinte numérique obtenue en appliquant une fonction de hachage à l'adresse @D i,j de la donnée D i,j vers laquelle le pointeur PD i,j pointe.
When the binary code includes instructions which, when they are executed by the microprocessor 2, dynamically allocates a free memory area to save data therein, then the pointer PD i,j and its identifier IP i,j are generated during the execution of the binary code 30. More precisely, when such instructions are executed, they generate a pointer which points to the dynamically allocated memory area. Such instructions are frequently used to allocate a memory area in the heap 48. For example, in a source code using the standard C language libraries, such instructions correspond to the functions "malloc()", "calloc()", "realloc()", ...etc. In this case, these functions "malloc()", "calloc()", "realloc()", ...etc are modified to generate the IP identifier i,j at the same time as it generates the PD pointer i ,j . Preferably, each execution of such a function must generate an IP identifier i,j as different as possible from the IP identifier i,j generated during the previous execution of this same function. To do this, for example, each time such a function is executed:
- the IP identifier i,j is drawn, randomly or pseudo-randomly, from the EIP set, or
- the identifier IP i,j is taken equal to the digital fingerprint obtained by applying a hash function to the address @ D i,j of the data D i,j towards which the pointer PD i,j points .

Le rôle de ces identifiantIP i,j est détaillé plus loin en référence à la .The role of these identifiersIPs i,j is detailed below with reference to the .

Le code MACiest une étiquette d'intégrité qui permet de vérifier l'intégrité du bloc BDide données. A cet effet, ici, le code MACiest un code permettant de vérifier l’intégrité et l’authenticité du cryptogramme BDi*. De plus, dans ce mode de réalisation, le code MACipermet aussi de vérifier l'intégrité et l'authenticité des métadonnées MDi .Ce code MACiest communément appelé « code d’authentification de message » et connu sous l’acronyme MAC (« Message Authentification Code »). Un tel code MACiest obtenu en construisant une empreinte numérique à partir du cryptogramme BDi* et des métadonnées MDi. Cette empreinte numérique comporte normalement moins de bits que le cryptogramme BDi*. Une telle empreinte numérique est plus connue sous le terme anglais de "digest" ou "hash". Cette empreinte numérique est construite à l’aide d’une fonction prédéterminée et d'une clé secrète k' connue seulement de l’auteur du code binaire 30 et du microprocesseur 2. Ici, la clé k’ est préenregistrée dans la mémoire 29 du module 28 de sécurisation. Par exemple, la fonction prédéterminée est une fonction à sens unique telle qu'une fonction de hachage. Dans ce cas, généralement, l'empreinte numérique est le résultat de l'application de cette fonction de hachage à une combinaison, par exemple une concaténation, du cryptogramme BDi* et des métadonnées MDi. La taille du code MACiest typiquement supérieure ou égale à 32 bits ou 64 bits. Ici, la taille du code MACiest égale à seize octets.The MAC i code is an integrity label which makes it possible to verify the integrity of the data block BD i . For this purpose, here, the MAC i code is a code making it possible to verify the integrity and the authenticity of the cryptogram BD i *. Moreover, in this embodiment, the code MAC i also makes it possible to verify the integrity and the authenticity of the metadata MD i . This MAC code i is commonly called “message authentication code” and known by the acronym MAC (“Message Authentication Code”). Such a code MAC i is obtained by constructing a digital fingerprint from the cryptogram BD i * and the metadata MD i . This digital fingerprint normally has fewer bits than the BD i * ciphertext. Such a digital fingerprint is better known by the English term "digest" or "hash". This digital fingerprint is constructed using a predetermined function and a secret key k' known only to the author of the binary code 30 and to the microprocessor 2. Here, the key k' is prerecorded in the memory 29 of the security module 28. For example, the predetermined function is a one-way function such as a hash function. In this case, generally, the digital fingerprint is the result of the application of this hash function to a combination, for example a concatenation, of the cryptogram BD i * and of the metadata MD i . The size of the MAC code i is typically greater than or equal to 32 bits or 64 bits. Here, the size of the MAC code i is equal to sixteen bytes.

Dans ce mode de réalisation, pour accélérer les transferts de données entre le microprocesseur 2 et l'ensemble 4 de mémoires, les tailles Tbet TBDsont toutes les deux des puissances de deux. Pour cela la taille Tbest égale à deux fois la taille TBD. Ainsi, dans cet exemple, TBDest égale à 64 octets. Dans ces conditions, la taille des métadonnées MDiest égale à quarante huit octets. Sur ces quarante huit octets, huit d'entre-eux sont utilisés pour stocker les identifiant IPi,j et huit octets sont utilisés pour stocker le vecteur iv i . In this embodiment, to speed up the data transfers between the microprocessor 2 and the set 4 of memories, the sizes T b and T BD are both powers of two. For this, the size T b is equal to twice the size T BD . So in this example, T BD equals 64 bytes. Under these conditions, the size of the metadata MD i is equal to forty eight bytes. Of these forty eight bytes, eight of them are used to store the IP identifiers i,j and eight bytes are used to store the vector iv i .

Enfin, l'adresse @BDCià laquelle débute le bloc BDCiest définie par la relation (1) suivante : @BDCi= @BDi.Tb/T BD. Le ratio @BDi/T BDest ici nécessairement un nombre entier puisque l'adresse @BDi est égale au cumul des tailles des blocs BD 1 à BD i-1 .De plus, de préférence, la relation qui convertie chaque adresse @BDCien une adresse physique dans la mémoire MP est une relation linéaire. Ainsi, les blocs BDCisont classées dans la mémoire MP dans le même ordre que les blocs BDi, c'est-à-dire par ordre croissant des adresses physiques des données données Di,jqui sont chiffrées dans ce bloc BDCi. De plus, la relation (1) impose que les blocs BDCisont, dans la mémoire MP, immédiatement consécutifs les uns aux autres et ne se chevauchent pas.Finally, the address @ BDCi at which block BDC i begins is defined by the following relationship (1): @ BDCi = @ BDi .T b / T BD . The ratio @ BDi / T BD is here necessarily an integer since the address @ BDi is equal to the sum of the sizes of the blocks BD 1 to BD i -1 . Moreover, preferably, the relation which converts each address @BDCi into a physical address in the memory MP is a linear relation. Thus, the blocks BDC i are classified in the memory MP in the same order as the blocks BD i , that is to say in ascending order of the physical addresses of the given data D i,j which are encrypted in this block BDC i . Moreover, relation (1) requires that the blocks BDC i are, in the memory MP, immediately consecutive to each other and do not overlap.

Dans cet exemple, le jeu d'instructions machines du microprocesseur 2 comporte notamment une instruction d'écriture et une instruction de chargement.In this example, the set of machine instructions of the microprocessor 2 notably comprises a write instruction and a load instruction.

Une instruction d'écriture est une instruction qui, lorsqu'elle est exécutée par l'unité 10, provoque l'écriture d'une donnée dans l'ensemble 4.A write instruction is an instruction which, when executed by unit 10, causes a piece of data to be written to set 4.

Une instruction de chargement est une instruction qui, lorsqu'elle est exécutée par l'unité 10, provoque le chargement d'une donnée dans le microprocesseur 2 à partir de l'ensemble 4. Généralement, la donnée chargée est enregistrée dans un registre du microprocesseur comme, par exemple, un des registres de l'ensemble 12.A load instruction is an instruction which, when it is executed by the unit 10, causes the loading of a datum into the microprocessor 2 from the set 4. Generally, the loaded datum is recorded in a register of the microprocessor like, for example, one of the registers of set 12.

A titre d'illustration, le microprocesseur 2 est conforme à l'architecture RISC (« Reduced Instructions Set Computer ») et il met en œuvre le jeu d'instructions "RISC-V".By way of illustration, the microprocessor 2 conforms to the RISC (“Reduced Instructions Set Computer”) architecture and it implements the “RISC-V” instruction set.

Ici, l'unité 10 est une unité arithmétique et logique de Ninstbits. Typiquement, Ninstest un entier supérieure ou égale à 8, 16, 32 ou 64. Dans cet exemple, Ninstest égal à 32.Here, unit 10 is an arithmetic and logic unit of N inst bits. Typically, N inst is an integer greater than or equal to 8, 16, 32 or 64. In this example, N inst is equal to 32.

Le chargeur 18 charge dans la file 22 la prochaine instruction à exécuter par l'unité 10 à partir de l'ensemble 4 de mémoires. Plus précisément, le chargeur 18 charge l'instruction sur laquelle pointe le compteur ordinal 26.Loader 18 loads into queue 22 the next instruction to be executed by unit 10 from set 4 of memories. More precisely, the loader 18 loads the instruction to which the ordinal counter 26 points.

L'unité 10 est notamment configurée pour exécuter les unes après les autres les instructions chargées dans la file 22. Les instructions chargées dans la file 22 sont généralement systématiquement exécutées dans l'ordre où ces instructions ont été enregistrées dans cette file 22. L'unité 10 est aussi capable d'enregistrer le résultat de ces instructions exécutées dans un ou plusieurs des registres de l'ensemble 12.The unit 10 is in particular configured to execute one after the other the instructions loaded into the queue 22. The instructions loaded into the queue 22 are generally systematically executed in the order in which these instructions were recorded in this queue 22. unit 10 is also capable of recording the result of these executed instructions in one or more of the registers of set 12.

Dans cette description, on utilisera comme synonymes « exécution par le microprocesseur 2 » et « exécution par l'unité 10 ».In this description, “execution by the microprocessor 2” and “execution by the unit 10” will be used as synonyms.

Le tampon 14 est utilisé pour accélérer encore plus les transferts de données entre le microprocesseur 2 et l'ensemble 4 de mémoire. Pour cela, les données transférées entre le microprocesseur 2 et l'ensemble 4 sont systématiquement transférées par bloc entier contenant exactement Nddonnées. Plus précisément, lors du chargement d'une donnée à partir de l'ensemble 4, c'est le bloc BDCiqui contient cette donnée qui est transféré, dans sa totalité, au microprocesseur 2 par l'intermédiaire du bus 50. A l'inverse, lorsqu'une donnée doit être écrite dans l'ensemble 4 de mémoires, c'est un bloc BDCicomplet, qui contient cette donnée écrite, qui est transféré du microprocesseur 2 vers l'ensemble 4 par l'intermédiaire du bus 50.Buffer 14 is used to further accelerate data transfers between microprocessor 2 and memory assembly 4. For this, the data transferred between the microprocessor 2 and the assembly 4 are systematically transferred by entire block containing exactly N d data. More specifically, when loading data from set 4, it is block BDC i which contains this data which is transferred, in its entirety, to microprocessor 2 via bus 50. conversely, when a piece of data must be written in the set 4 of memories, it is a complete block BDC i , which contains this written piece of data, which is transferred from the microprocessor 2 to the set 4 via the bus 50.

Ici, le tampon 14 est une mémoire déchiffrée, c'est-à-dire une mémoire dans laquelle les données sont enregistrées en clair. Ce tampon 14 est apte à contenir au moins un bloc BDide données en clair. Dans ce mode de réalisation, à titre d'illustration, il est apte à contenir un seul bloc de données BDi.Here, the buffer 14 is a decrypted memory, that is to say a memory in which the data is recorded in clear. This buffer 14 is capable of containing at least one block BD i of plain data. In this embodiment, by way of illustration, it is capable of containing a single block of data BD i .

Le module 28 est capable d'exécuter automatiquement les différentes opérations décrites en détails en référence au procédé de la pour sécuriser l'exécution du programme d'ordinateur. En particulier, il est apte à transformer un bloc BDCi en un bloc BDi de données en clair et vice versa. Le module 28 fonctionne indépendamment et sans utiliser l'unité 10. Ainsi, il est capable de traiter des blocs de données avant et/ou après que ceux-ci soient traités par l'unité 10. A cet effet, il comporte notamment la mémoire non-volatile sécurisée 29. Aucun accès à cette mémoire 29 sans passer par l’intermédiaire du module 28 n'est prévu. En particulier, l'unité 10 ne peut pas adresser cette mémoire 29. Dans ce mode de réalisation, le module 28 est pré-programmé, par exemple lors de sa conception, pour exécuter des opérations telles que les opérations suivantes :
- vérifier l'intégrité et l'authenticité d'un bloc BDCià partir du code MACiqu'il contient,
- calculer un code MACi,
- chiffrer le bloc BDipour obtenir le cryptogramme BDi*,
- déchiffrer le cryptogramme BDi* pour obtenir le bloc BDide données en clair.
The module 28 is capable of automatically executing the various operations described in detail with reference to the method of the to secure the execution of the computer program. In particular, it is capable of transforming a block BDCi into a block BDi of plain data and vice versa. The module 28 operates independently and without using the unit 10. Thus, it is capable of processing blocks of data before and/or after these are processed by the unit 10. For this purpose, it comprises in particular the memory secure non-volatile 29. No access to this memory 29 without going through the intermediary of the module 28 is provided. In particular, the unit 10 cannot address this memory 29. In this embodiment, the module 28 is pre-programmed, for example during its design, to execute operations such as the following operations:
- check the integrity and authenticity of a BDC i block from the MAC i code it contains,
- calculate a MAC i code,
- encrypt the BD i block to obtain the BD i * cryptogram,
- decrypt the BD i * cryptogram to obtain the BD i block of data in clear .

La mémoire 29 est utilisée pour stocker les informations secrètes nécessaires à la mise en œuvre du procédé de la . Ici, elle comporte donc notamment des informations secrètes pré-enregistrées avant le début de l'exécution du code binaire 30. En particulier, elle comporte les informations pré-enregistrées suivantes :
- une clé secrète k' utilisée pour le calcul et la vérification des codes MACi,
- un clé privée secrète skCPUqui permet de déchiffrer les données qui ont été chiffrées à l'aide de la clé publique pkCPU.
The memory 29 is used to store the secret information necessary for the implementation of the method of the . Here, it therefore includes in particular pre-recorded secret information before the start of the execution of the binary code 30. In particular, it includes the following pre-recorded information:
- a secret key k' used for the calculation and verification of the MAC codes i ,
- a secret private key sk CPU which makes it possible to decrypt the data which has been encrypted using the public key pk CPU .

Dans ce mode de réalisation, la mémoire 29 comporte aussi :
- un registre Rivpour stocker un vecteur d'initialisation ivi, et
- un registre BIPpour stocker les identifiants de pointeur.
In this embodiment, the memory 29 also comprises:
- a register R iv to store an initialization vector iv i , and
- a B IP register for storing pointer identifiers.

Dans cet exemple de réalisation, l'ensemble 12 comporte des registres généraux utilisables pour stocker tout type de données.In this exemplary embodiment, assembly 12 includes general registers that can be used to store any type of data.

Un bus d'échange de données 24 relie les différents composants du microprocesseur 2 entre eux. Il est représenté sur la pour indiquer que les différents composants du microprocesseur 2 peuvent échanger des données entre eux.A data exchange bus 24 connects the different components of the microprocessor 2 to one another. He is depicted on the to indicate that the various components of the microprocessor 2 can exchange data between them.

Le support 6 est typiquement une mémoire non volatile. Par exemple, il s'agit d'une mémoire du type EEPROM ou Flash. Il contient ici une copie 40 de sauvegarde du code binaire 30. Typiquement, c'est cette copie 40 qui est automatiquement recopiée dans la mémoire 4 pour restaurer le code 30, par exemple, après une coupure de courant ou similaire ou juste avant que débute l'exécution du code 30.Support 6 is typically a non-volatile memory. For example, it is a memory of the EEPROM or Flash type. It contains here a backup copy 40 of the binary code 30. Typically, it is this copy 40 which is automatically copied into the memory 4 to restore the code 30, for example, after a power cut or the like or just before the start of execution of code 30.

La représente la structure du pointeur PDi,j. Ici, la taille du pointeur PDi,j est égale à la taille N@ des adresses mémoires. Le pointeur PDi,j comporte :
- une plage P1de bits contenant l'adresse @Di,j vers laquelle le pointeur PDi,j pointe, et
- une plage P2distincte de bits contenant l'identifiant IPi,jdu pointeur PDi,j.
The represents the structure of the pointer PDi,j. Here, the size of the pointer PDi,j is equal to the size N@ of the memory addresses. The pointer PDi,j comprises:
- a range P 1 of bits containing the address @ Di,j towards which the pointer PDi,j points , and
- a distinct range P 2 of bits containing the identifier IP i,j of the pointer PD i,j .

Les données Di,jsont contenues dans une plage d'adresses de l'espace d'adressage du programme dont la taille est strictement inférieure à 2N@afin de laisser suffisamment de place pour coder l'identifiant IPi,jà l'intérieur du pointeur PDi,j. Pour cela, la taille de la plage P1est inférieure à N@-NPbits, où NPest la taille, en nombre de bits, de l'identifiant IPi,j. De préférence, la taille NPest supérieure à 4 bits ou 8 bits ou 16 bits et, généralement, inférieure à 32 bits ou 54 bits. Ici, la taille NPest égale à 8 bits et les adresses @Di,jsont donc codées sur moins de 56 bits. Dans ce mode de réalisation, la plage P1correspond aux N@-NPbits de poids faibles du pointeur PDi,j et la plage P2 correspond au N P bits de poids forts du pointeur PDi,j. Pour obtenir l'adresse @Di,jde la donnée Di,jà partir du pointeur PDi,j, il suffit donc de masquer les bits de poids forts du pointeur PDi,jutilisés pour enregistrer l'identifiant IPi,j.The data D i,j are contained in a range of addresses of the address space of the program whose size is strictly less than 2 N@ in order to leave enough space to encode the identifier IP i,j at l 'inside pointer PD i,j . For this, the size of the range P 1 is less than N @ -N P bits, where N P is the size, in number of bits, of the identifier IP i,j . Preferably, the size N P is greater than 4 bits or 8 bits or 16 bits and, generally, less than 32 bits or 54 bits. Here, the size N P is equal to 8 bits and the addresses @ Di,j are therefore coded on less than 56 bits. In this embodiment, the range P 1 corresponds to the N @ -N P least significant bits of the pointer PD i,j and the range P2 corresponds to the N P most significant bits of the pointer PDi,j . To obtain the address @ Di,j of the data D i,j from the pointer PD i,j , it is therefore sufficient to mask the most significant bits of the pointer PD i,j used to record the identifier IP i, j .

Un tel pointeur PDi,jqui contient, en plus de l'adresse @Di,j, d'autres informations, c'est-à-dire ici l'identifiant IPi,j, est appelé "pointeur enrichi".Such a pointer PD i,j which contains, in addition to the address @ Di,j , other information, that is to say here the identifier IP i,j , is called an “enriched pointer”.

La représente un procédé d'exécution du code binaire 30 par le microprocesseur 2.The represents a method of execution of the binary code 30 by the microprocessor 2.

Le procédé débute par une étape 150 de génération puis de fourniture du code binaire 30 dans la mémoire MP. La génération du code binaire 30 est typiquement réalisée par un compilateur tel que celui décrit, plus loin, en référence à la .The method begins with a step 150 of generation then supply of the binary code 30 in the memory MP. The generation of the binary code 30 is typically carried out by a compiler such as that described later, with reference to the .

Lors de la compilation du code source, à chaque fois que le compilateur construit un bloc BDCi, pour chaque donnée Di,jqui est chargée à l'aide d'un pointeur PDi,j, il enregistre l'identifiant IPi,jde ce pointeur dans les métadonnées MDi. Pour les données Di,jqui ne sont pas accédées à l'aide d'un pointeur, les bits situés à l'emplacement, dans les métadonnées MDi, réservé pour y enregistrer l'identifiant de pointeur associé à cette donnée, sont initialisés à zéro. Autrement dit, l'identifiant de pointeur associé à une donnée qui n'ai pas accédée à l'aide d'un pointeur, est nul.When compiling the source code, each time the compiler builds a BDC block i , for each data D i,j which is loaded using a pointer PD i,j , it records the identifier IP i ,j of this pointer in the metadata MD i . For the data D i,j which are not accessed using a pointer, the bits located at the location, in the metadata MD i , reserved for storing the pointer identifier associated with this data, are initialized to zero. In other words, the pointer identifier associated with data that was not accessed using a pointer is null.

La fourniture du code binaire 30 consiste ensuite à enregistrer la copie 40 dans le support 6. Puis, par exemple, le microprocesseur 2 recopie la copie 40 à l'intérieur de la mémoire MP pour obtenir le code binaire 30 enregistré dans la mémoire MP. Ainsi, lors de l'étape 150, les bloc BDCiconstruits lors de la compilation du code source et contenus dans le code binaire 30, sont enregistrés dans la mémoire MP et, généralement, dans la partie 44.The supply of the binary code 30 then consists in recording the copy 40 in the medium 6. Then, for example, the microprocessor 2 copies the copy 40 inside the memory MP to obtain the binary code 30 recorded in the memory MP. Thus, during step 150, the BDC blocks i built during the compilation of the source code and contained in the binary code 30, are recorded in the memory MP and, generally, in the part 44.

Ensuite, lors d'une phase 152, le microprocesseur 2 exécute le code binaire 30 et, en particulier, le code machine 32.Then, during a phase 152, the microprocessor 2 executes the binary code 30 and, in particular, the machine code 32.

Au début de la phase 152, lors d'une étape 154, le module 28 charge notamment le cryptogramme ka* contenu dans le bloc 34 et le déchiffre à l’aide de la clé skCPUcontenue dans la mémoire 29. À l’issue de l’étape 154, la clé ka est contenue dans la mémoire 29.At the start of phase 152, during a step 154, module 28 notably loads the cryptogram ka* contained in block 34 and decrypts it using the key sk CPU contained in memory 29. of step 154, the key ka is contained in the memory 29.

Ensuite, lors de l’étape 162, le microprocesseur 2 exécute, les unes après les autres, les instructions du code machine 32. Lors de cette étape 162, des instructions de chargement d'une donnée à l'aide d'un pointeur et des instructions d'écriture d'une donnée à l'aide d'un pointeur sont exécutées. Par la suite, ces deux types d'instructions sont collectivement désignées par l'expression "instruction d'accès" ou "instruction d'accès à la mémoire". A chaque fois qu'une instruction d'accès à la mémoire est exécutée par le microprocesseur 2, le procédé de la est exécuté.Then, during step 162, the microprocessor 2 executes, one after the other, the instructions of the machine code 32. During this step 162, instructions for loading data using a pointer and instructions for writing data using a pointer are executed. Hereinafter, these two types of instructions are collectively referred to as "access instruction" or "memory access instruction". Each time a memory access instruction is executed by the microprocessor 2, the method of is executed.

Le procédé de sécurisation des données enregistrées dans l'ensemble 4 va maintenant être décrit à l’aide de la et dans le cas où la donnée accédée est une donnée Di,j accédée à l'aide du pointeur PDi,j.The method for securing the data recorded in set 4 will now be described using the and in the case where the datum accessed is a datum Di,j accessed using the pointer PDi,j.

Tout d'abord, lors d'une étape 166, le pointeur PDi,jest obtenu. Typiquement, l'instruction d'accès à la donnée Di,jexécutée par l'unité 10 comporte un opérande qui contient l'adresse à laquelle le pointeur PDi,jest enregistré. Ainsi, l'exécution de cette instruction d'accès par l'unité 10 déclenche d'abord le chargement du pointeurPD i,j dansun registre du microprocesseur 2.First of all, during a step 166, the pointer PD i,j is obtained. Typically, the instruction for accessing data D i,j executed by unit 10 includes an operand which contains the address at which pointer PD i,j is stored. Thus, the execution of this access instruction by the unit 10 first triggers the loading of the pointer PD i,j in a register of the microprocessor 2.

Ensuite, lors d’une étape 170, le pointeur PDi,jest transmis au module 28. Then , during a step 170, the pointer PD i,j is transmitted to the module 28.

Lors d’une étape 172, le module 28 détermine l’adresse @BDCi du bloc BDC iqui contient cette donnée Di,j. Pour cela, le module 28 calcule ici l’adresse @BDCiselon la relation (2) suivante : @BDCi= E(@Di,j/TBD).Tb, où :
- E(…) est la fonction qui retourne la partie entière du nombre entre parenthèses, et
- TBDet Tbsont les tailles, en nombre d’octets, respectivement du bloc BDiet du bloc BDCi.
During a step 172, the module 28 determines the address @ BDCi of the block BDC i which contains this datum D i,j . For this, the module 28 here calculates the address @ BDCi according to the following relationship (2): @ BDCi = E(@ Di,j /T BD ).T b , where:
- E(…) is the function that returns the integer part of the number in parentheses, and
- T BD and T b are the sizes, in number of bytes, respectively of the block BD i and of the block BDC i .

La fonction E(...) est connue sous le terme anglais de "floor".The E(...) function is known by the English term "floor".

Le terme E(@Di,j/TBD) donne le numéro d’ordre du bloc BDCià partir duquel la donnée Di,jpeut être chargée. Étant donné que dans ce mode de réalisation, les tailles TBDet Tbsont toutes les deux des puissances de deux, la division par la taille TBDet la multiplication par la taille Tbpeuvent toutes les deux être réalisées par un registre à décalage. Un registre à décalage décale les bits du nombre qu’il contient vers la droite pour réaliser une division et vers la gauche pour réaliser une multiplication. Plus précisément, dans ce mode de réalisation, la taille TBDest égale à 26octets et la taille Tbest égale à 27octets. Ici, le module 28 comporte donc un registre matériel à décalage. Dans ces conditions, le module 28 est capable de calculer très rapidement, et typiquement en un cycle d’horloge, l’adresse @BDCi.The term E(@ Di,j /T BD ) gives the order number of the block BDC i from which the data item D i,j can be loaded. Since in this embodiment the sizes T BD and T b are both powers of two, the division by the size T BD and the multiplication by the size T b can both be performed by a register at gap. A shift register shifts the bits of the number it contains to the right to perform a division and to the left to perform a multiplication. More precisely, in this embodiment, the size T BD is equal to 26 bytes and the size T b is equal to 27 bytes. Here, the module 28 therefore comprises a hardware shift register. Under these conditions, the module 28 is able to calculate very quickly, and typically in one clock cycle, the address @BDCi .

Ainsi, ici, pour calculer l’adresse @BDCi, le module 28 enregistre l’adresse @Di,jdans son registre à décalage puis décale de six bits vers la droite les bits de l’adresse enregistrée dans ce registre pour obtenir le résultat du ratio @Di,j/TBD.Ensuite le module 28 calcule la partie entière du ratio obtenu puis enregistre cette partie entière dans le registre à décalage. Enfin, le registre à décalage décale de sept bits vers la gauche les bits de cette partie entière pour obtenir l’adresse @BDCi.Thus, here, to calculate the address @ BDCi , the module 28 records the address @ Di,j in its shift register then shifts the bits of the address recorded in this register to the right by six bits to obtain the result of the ratio @ Di,j /T BD. Then the module 28 calculates the integer part of the ratio obtained then stores this integer part in the shift register. Finally, the shift register shifts the bits of this integer part seven bits to the left to obtain the @BDCi address.

Il est préférable que le calcul de l’adresse @BDCisoit très rapide, car ce calcul est réalisé à chaque fois qu’une donnée est accédée.It is preferable that the calculation of the @BDCi address is very fast, because this calculation is carried out each time a data is accessed.

Une fois l’adresse @BDCidéterminée, lors d'une étape 174, le module 28 vérifie si l’adresse @BDCiest égale à une adresse @BDCc . L'adresse @ BDCc est l'adresse du bloc BDC c à partir duquel le bloc BD c actuellementcontenu dans le tampon 14 a été obtenu. L'adresse@ BDCc est, par exemple, enregistrée dans la mémoire 29. Once the address @BDCi has been determined, during a step 174, the module 28 verifies whether the address @BDCi is equal to an address @BDCc . The address @BDCc is the address of the block BDC c from which the block BD c currently contained in the buffer 14 was obtained. The @BDCc address is, for example, stored in memory 29.

Dans l’affirmative, cela signifie que le bloc BDiqui contient la donnée Di,jà accéder est déjà enregistré dans le tampon 14. Autrement dit, les blocs BDiet BDcsont les mêmes. Dans ce cas, le procédé se poursuit :
- directement par une étape 176 si l’instruction d'accès exécutée est une instruction de chargement, ou
- directement par une étape 190 si l’instruction d'accès exécutée est une instruction d’écriture.
If so, this means that the block BD i which contains the datum D i,j to be accessed is already recorded in the buffer 14. In other words, the blocks BD i and BD c are the same. In this case, the process continues:
- directly by a step 176 if the access instruction executed is a load instruction, or
- directly by a step 190 if the access instruction executed is a write instruction.

Lors de l’étape 176, pour la donnée Di,jà charger, le module 28 relève le premier identifiant IPi,jcontenu dans les métadonnées MDidu bloc BDCiet associé à cette donnée Di,j. Ici, comme expliqué plus loin, ce premier identifiant IPi,jse trouve dans le registre BIP. Le premier identifiant IPi,jest donc extrait de ce registre BIP. Le module 28 relève aussi le second identifiant IPi,jcontenu dans le pointeur PDi,jtransmis lors de l'étape 170. Pour cela, le module 28 extrait le second identifiant IPi,jde la plage P2du pointeur PDi,jreçu. Ensuite, le module 28 vérifie si les premier et second identifiants IPi,jextraits correspondent. Ici, les premier et second identifiants IPi,jcorrespondent uniquement s'ils sont égaux.During step 176, for the datum D i,j to be loaded, the module 28 records the first identifier IP i,j contained in the metadata MD i of the block BDC i and associated with this datum D i,j . Here, as explained below, this first IP identifier i,j is found in the B IP register. The first identifier IP i,j is therefore extracted from this register B IP . The module 28 also notes the second IP identifier i,j contained in the pointer PD i,j transmitted during step 170. For this, the module 28 extracts the second identifier IP i,j from the range P 2 of the pointer PD i,j received. Then, the module 28 checks whether the first and second IP identifiers i,j extracted correspond. Here, the first and second IP identifiers i,j match only if they are equal.

Si les premier et second identifiants IPi,jcorrespondent, lors d’une étape 178, le traitement de la donnée Di,jpar le microprocesseur 2 est autorisé. Dans ce cas, la donnée Di,jest alors directement chargé à partir du tampon 14 puis, par exemple, transférée dans l’un des registres de l’ensemble 12. Ensuite, l’unité 10 exécute des instructions de traitement de cette donnée Di,jenregistrée dans un registre de l'ensemble 12.If the first and second identifiers IP i,j correspond, during a step 178, the processing of the data item D i,j by the microprocessor 2 is authorized. In this case, the data D i,j is then directly loaded from the buffer 14 then, for example, transferred into one of the registers of the set 12. Then, the unit 10 executes processing instructions of this data D i,j recorded in a register of set 12.

Si les premier et second identifiants IPi,jne correspondent pas, c'est-à-dire qu'ils sont différents, dans ce cas, le procédé se poursuit par une étape 180. Lors de l'étape 180, le module 28 déclenche le signalement d’une faute d’exécution du code binaire 30. De plus, ici, lors de l'étape 180, le traitement, par le microprocesseur 2, de la donnée Di,jest interdit. Par exemple, lors de l’étape 180, la donnée Di,jn’est pas chargée dans un registre de l'ensemble 12.If the first and second IP identifiers i,j do not correspond, that is to say they are different, in this case, the method continues with a step 180. During step 180, the module 28 triggers the signaling of an execution fault of the binary code 30. In addition, here, during step 180, the processing, by the microprocessor 2, of the data D i,j is prohibited. For example, during step 180, data D i,j is not loaded into a register of set 12.

Ensuite, lors d'une étape 182, en réponse à ce signalement d'une faute d'exécution, le microprocesseur 2 met en œuvre une ou plusieurs mesures correctives et/ou une ou plusieurs contre-mesures.Then, during a step 182, in response to this signaling of an execution fault, the microprocessor 2 implements one or more corrective measures and/or one or more countermeasures.

De très nombreuses contre-mesures sont possibles. Les contre-mesures mises en œuvre peuvent avoir des degrés de sévérité très différents. Par exemple, les contre-mesures mises en œuvre peuvent aller d'un simple affichage ou une simple mémorisation d'un message d'erreur sans interrompre l'exécution normale du code binaire, jusqu'à une mise hors service définitive du microprocesseur 2. Le microprocesseur 2 est considéré comme étant hors service lorsqu'il est définitivement placé dans un état où il est incapable d'exécuter un quelconque code binaire. Entre ces degrés de sévérité extrêmes, il existe de nombreuses autres contre-mesures possibles telles que :
- l'indication par l'intermédiaire d'une interface homme-machine de la détection des fautes,
- l'interruption immédiate de l'exécution du code binaire et/ou sa réinitialisation, et
- la suppression du code binaire de la mémoire MP et/ou la suppression de la copie 40 de sauvegarde et/ou la suppression des données secrètes.
Many countermeasures are possible. The countermeasures implemented can have very different degrees of severity. For example, the countermeasures implemented can range from a simple display or a simple memorization of an error message without interrupting the normal execution of the binary code, up to a definitive decommissioning of the microprocessor 2. The microprocessor 2 is considered to be out of service when it is definitively placed in a state where it is incapable of executing any binary code. Between these extreme degrees of severity, there are many other possible countermeasures such as:
- indication via a man-machine interface of fault detection,
- the immediate interruption of the execution of the binary code and/or its reinitialization, and
- the deletion of the binary code from the memory MP and/or the deletion of the backup copy 40 and/or the deletion of the secret data.

Lors de l’étape 190, la valeur à écrire dans la donnée Di,jest directement écrite dans la donnée Di,jdu bloc de données BDiactuellement enregistré dans le tampon 14.During step 190, the value to be written in the datum D i,j is directly written in the datum D i,j of the data block BD i currently recorded in the buffer 14.

Ensuite, lors d'une étape 192, le module 28 remplace, dans le registre BIP, le précédent identifiant IPi,jassocié à la donnée Di,jpar l'identifiant IPi,jdu pointeur PDi,jtransmis lors de l'étape 170.Then, during a step 192, the module 28 replaces, in the register B IP , the previous identifier IP i,j associated with the data D i,j by the identifier IP i,j of the pointer PD i,j transmitted during step 170.

Ici, lors de l'écriture de la donnée Di,jdans le tampon 14, le module 28 ne procède pas à la vérification de l'identifiant IPi,jassocié à cette donnée. Au contraire, à chaque fois qu’une donnée est écrite dans le tampon 14, le module 28 autorise l'utilisation du pointeur PDi,jpour charger ultérieurement la donnée Di,j.Here, when writing data D i,j in buffer 14, module 28 does not verify the identifier IP i,j associated with this data. On the contrary, each time a datum is written in the buffer 14, the module 28 authorizes the use of the pointer PD i,j to subsequently load the datum D i,j .

De plus, lors de l'étape 192, le module 28 bascule un indicateur d’écriture vers son état actif. Ainsi, l’état actif de cet indicateur d’écriture indique que le bloc BDcactuellement présent dans le tampon 14 a été écrit. A l'inverse, l’état inactif de cet indicateur d’écriture indique que le blocBD c actuellement enregistrédans le tampon 14 n’a pas été écrit. Un tel indicateur d’écriture est connu sous le terme anglais de « bit dirty».In addition, during step 192, module 28 toggles a write flag to its active state. Thus, the active state of this write flag indicates that the block BD c currently present in the buffer 14 has been written. Conversely, the inactive state of this write flag indicates that the block BD c currently recorded in the buffer 14 has not been written. Such a write indicator is known by the English term “bit dirty”.

Si lors de l’étape 174, l’adresse @BDCiest différente de l’adresse contenue dans la mémoire 29, cela signifie que le bloc BDcactuellement contenu dans le tampon 14 ne contient pas la donnée Di,jà accéder. Dans ce cas, le procédé se poursuit par une étape 200.If during step 174, the address @ BDCi is different from the address contained in the memory 29, this means that the block BD c currently contained in the buffer 14 does not contain the data D i,j to be accessed. In this case, the method continues with a step 200.

Lors de l’étape 200, le module 28 vérifie si le bloc BDcactuellement contenu dans le tampon 14 a été écrit. Typiquement, pour faire cela, le module 28 vérifie l’état de l'indicateur d’écriture.During step 200, module 28 verifies whether block BD c currently contained in buffer 14 has been written. Typically, to do this, module 28 checks the state of the write flag.

Si l’indicateur d’écriture est dans son état inactif, il n’est pas nécessaire d’enregistrer le bloc BDcdans l’ensemble 4. Dans ce cas, le procédé se poursuit directement par une étape 300 de transfert du bloc BDCiqui contient la donnée Di,jchiffrée depuis l’ensemble 4 vers le tampon 14.If the write flag is in its inactive state, it is not necessary to record the block BD c in the set 4. In this case, the method continues directly with a step 300 of transferring the block BDC i which contains data D i,j encrypted from set 4 to buffer 14.

Dans le cas contraire, le bloc BDcactuellement enregistré dans le tampon 14 doit être sauvegardé dans l’ensemble 4. Dans ce cas, le procédé se poursuit par une étape 400 de transfert du bloc BDcactuellement contenu dans le tampon 14 vers l’ensemble 4.Otherwise, the block BD c currently recorded in the buffer 14 must be saved in the set 4. In this case, the method continues with a step 400 of transferring the block BD c currently contained in the buffer 14 to the together 4.

L’étape 300 débute par une opération 302 de chargement du bloc BDCisitué à l’adresse @BDCidéterminée lors de l’étape 172. Typiquement, lors de l'opération 302, l'adresse @BDCiest convertie automatiquement en une adresse physique par l'unité MMU ("Management Memory Unit"). De préférence, le bloc BDCiest chargé depuis l’ensemble 4 vers le microprocesseur en utilisant un mode de transfert accéléré de bloc de données sur le bus 50. Un tel mode est par exemple connu sous le terme anglais de « burst mode ».Step 300 begins with an operation 302 of loading the block BDC i located at the address @ BDCi determined during step 172. Typically, during operation 302, the address @ BDCi is automatically converted into an address physically by the MMU ("Management Memory Unit"). Preferably, block BDC i is loaded from assembly 4 to the microprocessor using an accelerated data block transfer mode on bus 50. Such a mode is for example known by the term “burst mode”.

Le bloc BDCichargé est alors temporairement stocké dans le microprocesseur 2. Par exemple, il est enregistré dans l’ensemble 12 ou dans la mémoire 29 ou dans le tampon 14.The loaded BDC block i is then temporarily stored in the microprocessor 2. For example, it is recorded in the set 12 or in the memory 29 or in the buffer 14.

Lors de l’opération 304, le module 28 vérifie l'intégrité du bloc BDCi chargé. Ici, il vérifie l’intégrité et l’authenticité du cryptogramme BDi* et des métadonnées MDià l’aide du code MACi. Pour cela, le module 28 calcule un code MACi' en utilisant le même algorithme que celui mis en œuvre pour construire le code MACisauf qu'il utilise le cryptogramme BDi* et les métadonnées MDichargés lors de l'opération 302. Si le code MACi' ainsi construit est identique au code MACichargé, alors l’intégrité et l’authenticité du cryptogramme BDi* et des métadonnées MDiest confirmée.During operation 304, module 28 verifies the integrity of the loaded block BDC i . Here it verifies the integrity and authenticity of the BD i * cryptogram and MD i metadata using the MAC i code. For this, the module 28 calculates a MAC code i 'by using the same algorithm as that implemented to construct the MAC code i except that it uses the cryptogram BD i * and the metadata MD i loaded during operation 302 If the MAC i ' code thus constructed is identical to the MAC i code loaded, then the integrity and authenticity of the cryptogram BD i * and of the metadata MD i is confirmed.

Dans ce cas, le module 28 procède, lors d'une opération 306, au déchiffrement du cryptogramme BDi* en utilisant pour cela la clé ka enregistrée dans sa mémoire 29 et le vecteur iviextrait des métadonnées MDidu bloc BDCichargé.In this case, the module 28 proceeds, during an operation 306, to the decryption of the cryptogram BD i * by using for this the key ka recorded in its memory 29 and the vector iv i extracts metadata MD i from the block BDC i loaded .

Après l'opération 306, lors d'une opération 308, le bloc BDien clair obtenu est enregistré dans le tampon 14 à la place du précédent bloc de données. A cette occasion, l’indicateur d’écriture est basculé dans son état inactif.After the operation 306, during an operation 308, the clear block BD i obtained is recorded in the buffer 14 in place of the previous data block. On this occasion, the write flag is switched to its inactive state.

Lors de l'opération 308, le module 28 enregistre également les identifiants IPi,jcontenus dans les métadonnées MDidu bloc BDCichargé dans le registre BIPde la mémoire 29. Le vecteur ivicontenu dans les métadonnées MDidu bloc BDCichargé est lui aussi enregistré dans le registre Rivde la mémoire 29. Enfin, l'adresse @BDCidu bloc BDCichargé est aussi enregistrée dans la mémoire 29. Cette adresse @BDCienregistrée devient la nouvelle adresse @BDCc.During operation 308, the module 28 also records the identifiers IP i,j contained in the metadata MD i of the block BDC i loaded into the register B IP of the memory 29. The vector iv i contained in the metadata MD i of the Block BDC i loaded is also stored in register R iv of memory 29. Finally, the address @BDCi of block BDC i loaded is also stored in memory 29. This stored address @BDCi becomes the new address @BDCc .

Dans le cas où la vérification de l'intégrité du bloc BDCiéchoue, le module 28 procède à une opération 310 d’inhibition du traitement des données de ce bloc. Par exemple, ici, lors de l'opération 310, le module 28 remplace le bloc BDcenregistré dans le tampon 14 par un bloc BDi vierge. Lors de cette opération 310, le module 28 initialise toutes les données du bloc BDi vierge à une valeur prédéterminée. Typiquement, cette valeur prédéterminée est la valeur zéro. Ensuite, ce bloc BDi vierge est enregistré dans le tampon 14 à la place du bloc BDc. Toujours lors de cette opération 310, le module 28 initialise aussi à zéro tous les identifiants IPi,j contenus dans le registre BIP de la mémoire 29. Il ré-initialise aussi la valeur du vecteur ivi contenue dans le registre Riv. Par exemple, la nouvelle valeur du vecteur ivi contenu dans le registre Riv est générée par tirage aléatoire ou pseudo-aléatoire. Enfin, l'adresse @BDCi du bloc BDCi chargé est aussi enregistrée dans la mémoire 29. Ainsi, dans le cas où la vérification de l'intégrité du bloc BDCi échoue, c'est un bloc BDi vierge qui est enregistré dans le tampon 14. If the verification of the integrity of the block BDC i fails, the module 28 performs an operation 310 of inhibiting the processing of the data of this block. For example, here, during operation 310, module 28 replaces block BD c recorded in buffer 14 with a blank block BD i. During this operation 310, the module 28 initializes all the data of the blank block BDi to a predetermined value. Typically, this predetermined value is zero. Then, this blank block BDi is recorded in the buffer 14 in place of the block BDc. Still during this operation 310, the module 28 also initializes to zero all the identifiers IPi,j contained in the register BIP of the memory 29. It also reinitializes the value of the vector ivi contained in the register Riv. For example, the new value of the vector ivi contained in the register Riv is generated by random or pseudo-random drawing. Finally, the address @BDCi of the loaded block BDCi is also recorded in the memory 29. Thus, in the event that the verification of the integrity of the block BDCi fails, it is a blank block BDi which is recorded in the buffer 14 .

Après l'opération 308 ou 310, le procédé se poursuit par l'étape 176 ou l'étape 190 selon que l'instruction à exécuter est une instruction de chargement ou une instruction d'écriture.After operation 308 or 310, the method continues with step 176 or step 190 depending on whether the instruction to be executed is a load instruction or a write instruction.

L’étape 400 débute par une opération 402 de transformation du bloc BDcen un bloc BDCc.Step 400 begins with an operation 402 of transforming the block BD c into a block BDC c .

Pour cela, lors d’une sous-opération 404, le module 28 commence par générer un nouveau vecteur ivi. Le nouveau vecteur iviest par exemple généré à partir de l’ancienne valeur de ce vecteur ivienregistrée dans le registre Riv. Par exemple, le nouveau vecteur iviest obtenu en incrémentant cette ancienne valeur d’un pas prédéterminé.For this, during a sub-operation 404, the module 28 begins by generating a new vector iv i . The new vector iv i is for example generated from the old value of this vector iv i recorded in the register R iv . For example, the new vector iv i is obtained by incrementing this old value by a predetermined step.

Ensuite, lors d’une sous opération 406, le module 28 chiffre le bloc BDcactuellement contenu dans le tampon 14 en utilisant pour cela la clé ka et le nouveau vecteur ivigénéré lors de la sous-opération 404. A l’issue de cette opération, le cryptogramme BDc *est obtenu.Then, during a sub-operation 406, the module 28 encrypts the block BD c currently contained in the buffer 14 using for this the key ka and the new vector iv i generated during the sub-operation 404. At the end from this operation, the cryptogram BD c * is obtained.

Lors d’une sous-opération 408, le module 28 construit les métadonnées MDc. Pour cela, le module enregistre, dans les emplacements réservés à cet effet, les identifiants IPi,jactuellement contenus dans le registre BIPet le vecteur ivienregistré dans le registre Riv. Ensuite, le module 28 calcule le nouveau code MACcà partir du cryptogramme BDc *obtenu à l’issue de la sous-opération 406 et des métadonnées MDcconstruites.During a sub-operation 408, the module 28 constructs the metadata MD c . For this, the module saves, in the slots reserved for this purpose, the identifiers IP i,j currently contained in the register B IP and the vector iv i saved in the register R iv . Then, the module 28 calculates the new code MAC c from the cryptogram BD c * obtained at the end of the sub-operation 406 and from the metadata MD c constructed.

Enfin, une fois le nouveau code MACccalculé, à la fin de la sous-opération 408, le module 28 regroupe dans un même bloc de données, le cryptogramme BDc *, les métadonnées construites MDcet le nouveau code MACcafin d’obtenir un nouveau bloc BDCc.Finally, once the new MAC code c has been calculated, at the end of sub-operation 408, the module 28 groups together in the same block of data, the cryptogram BD c * , the constructed metadata MD c and the new MAC code c in order to obtain a new block BDC c .

Après, lors d’une opération 410, le nouveau bloc BDCcest enregistré dans l’ensemble 4 à l’adresse physique correspond à l'adresse @BDCcactuellement contenue dans la mémoire 29.Afterwards, during an operation 410, the new block BDC c is recorded in set 4 at the physical address corresponding to the address @ BDCc currently contained in memory 29.

L’étape 400 s’achève alors et le procédé se poursuit par l’étape 300.Step 400 then ends and the method continues with step 300.

La représente un compilateur 500 apte à générer automatiquement le code binaire 30 à partir d'un code source 502 du programme d'ordinateur. À cet effet, le compilateur 500 comporte typiquement un microprocesseur 504 programmable et une mémoire 506. La mémoire 506 contient les instructions et les données nécessaires pour, lorsqu'elles sont exécutées par le microprocesseur 504, générer automatiquement le code binaire 30 à partir du code source 502. Par exemple, pour cela, le compilateur parcourt le code source 502 et génère, pour chaque pointeur PDi,j à protéger, l'identifiant IPi,j de ce pointeur. L'identifiant IPi,j ainsi généré est enregistré dans la plage P2 de ce pointeur IPi,j. Après cela, les bloc BDCi qui seront ensuite enregistrés dans la partie 44 de la mémoire MP après chargement de ce code binaire 30 dans cette mémoire MP, sont générés. Plus précisément, lors de la compilation, le compilateur 500 transforme chaque bloc BDi en clair destiné à être enregistré dans la partie 44 de la mémoire MP en un bloc BDCi de façon similaire à ce qui a été décrit en référence au procédé de la . En particulier, pour chaque donnée Di,j du bloc BDi accédée à l'aide d'un pointeur PDi,j, le compilateur insère automatiquement l’identifiant IPi,j de ce pointeur à l'emplacement réservé à cet effet dans les métadonnées MDi. La conception et la réalisation d'un tel compilateur sont à la portée de l'homme du métier à partir des explications données dans cette description.The represents a compiler 500 capable of automatically generating the binary code 30 from a source code 502 of the computer program. To this end, the compiler 500 typically includes a programmable microprocessor 504 and a memory 506. The memory 506 contains the instructions and data necessary to, when executed by the microprocessor 504, automatically generate the binary code 30 from the code source 502. For example, for this, the compiler scans the source code 502 and generates, for each pointer PDi,j to be protected, the identifier IPi,j of this pointer. The identifier IPi,j thus generated is recorded in the range P2 of this pointer IPi,j. After that, the blocks BDCi which will then be recorded in the part 44 of the memory MP after loading this binary code 30 into this memory MP, are generated. More precisely, during the compilation, the compiler 500 transforms each block BDi in clear intended to be recorded in the part 44 of the memory MP into a block BDCi in a manner similar to what has been described with reference to the method of the . In particular, for each data item Di,j of block BDi accessed using a pointer PDi,j, the compiler automatically inserts the identifier IPi,j of this pointer in the space reserved for this purpose in the metadata MDi . The design and production of such a compiler are within the abilities of those skilled in the art based on the explanations given in this description.

CHAPITRE III : VARIANTESCHAPTER III: VARIANTS

Variantes de l'appareil 1 :Device 1 variants:

D'autres modes de réalisation de l'ensemble 4 sont possibles. Par exemple, l'ensemble 4 peut comporter un plus grand nombre ou un plus petit nombre de mémoires caches. Dans un cas très simplifié, l'ensemble 4 ne comporte pas de mémoire cache et comporte, par exemple, seulement la mémoire principale MP.Other embodiments of set 4 are possible. For example, set 4 may include more or fewer cache memories. In a very simplified case, the set 4 does not include a cache memory and includes, for example, only the main memory MP.

La mémoire MP peut être une mémoire non volatile. Dans ce cas, il n'est pas nécessaire de copier le code binaire 30 à l'intérieur de cette mémoire avant le lancement de son exécution puisqu'il s'y trouve déjà.The memory MP can be a non-volatile memory. In this case, it is not necessary to copy the binary code 30 inside this memory before launching its execution since it is already there.

Le fait qu'une mémoire de l'ensemble 4 soit intégrée ou non à l'intérieur du microprocesseur 2 peut être librement modifié. Ainsi, en variante, une ou plusieurs des mémoires caches L1, L2 et L3 sont intégrées à l'intérieur du microprocesseur 2, c'est-à-dire réalisées sur la même puce semi-conductrice que l'unité 10 du microprocesseur 2. En variante, la mémoire MP peut aussi être une mémoire interne intégrée à l'intérieur du microprocesseur 2.The fact that a memory of set 4 is integrated or not inside microprocessor 2 can be freely modified. Thus, as a variant, one or more of the cache memories L1, L2 and L3 are integrated inside the microprocessor 2, that is to say made on the same semiconductor chip as the unit 10 of the microprocessor 2. As a variant, the memory MP can also be an internal memory integrated inside the microprocessor 2.

De nombreuses architectures matérielles différentes sont possibles pour réaliser le module 28. En particulier, le module 28 peut être composé par la combinaison de plusieurs blocs matériels du microprocesseur 2 remplissant des fonctions respectives et situés chacun dans une aire différente de la puce du microprocesseur 2.Many different hardware architectures are possible to make the module 28. In particular, the module 28 can be composed by the combination of several hardware blocks of the microprocessor 2 fulfilling respective functions and each located in a different area of the chip of the microprocessor 2.

En variante, le tampon 14 est apte à contenir simultanément plusieurs blocs de données en clair.As a variant, the buffer 14 is capable of simultaneously containing several blocks of data in clear.

Variantes du code d'authentification :Authentication code variants:

D’autres méthodes de calcul du code d’authentification sont possibles. Par exemple, en variante, le module 28 calcule un premier code d’authentification uniquement à partir du cryptogramme BDi * et un second code d’authentification uniquement à partir des métadonnées MDi. Dans ce cas, le code d’authentification contenu dans le bloc BDCiest le résultat, par exemple, de la concaténation de ce premier et de ce second codes d’authentification. Ensuite, les premier et second codes d’authentification sont utilisés par le module 28 pour vérifier l’intégrité, respectivement, du cryptogramme BDi * et des métadonnées MDi lors de l’opération 304.Other methods of calculating the authentication code are possible. For example, as a variant, the module 28 calculates a first authentication code only from the cryptogram BDI * and a second authentication code only from MD metadataI. In this case, the authentication code contained in the BDC blockIis the result, for example, of the concatenation of this first and this second authentication code. Then, the first and second authentication codes are used by the module 28 to verify the integrity, respectively, of the cryptogram BDI * and MD metadataI during operation 304.

Dans un autre mode de réalisation, le code MACiest calculé à partir du cryptogramme BDi *et sans prendre en compte les métadonnées MDi. Dans ce cas, de préférence, les métadonnées MDisont alors chiffrées de sorte qu’elles n’apparaissent pas en clair dans le bloc BDCi. Par exemple, elles sont chiffrées à l'aide de la fonction fka.In another embodiment, the MAC code i is calculated from the cryptogram BD i * and without taking into account the metadata MD i . In this case, preferably, the metadata MD i are then encrypted so that they do not appear unencrypted in the block BDC i . For example, they are encrypted using the f ka function.

Dans une autre variante, le code MACiest calculé à partir des données Di,jen clair et non pas à partir du cryptogramme BDi *. Dans ce cas, il faut inverser l’ordre des opérations de vérification de l’intégrité du code d’authentification et de déchiffrement du cryptogramme BDi *. En effet, dans ce cas, les données doivent d’abord être déchiffrées et seulement ensuite, le module 28 est en mesure d’en vérifier l’intégrité.In another variant, the MAC code i is calculated from the data D i,j in clear and not from the cryptogram BD i * . In this case, it is necessary to reverse the order of the operations for verifying the integrity of the authentication code and for decrypting the cryptogram BD i * . Indeed, in this case, the data must first be decrypted and only then, the module 28 is able to verify its integrity.

Variantes des métadonnées :Variants of metadata:

En variante les métadonnées MDicomportent d'autres données que les identifiants IPi,jet que le vecteur ivi. Par exemple, les métadonnées peuvent en plus comporter des indicateurs de validité tels que ceux décrits dans la demande américaine déposée le 02/12/2020 sous le numéro 17/109,424. A l'inverse, dans un mode de réalisation simplifié, les métadonnées MDine comportent pas le vecteur ivi. Dans ce dernier cas, le vecteur ivià utiliser pour déchiffrer le cryptogramme BDi* est alors stocké différemment. Par exemple, un registre associant, à chaque bloc BDCi, le vecteur ivinécessaire pour déchiffrer le cryptogramme BDi* est enregistré dans la mémoire MP.As a variant, the metadata MD i include data other than the identifiers IP i,j and the vector iv i . For example, the metadata may additionally include validity indicators such as those described in the American application filed on 02/12/2020 under number 17/109,424. Conversely, in a simplified embodiment, the metadata MD i does not include the vector iv i . In the latter case, the vector iv i to be used to decrypt the cryptogram BD i * is then stored differently. For example, a register associating, with each block BDC i , the vector iv i necessary to decipher the cryptogram BD i * is recorded in the memory MP.

Les métadonnées peuvent être enregistrées dans le tampon 14 ou dans un registre indépendant du tampon 14 et de la mémoire 29. Dans le cas où les métadonnées MDisont enregistrées dans le tampon 14, celles-ci sont, de préférence, enregistrées dans une plage d’adresses distincte de la plage d’adresses où sont enregistrées les données Di,j. Typiquement, cette plage d’adresses distincte n’est pas adressable par le l'unité 10 de sorte que la présence des métadonnées MDidans le tampon 14 ne modifie en rien l’adressage des données Di,j. Par contre, les métadonnées MDisont accessibles par le module 28 pour qu’il puisse mettre en œuvre les différentes étapes décrites dans le chapitre II.The metadata can be recorded in the buffer 14 or in a register independent of the buffer 14 and of the memory 29. In the case where the metadata MD i are recorded in the buffer 14, these are preferably recorded in a range of addresses distinct from the range of addresses where the data D i,j are recorded. Typically, this distinct range of addresses cannot be addressed by the unit 10 so that the presence of the metadata MD i in the buffer 14 in no way modifies the addressing of the data D i,j . On the other hand, the metadata MD i are accessible by the module 28 so that it can implement the various steps described in chapter II.

En variante, lorsque le nouveau vecteur ivid’un bloc BDCiest généré sans prendre en compte sa précédente valeur, il n’est pas nécessaire de sauvegarder sa précédente valeur dans le registre Rivaprès le chargement du bloc BDCidans le tampon 14. C’est par exemple le cas lorsque, à chaque transfert d’un bloc de données du tampon 14 vers l’ensemble 4, le nouveau vecteur iviest généré par tirage aléatoire ou pseudo aléatoire.As a variant, when the new vector iv i of a block BDC i is generated without taking into account its previous value, it is not necessary to save its previous value in the register R iv after the block BDC i has been loaded into the buffer 14. This is for example the case when, on each transfer of a block of data from buffer 14 to set 4, the new vector iv i is generated by random or pseudo-random drawing.

D’autres méthodes de génération d’un nouveau vecteur ivisont possibles. Par exemple, le nouveau vecteur iviest pris égal à la précédente valeur du code MACi. Dans ce cas, à chaque fois qu’un bloc BDCiest transféré de l’ensemble 4 vers le tampon 14, le code MACicontenu dans ce bloc BDCiest enregistré dans le microprocesseur, par exemple, dans la mémoire 29.Other methods of generating a new vector iv i are possible. For example, the new vector iv i is taken equal to the previous value of the MAC code i . In this case, each time a block BDC i is transferred from set 4 to buffer 14, the MAC code i contained in this block BDC i is recorded in the microprocessor, for example, in memory 29.

Le nouveau vecteur ivipeut aussi être complété par d’autres informations pour obtenir un vecteur d’initialisation complet ivcipuis, lors de l’opération 406 de chiffrement, c’est ce vecteur ivciqui est utilisé à la place du vecteur ivi. Dans ce cas, le cryptogramme BDi * est le résultat de la fonction fka(BDi; ivci). L’opération 306 de déchiffrement doit alors être adaptée en conséquence. Autrement dit, le bloc BDien clair est le résultat de la fonction fka -1(BDi *; ivci). Par exemple, le vecteur ivciest obtenu en combinant le vecteur iviet l’adresse @BDCicontenue dans la mémoire 29. Par exemple, le vecteur iviet l’adresse @BDCisont concaténés. Le vecteur ivcipeut aussi être obtenu en combinant le vecteur ivi avecun identifiant du code binaire 30. Dans ce cas, le cryptogramme BDi *obtenu est fonction du code binaire 30 à exécuter. Le vecteur ivcipeut aussi être obtenu en combinant le vecteur ivi, l’adresse @BDCiet l’identifiant du code binaire 30.The new vector ivIcan also be supplemented with other information to obtain a complete initialization vector ivcIthen, during the 406 encryption operation, it is this ivc vectorIwhich is used instead of vector ivI. In this case, the cryptogram BDI * is the result of the function fwhat(BDI; ivcI). The decryption operation 306 must then be adapted accordingly. In other words, the BD blockIplainly is the result of the function fwhat -1(BDI *; ivcI). For example, the vector ivcIis obtained by combining the vector ivIand the address @BDCicontained in memory 29. For example, the vector ivIand the address @BDCiare concatenated. The ivc vectorIcan also be obtained by combining the vector ivI withan identifier of the binary code 30. In this case, the cryptogram BDI *obtained depends on the binary code 30 to be executed. The ivc vectorIcan also be obtained by combining the vector ivI, the address @BDCiand the identifier of the binary code 30.

Variantes du procédé :Variants of the process:

D'autres modes de réalisation de l'étape 176 sont possibles. Par exemple, lors de l'étape 176, deux identifiants de pointeurs sont dit correspondant si l'écart entre ces deux identifiants est inférieur, en valeur absolue, à un seuil prédéterminé.Other embodiments of step 176 are possible. For example, during step 176, two pointer identifiers are said to correspond if the difference between these two identifiers is less, in absolute value, than a predetermined threshold.

L'étape 176 peut aussi être exécutée avant l'étape 304 de vérification de l'intégrité du bloc de données chargés. Dans ce cas, par exemple, les étapes 304, 306, 308 et 310 sont exécutées entre les étapes 176 et 178.Step 176 can also be executed before step 304 of verifying the integrity of the loaded data block. In this case, for example, steps 304, 306, 308 and 310 are executed between steps 176 and 178.

Lorsque la vérification de l’intégrité du code MACiéchoue, une ou plusieurs des contre-mesures précédemment décrites peuvent être déclenchées et exécutées.When the MAC i code integrity check fails, one or more of the previously described countermeasures can be triggered and executed.

En variante, une autre relation que la relation (1) est utilisée pour déterminer l'adresse @BDCi est enregistré le bloc BDCi. Dans ce cas, la relation (2) doit être adaptée en conséquence. Par exemple, dans un mode de réalisation particulièrement souple, le module 28 comporte une table de correspondance qui, à chaque adresse @BDid’un bloc BDien clair associe l’adresse @BDCidu bloc BDCicontenant les données Di,jsous forme chiffrée. Dans un tel cas, le module 28 peut déterminer l’adresse @BDCidu bloc contenant la donnée Di,jsituée à l’adresse @Di,jen mettant en œuvre les étapes suivantes :
- Étape 1 : le module 28 calcule l’adresse @BDidu bloc BDiqui contient la donnée Di,jà l’aide de la relation suivante : @BDi= E(@Di,j/TBD).TBD, puis
- Etape 2 : le module 28 recherche dans la table de correspondance l’adresse @BDCiassociée à l’adresse @BDicalculée.
As a variant, a relationship other than relationship (1) is used to determine the address @ BDCi where the block BDC i is stored. In this case, relation (2) must be adapted accordingly. For example, in a particularly flexible embodiment, the module 28 comprises a correspondence table which, with each address @ BDi of a block BD i in clear, associates the address @ BDCi of the block BDC i containing the data D i, j in encrypted form. In such a case, the module 28 can determine the address @ BDCi of the block containing the data D i,j located at the address @ Di,j by implementing the following steps:
- Step 1: the module 28 calculates the address @ BDi of the block BD i which contains the data D i,j using the following relationship: @ BDi = E(@ Di,j /T BD ).T BD , then
- Step 2: the module 28 searches in the correspondence table for the address @ BDCi associated with the address @ BDi calculated.

Le fait que les tailles Tbet TBDsoient toutes les deux des puissances de deux impose que la taille Tbest deux fois plus grande que la taille TBD .Ainsi à chaque fois que la taille TBDest augmentée, la taille Tbdoit aussi être augmentée de façon proportionnelle. Cela revient donc à augmenter l’espace disponible pour stocker les métadonnées MDiet le code MACi. Or, il n’est pas toujours souhaitable d’augmenter l’espace disponible pour stocker les métadonnées MDiet le code MACicar cela revient à occuper plus de place en mémoire, sans que cela se traduise nécessairement par une amélioration des performances de l’appareil 1. Ainsi, en variante, la taille Tbn’est pas égale à deux fois la taille TBD. Par exemple, la taille Tbest plus petite que 2TBD. Dans ce dernier cas, de préférence, les tailles Tbet TBDsont alors choisies de manière à ce que le nombre (Tb-TBD) et la taille TBDsont tous les deux des puissances de deux. Dans ce cas, la relation (1) est remplacée par la relation (3) suivante : @BDCi=@BDi+@BDi(Tb-TBD)/TBD. La relation (2) est remplacée par la relation (4) suivante : @BDCi=E(@Di,j/TBD).TBD+E(@Di,j/TBD)(Tb-TBD). Dans les relations (3) et (4), les multiplications et les divisions peuvent toujours être réalisées en utilisant les registres à décalage du module 28 et donc très rapidement. Par contre, par rapport au cas où ce sont les relations (1) et (2) qui sont utilisées, il faut réaliser une opération d’addition en plus pour calculer l’adresse @BDCi. Par conséquent, cette variante est un peu moins rapide que ce qui a été décrit dans le chapitre II. Par contre, elle présente l’avantage d'autoriser une taille TBDqui est supérieure à la taille (Tb-TBD), c’est-à-dire supérieure à la taille des métadonnées MDiet du code MACi.The fact that the sizes T b and T BD are both powers of two imposes that the size T b is twice as large as the size T BD . Thus each time the size T BD is increased, the size T b must also be increased proportionally. This therefore amounts to increasing the space available for storing the metadata MD i and the code MAC i . However, it is not always desirable to increase the space available for storing the MD i metadata and the MAC i code because this amounts to occupying more space in memory, without this necessarily resulting in an improvement in the performance of the device 1. Thus, as a variant, the size T b is not equal to twice the size T BD . For example, size T b is smaller than 2T BD . In the latter case, preferably, the sizes T b and T BD are then chosen so that the number (T b -T BD ) and the size T BD are both powers of two. In this case, relation (1) is replaced by the following relation (3): @ BDCi =@ BDi +@ BDi (T b -T BD )/T BD . Relation (2) is replaced by the following relation (4): @ BDCi =E(@ Di,j /T BD ).T BD +E(@ Di,j /T BD )(T b -T BD ). In the relations (3) and (4), the multiplications and the divisions can always be carried out using the shift registers of the module 28 and therefore very quickly. On the other hand, compared to the case where relations (1) and (2) are used, an addition operation must be performed in addition to calculate the address @ BDCi . Consequently, this variant is a little slower than what was described in chapter II. On the other hand, it has the advantage of authorizing a size T BD which is greater than the size (T b -T BD ), that is to say greater than the size of the metadata MD i and of the code MAC i .

Ce qui a été décrit en détail dans le cas particulier de la partie 44 de la mémoire MP, s'applique à tout autre partie de la mémoire MP contenant des données à protéger. Par exemple, cela peut aussi être appliqué à la pile 46 ou au tas 48. Dans le cas du tas 48, comme déjà indiqué précédemment, l'identifiant IPi,jest généré en même temps que le pointeur PDi,j, c'est-à-dire non pas lors de la compilation mais lors de l'exécution du code binaire 30. Ensuite, l'identifiant IPi,jest enregistré dans le registre BIP, de préférence, à chaque fois qu'une donnée Di,jest écrite, à l'aide de ce pointeur PDi,j, dans la zone de mémoire allouée dynamiquement.What has been described in detail in the particular case of part 44 of the memory MP applies to any other part of the memory MP containing data to be protected. For example, this can also be applied to the stack 46 or to the heap 48. In the case of the heap 48, as already indicated previously, the identifier IP i,j is generated at the same time as the pointer PD i,j , c 'that is to say not during compilation but during the execution of the binary code 30. Then, the identifier IP i,j is recorded in the register B IP , preferably, each time a piece of data D i,j is written, using this pointer PD i,j , in the dynamically allocated memory area.

Dans l'exemple détaillé de mode de réalisation, le transfert par blocs entiers entre l'ensemble 4 et le microprocesseur 2 est uniquement mis en œuvre pour les données et pas pour les instructions du code machine 30. Dans ce cas, les instructions sont enregistrées dans l'ensemble 4 de façon conventionnelle. Ainsi, dans ce mode de réalisation, les instructions sont transférées une par une vers le microprocesseur 2. De plus, dans ce cas, les instructions ne sont pas nécessairement enregistrées sous forme chiffrée dans l'ensemble 4. Toutefois, ce qui a été décrit ici dans le cas particulier des données peut aussi être appliqué aux instructions du code machine 32. Par la suite, lorsqu'un bloc contient des instructions, il est appelé "bloc d'instructions". Par exemple, comme décrit dans le cas particulier des données, le code machine est divisé en blocs d'instructions successifs et contigus. Par exemple, dans un premier mode de réalisation, la structure des bloc de données et des blocs d'instructions sont identiques. De plus, les fonctionnements dans le cas des blocs de données et dans le cas des blocs d'instructions sont identiques. A partir de l'enseignement donné ici dans le cas particulier des blocs de données, l'homme du métier est capable de le transposer, sans difficulté, au cas des instructions. Il est donc seulement souligné que, dans le cas des instructions, l'adresse de la prochaine instruction à charger dans le microprocesseur 2 est contenue dans le compteur ordinal 26 et non pas dans une instruction de chargement exécutée par l'unité 10. Il est également souligné que, de préférence, le tampon utilisé pour stocker un bloc d'instructions en clair est un tampon, par exemple structurellement identique au tampon 14, mais distinct du tampon 14 et dédié au stockage d'un bloc d'instruction. Enfin, il faut remarquer que dans le cas des instructions, les pointeurs d'instructions sont souvent utilisés pour appeler des fonctions et ils sont donc également connus sous le terme de "pointeur de fonction". L'intérêt de traiter exactement de la même manière les instructions et les données est aussi d'harmoniser ces traitements et, par conséquent, de simplifier la réalisation du module 28 de sécurisation.In the detailed exemplary embodiment, the whole-block transfer between assembly 4 and microprocessor 2 is only implemented for data and not for machine code instructions 30. In this case, the instructions are stored in all 4 in a conventional way. Thus, in this embodiment, the instructions are transferred one by one to the microprocessor 2. Moreover, in this case, the instructions are not necessarily recorded in encrypted form in the set 4. However, what has been described here in the particular case of data can also be applied to machine code instructions 32. Hereafter, when a block contains instructions, it is called an "instruction block". For example, as described in the particular case of data, the machine code is divided into successive and contiguous blocks of instructions. For example, in a first embodiment, the structure of the data blocks and the instruction blocks are identical. Moreover, the operations in the case of data blocks and in the case of instruction blocks are identical. From the teaching given here in the particular case of data blocks, the person skilled in the art is able to transpose it, without difficulty, to the case of instructions. It is therefore only emphasized that, in the case of the instructions, the address of the next instruction to be loaded into the microprocessor 2 is contained in the ordinal counter 26 and not in a loading instruction executed by the unit 10. It is also underlined that, preferably, the buffer used to store a block of plaintext instructions is a buffer, for example structurally identical to buffer 14, but distinct from buffer 14 and dedicated to the storage of a block of instructions. Finally, it should be noted that in the case of instructions, instruction pointers are often used to call functions and they are therefore also known as "function pointers". The advantage of processing the instructions and the data in exactly the same way is also to harmonize these processing operations and, consequently, to simplify the production of the security module 28 .

Autres variantes :Other variants:

Les différents modes de réalisation et les différentes variantes ont jusqu’à présent été décrits dans le cas particulier où la mémoire déchiffrée est le tampon 14 et la mémoire chiffrée est l’ensemble 4 de mémoire, c’est-à-dire la mémoire de rang juste supérieur. Toutefois, l’enseignement donné ici s’applique à toutes mémoires déchiffrée et chiffrée entre lesquelles des données sont transférées par bloc entier de données chiffrées et authentifiées. Par exemple, en variante, la mémoire déchiffrée est la mémoire cache L1 et la mémoire chiffrée est la mémoire cache L2. Dans ce cas, le module de sécurisation est, par exemple, implémenté dans la mémoire cache L1 pour chiffrer et déchiffrer les blocs BDCiqui sont transférés entre ces deux mémoires cache L1 et L2. On notera que dans ce cas, les données sont en clair dans la mémoire cache L1 et sont chiffrées dans la mémoire cache L2. A partir du moment où les données sont chiffrées dans la mémoire cache L2, celles-ci seront nécessairement chiffrées dans les mémoires de rang supérieur. Ce qui est décrit ici peut aussi être appliqué entre les mémoires cache L2 et L3 ou entre la mémoire cache L3 et la mémoire principale MP.The different embodiments and the different variants have so far been described in the particular case where the decrypted memory is the buffer 14 and the encrypted memory is the memory set 4, that is to say the memory of rank just above. However, the teaching given here applies to all decrypted and encrypted memories between which data is transferred by whole block of encrypted and authenticated data. For example, alternatively, the decrypted memory is the L1 cache memory and the encrypted memory is the L2 cache memory. In this case, the security module is, for example, implemented in the cache memory L1 to encrypt and decrypt the blocks BDC i which are transferred between these two cache memories L1 and L2. It will be noted that in this case, the data is in clear in the cache memory L1 and is encrypted in the cache memory L2. From the moment the data is encrypted in the L2 cache memory, these will necessarily be encrypted in the memories of higher rank. What is described here can also be applied between the cache memories L2 and L3 or between the cache memory L3 and the main memory MP.

Dans le cas où le module de sécurisation est seulement implémenté entre deux niveaux de mémoire supérieure au tampon 14, le tampon 14 peut être supprimé.In the case where the security module is only implemented between two memory levels higher than buffer 14, buffer 14 can be deleted.

Les modes de réalisation décrits ici peuvent aussi être mis en œuvre dans un appareil dépourvu de mécanisme de mémoire virtuelle. Dans ce cas, la fonction bijective qui relie les adresses virtuelles aux adresses physiques correspondantes est la fonction identité. L'unité MMU est alors omise.The embodiments described here can also be implemented in an apparatus lacking a virtual memory mechanism. In this case, the one-to-one function that links the virtual addresses to the corresponding physical addresses is the identity function. The MMU unit is then omitted.

Chapitre IV : Avantages des modes de réalisation décritsChapter IV: Advantages of the Embodiments Described

L'étape 176 de vérification de la correspondance entre les premier et second identifiants IPi,jpermet de détecter pratiquement tous les usages erronés d'un pointeur. Par exemple, l'étape 176 détecte une utilisation incorrecte d'un pointeur PDkpour lire la donnée Di,j. Plus précisément, si un autre pointeur PDk, différent du pointeur PDi,j attendu, est utilisé pour lire la donnée Di,j, c'est l'identifiant IPk qui est comparé àl'identifiant IPi,jextrait des métadonnées MDi. Par conséquent, cet usage erroné du pointeur PDkest détecté et déclenche donc le signalement d'une faute d'exécution. Si le pointeur PDkest utilisé pour écrire une donnée Dkà la place de la donnée Di,j, alors l'identifiant IPkdu pointeur PDkest enregistréà la place de l'identifiant IP i,j. Par la suite, si le pointeur PDi,j est utilisé pour lire la donnée D k, l'identifiant IPi,jcontenu dans le pointeur PDi,jest différent de l'identifiant IPkcontenu dans les métadonnées MDi. Dès lors, cette utilisation erronée du pointeur PDkest aussi détectée. Grace à cela, les attaques par dépassement de tampon sont détectées.The step 176 of verifying the correspondence between the first and second IP identifiers i,j makes it possible to detect practically all the erroneous uses of a pointer. For example, step 176 detects incorrect use of a pointer PD k to read data D i,j . More precisely, if another pointer PD k , different from the expected pointer PD i,j , is used to read the data D i,j , it is the identifier IP k which is compared with the identifier IP i,j extracted MD i metadata. Consequently, this erroneous use of the pointer PD k is detected and therefore triggers the signaling of an execution fault. If the pointer PD k is used to write a datum D k instead of the datum D i,j , then the identifier IP k of the pointer PD k is recorded instead of the identifier IP i,j . Subsequently, if the pointer PD i,j is used to read the data D k , the identifier IP i,j contained in the pointer PD i,j is different from the identifier IP k contained in the metadata MD i . Consequently, this erroneous use of the pointer PD k is also detected. Thanks to this, buffer overflow attacks are detected.

De même, l'étape 176 permet de détecter l'utilisation du pointeur PDi,japrès que la zone de mémoire contenant la donnée Di,jait été libérée. En effet, typiquement, après la libération de cette zone de mémoire, celle-ci est réutilisée pour y enregistrer d'autres données. Pour réutiliser cette zone de mémoire, un nouveau pointeur PDkest généré puis utilisé pour enregistrer des données dans cette zone de mémoire. Ce nouveau pointeur PDkcomporte un identifiant IPkdifférent de l'identifiant IPi,j. Ensuite, si le pointeur PDi,jest utilisé pour lire l'une des données écrite en utilisant le pointeur PDk, ceci est détecter. En effet, dans ce cas là aussi, les identifiants de pointeur contenus, d'un coté dans le pointeur PDi,j, et de l'autre coté, dans les métadonnées MDk ne correspondent pas. Ainsi, l'étape 176 permet de détecter des attaques utilisant des "dangling pointer" ou des attaques du type "use-after-free".Likewise, step 176 makes it possible to detect the use of the pointer PD i,j after the memory zone containing the data item D i,j has been freed. Indeed, typically, after the freeing of this memory area, the latter is reused to record other data therein. To reuse this memory area, a new pointer PD k is generated and then used to save data in this memory area. This new pointer PD k comprises an identifier IP k different from the identifier IP i,j . Then, if the PD pointer i,j is used to read any of the data written using the PD pointer k , this is detected. Indeed, in this case too, the pointer identifiers contained, on the one hand in the pointer PD i,j , and on the other hand, in the metadata MD k do not correspond . Thus, step 176 makes it possible to detect attacks using “dangling pointers” or attacks of the “use-after-free” type.

Le fait de calculer le code MACicontenu dans le bloc BDCià partir des identifiant IPi,jrend la falsification des valeurs de ces identifiants très difficile. Cela accroît donc la sécurité du procédé d’exécution.The fact of calculating the MAC code i contained in the block BDC i from the IP identifiers i,j makes it very difficult to falsify the values of these identifiers. This therefore increases the security of the execution method.

Le fait d’enregistrer le vecteur ividans les métadonnées MDipermet simplement d’enregistrer puis de retrouver chaque vecteur ivinécessaire pour déchiffrer le cryptogramme BDi *.The fact of recording the vector iv i in the metadata MD i simply makes it possible to record and then find each vector iv i necessary to decipher the cryptogram BD i * .

Le fait que le module 28exécute lui-même les différentes opérations liées au chiffrement, déchiffrement et vérification des données rendtransparent le procédé de sécurisation des données pour l'unité 10. En pratique, l'unité 10 fonctionne comme si toutes les données étaient en clair sans avoir à se préoccuper du chiffrement et du déchiffrement ni de la présence des métadonnées MDidans la mémoire chiffrée.The fact that the module 28 itself executes the various operations related to the encryption, decryption and verification of the data makes the process of securing the data transparent for the unit 10. In practice, the unit 10 operates as if all the data were in plain text without having to worry about encryption and decryption or the presence of MD i metadata in the encrypted memory.

Le fait que le module 28 calcule lui-même l'adresse @BDCidu bloc BDCià partir de laquelle peut être chargée une donnée Di,jà accéder rend la présence des métadonnées MDiet du code MACitransparente pour l'unité 10. En effet, c’est le module 28 qui réalise la conversion d’adresse et non pas l'unité 10.The fact that the module 28 itself calculates the address @ BDCi of the block BDC i from which a data item D i,j to be accessed can be loaded makes the presence of the metadata MD i and of the MAC code i transparent for the unit 10. Indeed, it is module 28 that performs the address conversion and not unit 10.

Claims (9)

Procédé d’exécution d’un programme d'ordinateur par un appareil électronique comportant un microprocesseur, une mémoire déchiffrée, une mémoire chiffrée et un module matériel de sécurisation, dans lequel, lors de l'exécution du programme d'ordinateur, le transfert des lignes de code entre la mémoire déchiffrée et la mémoire chiffrée se fait par bloc entier de plusieurs lignes de code chiffrées et authentifiées, ce procédé comportant les étapes suivantes:
a) l'enregistrement (410) dans la mémoire chiffrée d'un bloc de lignes de code chiffrées et authentifiées contenant une ligne de code à accéder à l'aide d'un pointeur, ce bloc de lignes de code chiffrées et authentifiées contenant :
- un cryptogramme de l'ensemble des lignes de code de ce bloc, ce cryptogramme pouvant uniquement être déchiffré dans sa totalité pour obtenir un bloc de lignes de code en clair et non pas ligne de code par ligne de code,
- un code d'authentification calculé à partir du bloc de lignes de code en clair ou à partir du cryptogramme du bloc de lignes de code en clair, et
-des métadonnées,
b) l’obtention (166), par le microprocesseur, d’un pointeur contenant l’adresse à laquelle est enregistrée la ligne de code à accéder, puis
c) le chargement (302) du bloc contenant la ligne de code à accéder depuis la mémoire chiffrée vers le microprocesseur, puis
d) la vérification (304), par le module matériel de sécurisation et à l'aide du code d'authentification contenu dans le bloc chargé, de l'intégrité :
- du bloc de lignes de codes en clair obtenu à partir du cryptogramme contenu dans le bloc chargé, ou
- du cryptogramme contenu dans le bloc chargé,
e) lorsque cette vérification échoue, l'inhibition (310) du traitement, par le microprocesseur, des lignes de code de ce bloc chargé et, lorsque cette vérification réussie :
- le déchiffrement (306) du cryptogramme contenu dans le bloc chargé pour obtenir le bloc de lignes de code en clair, et
- l'enregistrement (308) du bloc de lignes de code en clair obtenu dans la mémoire déchiffrée et l'enregistrement des métadonnées du bloc chargé,
caractérisé en ce que :
- l'étape a) comporte l'incorporation (408), dans les métadonnées du bloc contenant la ligne de code à accéder, d'un premier identifiant de pointeur associé à la ligne de code à accéder, ce premier identifiant de pointeur permettant à lui seul d’identifier de façon unique un pointeur parmi un ensemble contenant plusieurs pointeurs différents mis en œuvre lors de la même exécution du programme d'ordinateur par le microprocesseur,
- l'étape b) d'obtention (166) du pointeur comporte l'obtention d'un pointeur comprenant :
- une première plage de bits contenant l’adresse de la ligne de code à accéder, et
- une seconde plage différente de bits contenant un second identifiant de pointeur,
- après l'étape c), le procédé comporte une étape f) de vérification (176), par le module matériel de sécurisation, que le second identifiant de pointeur contenu dans le pointeur obtenu lors de l'étape b) correspond au premier identifiant de pointeur associé à la ligne de code à accéder et contenu dans les métadonnées du bloc chargé, et lorsque les premier et second identifiants de pointeur ne correspondent pas, alors le module de sécurisation déclenche (180) le signalement d'une faute d'exécution et, dans le cas contraire, le module de sécurisation inhibe (178) le déclenchement du signalement d'une faute d'exécution et le microprocesseur traite la ligne de code à accéder.
Method for executing a computer program by an electronic device comprising a microprocessor, a decrypted memory, an encrypted memory and a hardware security module, in which, during the execution of the computer program, the transfer of the lines of code between the decrypted memory and the encrypted memory is done by whole block of several encrypted and authenticated lines of code, this process comprising the following steps:
a) the recording (410) in the encrypted memory of a block of encrypted and authenticated lines of code containing a line of code to be accessed using a pointer, this block of encrypted and authenticated lines of code containing:
- a cryptogram of all the lines of code of this block, this cryptogram can only be deciphered in its entirety to obtain a block of lines of code in plain text and not line of code by line of code,
- an authentication code calculated from the block of plaintext lines of code or from the cryptogram of the block of plaintext lines of code, and
- metadata,
b) obtaining (166), by the microprocessor, a pointer containing the address at which the line of code to be accessed is stored, then
c) loading (302) the block containing the line of code to be accessed from the encrypted memory to the microprocessor, then
d) verification (304), by the hardware security module and using the authentication code contained in the loaded block, of the integrity:
- the block of plain code lines obtained from the cryptogram contained in the loaded block, or
- the cryptogram contained in the loaded block,
e) when this verification fails, the inhibition (310) of the processing, by the microprocessor, of the lines of code of this loaded block and, when this verification succeeds:
- the decryption (306) of the cryptogram contained in the loaded block to obtain the block of lines of code in clear, and
- the recording (308) of the block of plain code lines obtained in the decrypted memory and the recording of the metadata of the loaded block,
characterized in that:
- step a) includes the incorporation (408), in the metadata of the block containing the line of code to be accessed, of a first pointer identifier associated with the line of code to be accessed, this first pointer identifier allowing alone to uniquely identify a pointer among a set containing several different pointers implemented during the same execution of the computer program by the microprocessor,
- step b) of obtaining (166) the pointer comprises obtaining a pointer comprising:
- a first range of bits containing the address of the line of code to be accessed, and
- a second different range of bits containing a second pointer identifier,
- after step c), the method comprises a step f) of verification (176), by the hardware security module, that the second pointer identifier contained in the pointer obtained during step b) corresponds to the first identifier pointer associated with the line of code to be accessed and contained in the metadata of the loaded block, and when the first and second pointer identifiers do not match, then the security module triggers (180) the signaling of an execution fault and, in the opposite case, the security module inhibits (178) the triggering of the signaling of an execution fault and the microprocessor processes the line of code to be accessed.
Procédé selon la revendication 1, dans lequel l'étape e) comporte l'enregistrement (308) du premier identifiant de pointeur contenu dans les métadonnées du bloc chargé dans une mémoire uniquement accessible par le module matériel de sécurisation.Method according to claim 1, in which step e) comprises the recording (308) of the first pointer identifier contained in the metadata of the block loaded in a memory only accessible by the hardware security module. Procédé selon l'une quelconque des revendications précédentes, dans lequel, avant l'étape a), le code d'authentification du bloc de lignes de code chiffrées et authentifiées à enregistrer, est aussi calculé (408) à partir des métadonnées.Method according to any one of the preceding claims, in which, before step a), the authentication code of the block of encrypted and authenticated lines of code to be recorded, is also calculated (408) from the metadata. Procédé selon l'une quelconque des revendications précédentes, dans lequel, avant l'étape a), le procédé comporte :
- le chiffrement (406) du bloc de lignes de code en clair en utilisant un vecteur d'initialisation et la génération (404) d'un nouveau vecteur d'initialisation avant chaque chiffrement du bloc de lignes de code en clair, et
- l'incorporation (408) dans les métadonnées du bloc de lignes de code chiffrées et authentifiées, du vecteur d'initialisation utilisé pour obtenir le cryptogramme de ce bloc de lignes de code chiffrées et authentifiées, et
- lors du déchiffrement (306) du cryptogramme, le module matériel de sécurisation extrait des métadonnées du bloc de lignes de code chiffrées et authentifiées, le vecteur d'initialisation à utiliser pour réaliser ce déchiffrement.
Process according to any one of the preceding claims, in which, before step a), the process comprises:
- encrypting (406) the block of plaintext lines of code using an initialization vector and generating (404) a new initialization vector before each encryption of the block of plaintext lines of code, and
- the incorporation (408) in the metadata of the block of encrypted and authenticated lines of code, of the initialization vector used to obtain the cryptogram of this block of encrypted and authenticated lines of code, and
- During decryption (306) of the cryptogram, the hardware security module extracts metadata from the block of encrypted and authenticated lines of code, the initialization vector to be used to perform this decryption.
Procédé selon l'une quelconque des revendications précédentes, dans lequel, lors de l'étape a), l'adresse à laquelle est enregistrée le bloc de lignes de code chiffrées et authentifiées est reliée, par une fonction bijective, à une adresse @BDCidéfinie par la relation suivante : @BDCi= @BDi.Tb/TBD, où :
- @BDiest l'adresse où débute, dans l'espace d'adressage du programme d'ordinateur, le bloc de lignes de code en clair,
- Tbest la taille, en nombre d'octets, du bloc de lignes de code chiffrées et authentifiées,
- TBDest la taille, en nombre d'octets, du bloc de lignes de code en clair.
Method according to any one of the preceding claims, in which, during step a), the address at which the block of encrypted and authenticated lines of code is stored is linked, by a one-to-one function, to an address @ BDCi defined by the following relation: @ BDCi = @ BDi .T b /T BD , where:
- @ BDi is the address where the block of lines of plain code begins, in the address space of the computer program,
- T b is the size, in number of bytes, of the block of encrypted and authenticated lines of code,
- T BD is the size, in number of bytes, of the block of plain code lines.
Procédé selon la revendication 5, dans lequel :
- après l'étape b) et avant l'étape c), le module matériel de sécurisation détermine (172) l'adresse @BDCià l'aide de la première relation suivante : @BDCi= E(@Di,j/TBD).Tb, où
- E() est la fonction qui retourne la partie entière du nombre situé entre les parenthèses, et
- @Di,jest l'adressecontenue dans le pointeur obtenu à l'étape b),
- T b et T BD sont tous les deux des puissances de deux,
lors de cette détermination, la division et la multiplication de la première relation sont exécutées par des registres à décalage du module matériel de sécurisation,puis
- lors de l'étape c), le bloc contenant la ligne de code à accéder est chargé, depuis la mémoire chiffrée, à partir de l'adresse reliée, par la fonction bijective, à l'adresse @BDCidéterminée.
A method according to claim 5, wherein:
- after step b) and before step c), the hardware security module determines (172) the @ BDCi address using the following first relationship: @ BDCi = E(@ Di,j /T BD ).T b , where
- E() is the function that returns the integer part of the number located between the parentheses, and
- @ Di,j is the address contained in the pointer obtained in step b),
- T b and T BD are both powers of two,
during this determination, the division and the multiplication of the first relation are executed by shift registers of the security hardware module, then
- During step c), the block containing the line of code to be accessed is loaded, from the encrypted memory, from the address connected, by the one-to-one function, to the determined address @BDCi .
Procédé selon la revendication 5, dans lequel :
- après l'étape b) et avant l'étape c), le module matériel de sécurisation détermine l'adresse @BDCià l'aide de la seconde relation suivante :@ BDCi = E(@ Di,j /T BD ).T BD + E(@ Di,j /T BD ).(T b -T BD ), où
- E() est la fonction qui retourne la partie entière du nombre situé entre les parenthèses, et
- @Di,jest l'adressecontenue dans le pointeur obtenu à l'étape b),
- (Tb-TBD) et TBDsont tous les deux des puissances de deux,
lors de cette détermination, chaque division et chaque multiplication de la seconde relation sont exécutées par des registres à décalage du module matériel de sécurisation, et
- lors de l'étape c), le bloc contenant la ligne de code à accéder est chargé, depuis la mémoire chiffrée, à partir de l'adresse reliée, par la fonction bijective, à l'adresse @BDCidéterminée.
A method according to claim 5, wherein:
- after step b) and before step c), the hardware security module determines the address @ BDCi using the following second relationship: @ BDCi = E(@ Di,j /T BD ). T BD + E(@ Di,j /T BD ).(T b -T BD ) , where
- E() is the function that returns the integer part of the number located between the parentheses, and
- @ Di,j is the address contained in the pointer obtained in step b),
- (T b -T BD ) and T BD are both powers of two,
during this determination, each division and each multiplication of the second relation are executed by shift registers of the security hardware module, and
- During step c), the block containing the line of code to be accessed is loaded, from the encrypted memory, from the address connected, by the one-to-one function, to the determined address @BDCi .
Programme d'ordinateur apte à être exécuté par un microprocesseur en mettant en œuvre un procédé conforme à l'une quelconque des revendications précédentes, dans lequel le code binaire du programme d'ordinateur comporte :
- un bloc de lignes de code chiffrées et authentifiées contenant une ligne de code à accéder à l'aide d'un pointeur respectif, ce bloc de lignes de code chiffrées et authentifiées contenant :
- un cryptogramme (BDi*) de l'ensemble des lignes de code de ce bloc, ce cryptogramme pouvant uniquement être déchiffré dans sa totalité pour obtenir un bloc de lignes de code en clair et non pas ligne de code par ligne de code,
- un code d'authentification (MACi) calculé à partir du bloc de lignes de code en clair ou à partir du cryptogramme du bloc de lignes de code en clair, et
-des métadonnées (MDi),
- un pointeur contenant l’adresse à laquelle est enregistrée la ligne de code à accéder
caractérisé en ce que:
- les métadonnées (MDi) comporte un premier identifiant de pointeur associé à la ligne de code à accéder, ce premier identifiant de pointeur permettant à lui seul d’identifier de façon unique un pointeur parmi un ensemble contenant plusieurs pointeurs différents mis en œuvre lors de la même exécution du programme d'ordinateur par le microprocesseur, et
- le pointeur comprend :
- une première plage de bits contenant l’adresse de la ligne de code à accéder, et
- une seconde plage différente de bits contenant un second identifiant de pointeur, ce second identifiant de pointeur étant égal au premier identifiant de pointeur.
Computer program capable of being executed by a microprocessor by implementing a method in accordance with any one of the preceding claims, in which the binary code of the computer program comprises:
- a block of encrypted and authenticated lines of code containing a line of code to be accessed using a respective pointer, this block of encrypted and authenticated lines of code containing:
- a cryptogram (BD i *) of all the lines of code of this block, this cryptogram can only be deciphered in its entirety to obtain a block of lines of code in plain text and not line of code by line of code,
- an authentication code (MAC i ) calculated from the block of lines of code in plain text or from the cryptogram of the block of lines of code in plain text, and
- metadata (MD i ),
- a pointer containing the address at which the line of code to be accessed is stored
characterized in that:
- the metadata (MD i ) comprises a first pointer identifier associated with the line of code to be accessed, this first pointer identifier alone making it possible to uniquely identify a pointer from among a set containing several different pointers implemented during of the same execution of the computer program by the microprocessor, and
- the pointer includes:
- a first range of bits containing the address of the line of code to be accessed, and
- a second different range of bits containing a second pointer identifier, this second pointer identifier being equal to the first pointer identifier.
Module matériel (28) de sécurisation pour la mise en œuvre d'un procédé conforme à l'une quelconque des revendications 1 à 7, dans lequel le module matériel est configuré pour :
a) déclencher l'enregistrement dans la mémoire chiffrée d'un bloc de lignes de code chiffrées et authentifiées contenant une ligne de code à accéder à l'aide d'un pointeur, ce bloc de lignes de code chiffrées et authentifiées contenant :
- un cryptogramme de l'ensemble des lignes de code de ce bloc, ce cryptogramme pouvant uniquement être déchiffré dans sa totalité pour obtenir un bloc de lignes de code en clair et non pas ligne de code par ligne de code,
- un code d'authentification calculé à partir du bloc de lignes de code en clair ou à partir du cryptogramme du bloc de lignes de code en clair, et
-des métadonnées,
b) recevoir un pointeur contenant l’adresse à laquelle est enregistrée la ligne de code à accéder, puis
c) déclencher le chargement du bloc contenant la ligne de code à accéder depuis la mémoire chiffrée vers le microprocesseur, puis
d) vérifier, à l'aide du code d'authentification contenu dans le bloc chargé, l'intégrité :
- du bloc de lignes de codes en clair obtenu à partir du cryptogramme contenu dans le bloc chargé, ou
- du cryptogramme contenu dans le bloc chargé,
e) lorsque cette vérification échoue, inhiber le traitement, par le microprocesseur, des lignes de code de ce bloc chargé et, lorsque cette vérification réussie :
- déchiffrer le cryptogramme contenu dans le bloc chargé pour obtenir le bloc de lignes de code en clair, et
- déclencher l'enregistrement du bloc de lignes de code en clair obtenu dans la mémoire déchiffrée et l'enregistrement des métadonnées du bloc chargé,
caractérisé en ce que le module de sécurisation est également configuré :
- pour incorporer, dans les métadonnées du bloc contenant la ligne de code à accéder, un premier identifiant de pointeur associé à la ligne de code à accéder, ce premier identifiant de pointeur permettant à lui seul d’identifier de façon unique un pointeur parmi un ensemble contenant plusieurs pointeurs différents mis en œuvre lors de la même exécution du programme d'ordinateur par le microprocesseur,
- en réponse à l'exécution d'une instruction d'accès à la ligne de code à accéder à l'aide d'un pointeur, pour extraire un second identifiant de pointeur dans une plage de bits de ce pointeur, puis
- pour vérifier que le second identifiant de pointeur correspond au premier identifiant de pointeur associé à la ligne de code à accéder et contenu dans les métadonnées du bloc chargé, et si les premier et second identifiants de pointeur ne correspondent pas, alors déclencher le signalement d'une faute d'exécution et, dans le cas contraire, inhiber le déclenchement du signalement d'une faute d'exécution et autoriser le microprocesseur à traiter la ligne de code à accéder.
Hardware module (28) for securing for the implementation of a method in accordance with any one of claims 1 to 7, in which the hardware module is configured to:
a) triggering the recording in the encrypted memory of a block of encrypted and authenticated lines of code containing a line of code to be accessed using a pointer, this block of encrypted and authenticated lines of code containing:
- a cryptogram of all the lines of code of this block, this cryptogram can only be deciphered in its entirety to obtain a block of lines of code in plain text and not line of code by line of code,
- an authentication code calculated from the block of plaintext lines of code or from the cryptogram of the block of plaintext lines of code, and
- metadata,
b) receive a pointer containing the address at which the line of code to be accessed is stored, then
c) trigger the loading of the block containing the line of code to be accessed from the encrypted memory to the microprocessor, then
d) verify, using the authentication code contained in the loaded block, the integrity:
- the block of plain code lines obtained from the cryptogram contained in the loaded block, or
- the cryptogram contained in the loaded block,
e) when this verification fails, inhibit the processing, by the microprocessor, of the lines of code of this loaded block and, when this verification succeeds:
- decrypt the cryptogram contained in the loaded block to obtain the block of lines of code in clear, and
- trigger the recording of the block of plain code lines obtained in the decrypted memory and the recording of the metadata of the loaded block,
characterized in that the security module is also configured:
- to incorporate, in the metadata of the block containing the line of code to be accessed, a first pointer identifier associated with the line of code to be accessed, this first pointer identifier alone making it possible to uniquely identify a pointer among a set containing several different pointers implemented during the same execution of the computer program by the microprocessor,
- in response to executing an instruction to access the line of code to be accessed using a pointer, to extract a second pointer identifier within a bit range of that pointer, then
- to verify that the second pointer identifier matches the first pointer identifier associated with the line of code to be accessed and contained in the metadata of the loaded block, and if the first and second pointer identifiers do not match, then trigger the flag d an execution fault and, in the contrary case, inhibit the triggering of the signaling of an execution fault and authorize the microprocessor to process the line of code to be accessed.
FR2102263A 2021-03-09 2021-03-09 Process for executing a computer program by an electronic device Active FR3120718B1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
FR2102263A FR3120718B1 (en) 2021-03-09 2021-03-09 Process for executing a computer program by an electronic device
US17/650,861 US20220294634A1 (en) 2021-03-09 2022-02-14 Method for executing a computer program by means of an electronic apparatus
EP22157119.3A EP4057168B1 (en) 2021-03-09 2022-02-16 Method for executing a computer program by an electronic apparatus

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
FR2102263 2021-03-09
FR2102263A FR3120718B1 (en) 2021-03-09 2021-03-09 Process for executing a computer program by an electronic device

Publications (2)

Publication Number Publication Date
FR3120718A1 true FR3120718A1 (en) 2022-09-16
FR3120718B1 FR3120718B1 (en) 2023-02-10

Family

ID=77021388

Family Applications (1)

Application Number Title Priority Date Filing Date
FR2102263A Active FR3120718B1 (en) 2021-03-09 2021-03-09 Process for executing a computer program by an electronic device

Country Status (3)

Country Link
US (1) US20220294634A1 (en)
EP (1) EP4057168B1 (en)
FR (1) FR3120718B1 (en)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20190087566A1 (en) * 2017-09-15 2019-03-21 Arm Limited Call path dependent authentication
EP3761199A1 (en) * 2019-07-05 2021-01-06 Commissariat à l'Energie Atomique et aux Energies Alternatives Method for executing a binary code of a secure function by a microprocessor

Family Cites Families (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2836573A1 (en) * 2002-02-27 2003-08-29 France Telecom Computer representation of a data tree structure, which is representative of the organization of a data set or data dictionary, has first and second total order relations representative of tree nodes and stored data items
US7472285B2 (en) * 2003-06-25 2008-12-30 Intel Corporation Apparatus and method for memory encryption with reduced decryption latency
US7636439B2 (en) * 2004-09-10 2009-12-22 Hitachi Kokusai Electric, Inc. Encryption method, encryption apparatus, data storage distribution apparatus and data delivery system
EP1912148A1 (en) * 2006-10-09 2008-04-16 Axalto S.A. Protection against side channel attacks with an integrity check
EP2107808A1 (en) * 2008-04-03 2009-10-07 Nagravision S.A. Security module (SM) for an audio/video data processing unit
US8364979B1 (en) * 2009-04-27 2013-01-29 Stealth Software Technologies, Inc. Apparatus, system, and method to efficiently search and modify information stored on remote servers, while hiding access patterns
EP2747361B1 (en) * 2012-12-21 2020-07-01 Nagravision S.A. Method using a single authentication device to authenticate a user to a service provider among a plurality of service providers and device for performing such a method
RU2642821C2 (en) * 2013-12-02 2018-01-29 Мастеркард Интернэшнл Инкорпорейтед Method and system for protected transmition of remote notify service messages to mobile devices without protected elements
US9436847B2 (en) * 2014-09-26 2016-09-06 Intel Corporation Cryptographic pointer address encoding
EP3139646A1 (en) * 2015-09-03 2017-03-08 Alcatel Lucent Methods, apparatuses and computer programs for providing a user plane address
US10706400B1 (en) * 2015-11-19 2020-07-07 Wells Fargo Bank, N.A. Systems and methods for financial operations performed at a contactless ATM
US20170250796A1 (en) * 2016-02-18 2017-08-31 Gideon Samid Trans Vernam Cryptography: Round One
DE102016124168A1 (en) * 2016-12-13 2018-06-14 Endress+Hauser Conducta Gmbh+Co. Kg Method for operating a specific field device via a mobile operating device
WO2019027445A1 (en) * 2017-08-01 2019-02-07 Visa International Service Association Private data processing

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20190087566A1 (en) * 2017-09-15 2019-03-21 Arm Limited Call path dependent authentication
EP3761199A1 (en) * 2019-07-05 2021-01-06 Commissariat à l'Energie Atomique et aux Energies Alternatives Method for executing a binary code of a secure function by a microprocessor
US20210004456A1 (en) 2019-07-05 2021-01-07 Commissariat A L'energie Atomique Et Aux Energies Alternatives Method for executing a binary code of a secure function with a microprocessor

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
CLERCQ RUAN DE ET AL: "SOFIA: Software and control flow integrity architecture", 2016 DESIGN, AUTOMATION & TEST IN EUROPE CONFERENCE & EXHIBITION (DATE), EDAA, 14 March 2016 (2016-03-14), pages 1172 - 1177, XP032895110 *

Also Published As

Publication number Publication date
FR3120718B1 (en) 2023-02-10
US20220294634A1 (en) 2022-09-15
EP4057168A1 (en) 2022-09-14
EP4057168B1 (en) 2023-06-28

Similar Documents

Publication Publication Date Title
EP3457620B1 (en) Method for executing a binary code of a secure function by a microprocessor
EP3761199B1 (en) Method for executing a binary code of a secure function by a microprocessor
EP3736719B1 (en) Method for executing a binary code of a secure function by a microprocessor
EP2893431A1 (en) Protection against side channels
EP3712795B1 (en) Method for the execution, by a microprocessor, of a binary code comprising a calling function and a called function
EP3712794B1 (en) Method for executing a binary code of a function secured by a microprocessor
US8566609B2 (en) Integrity of ciphered data
FR2976147A1 (en) DATA INTERLACEMENT DIAGRAM FOR AN EXTERNAL MEMORY OF A SECURE MICROCONTROLLER
FR3071082A1 (en) METHOD FOR EXECUTING A BINARY CODE OF A FUNCTION SECURE BY A MICROPROCESSOR
EP3457621B1 (en) Method for executing a binary code of a secure function by a microprocessor
EP3610372B1 (en) Method for executing a machine code of a secure function
EP4057168B1 (en) Method for executing a computer program by an electronic apparatus
EP3832947B1 (en) Method for executing a computer program by an electronic apparatus
EP4057169B1 (en) Method for executing a binary code of a computer program by a microprocessor
EP3685259B1 (en) Method for executing a machine code of a secure function
FR3010598A1 (en) METHOD FOR MANAGING COHERENCE COACHES
EP1591866B1 (en) Control of execution of an algorithm by an integrated circuit
EP4242884A1 (en) Method for protection against side-channel attacks
EP4328771A1 (en) Method for executing a machine code by a computer
EP4089557A1 (en) Method for executing a binary code by a microprocessor
EP4089558A1 (en) Method for executing a machine code by a microprocessor
FR3105484A1 (en) METHOD OF DYNAMIC VERIFICATION OF THE INTEGRITY OF A MACHINE CODE

Legal Events

Date Code Title Description
PLFP Fee payment

Year of fee payment: 2

PLSC Publication of the preliminary search report

Effective date: 20220916

PLFP Fee payment

Year of fee payment: 3

PLFP Fee payment

Year of fee payment: 4