APPLICATION PIRACY PREVENTION WITH SECURE ENCLAVE PROTECTION OF AUTOMATICALLY MODULARIZED FUNCTIONS

A compiler automatically modularizes identified functions or portions of source code, thereby enabling developers to merely identify portions of source code that represent functionality that is to be protected, including going back and identifying such portions after the programming of the software...

Ausführliche Beschreibung

Gespeichert in:
Bibliographische Detailangaben
Hauptverfasser: BOSTANCI, Hakki Tunc, MILLER, Olaf Alexander, CHEN, Ling Tony
Format: Patent
Sprache:eng ; fre
Schlagworte:
Online-Zugang:Volltext bestellen
Tags: Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
Beschreibung
Zusammenfassung:A compiler automatically modularizes identified functions or portions of source code, thereby enabling developers to merely identify portions of source code that represent functionality that is to be protected, including going back and identifying such portions after the programming of the software application program has been substantially completed. Such identification can be inline, within the source code itself, or specified in an external file. During compilation of such source code, a compiler recognizes such identifications and appropriately compiles the source code such that the relevant portions of the software application program are appropriately modularized, including inserting functionality to provide for marshaling of parameters between functionality that will be protected and functionality that will be executed outside of the enclave, as well as appropriately modifying pointers or addresses to be position independent based upon where the functionality making reference to such pointers or addresses will be executed. Un compilateur modularise automatiquement des fonctions ou des parties identifiées d'un code source, ce qui permet à des développeurs d'identifier simplement des parties du code source qui représentent une fonctionnalité devant être protégée, notamment en revenant à ces parties et en les identifiant une fois la programmation du programme d'application logicielle sensiblement achevée. Une telle identification est possible en ligne ou dans le code source lui-même. Elle peut également être spécifiée dans un fichier externe. Pendant une compilation de ce code source, un compilateur reconnaît ces identifications et compile judicieusement le code source de telle sorte que les parties pertinentes du programme d'application logicielle sont modularisées de manière appropriée, notamment en insérant une fonctionnalité visant à permettre un ordonnancement de paramètres entre une fonctionnalité qui sera protégée et une fonctionnalité qui sera exécutée en dehors de l'enclave, ainsi qu'une modification appropriée de pointeurs ou d'adresses afin qu'ils soient indépendants d'une position sur la base de l'emplacement auquel la fonctionnalité faisant référence à ces pointeurs ou adresses sera exécutée.