| dc.contributor.author | Evans, Isaac | |
| dc.contributor.author | Long, Fan | |
| dc.contributor.author | Otgonbaatar, Ulziibayar | |
| dc.contributor.author | Shrobe, Howard E | |
| dc.contributor.author | Rinard, Martin C | |
| dc.contributor.author | Okhravi, Hamed | |
| dc.contributor.author | Sidiroglou-Douskos, Stelios | |
| dc.date.accessioned | 2018-02-22T21:23:24Z | |
| dc.date.available | 2018-02-22T21:23:24Z | |
| dc.date.issued | 2015-10 | |
| dc.identifier.isbn | 978-1-4503-3832-5 | |
| dc.identifier.uri | http://hdl.handle.net/1721.1/113878 | |
| dc.description.abstract | Control flow integrity (CFI) has been proposed as an approach to defend against control-hijacking memory corruption attacks. CFI works by assigning tags to indirect branch targets statically and checking them at runtime. Coarse-grained enforcements of CFI that use a small number of tags to improve the performance overhead have been shown to be ineffective. As a result, a number of recent efforts have focused on fine-grained enforcement of CFI as it was originally proposed. In this work, we show that even a fine-grained form of CFI with unlimited number of tags and a shadow stack (to check calls and returns) is ineffective in protecting against malicious attacks. We show that many popular code bases such as Apache and Nginx use coding practices that create flexibility in their intended control flow graph (CFG) even when a strong static analyzer is used to construct the CFG. These flexibilities allow an attacker to gain control of the execution while strictly adhering to a fine-grained CFI. We then construct two proof-of-concept exploits that attack an unlimited tag CFI system with a shadow stack. We also evaluate the difficulties of generating a precise CFG using scalable static analysis for real-world applications. Finally, we perform an analysis on a number of popular applications that highlights the availability of such attacks. | en_US |
| dc.description.sponsorship | United States. Defense Advanced Research Projects Agency (Grant FA8650-11-C-7192) | en_US |
| dc.language.iso | en_US | |
| dc.publisher | Association for Computing Machinery | en_US |
| dc.relation.isversionof | http://dx.doi.org/10.1145/2810103.2813646 | en_US |
| dc.rights | Creative Commons Attribution-Noncommercial-Share Alike | en_US |
| dc.rights.uri | http://creativecommons.org/licenses/by-nc-sa/4.0/ | en_US |
| dc.source | MIT Web Domain | en_US |
| dc.title | Control Jujutsu | en_US |
| dc.type | Article | en_US |
| dc.identifier.citation | Evans, Isaac, et al. "Control Jujutsu: On the Weaknesses of Fine-Grained Control Flow Integrity." Proceedings of the 22nd ACM SIGSAC Conference on Computer and Communications Security, 12-16 October, 2015, Denver, Colorado, ACM Press, 2015, pp. 901–13. | en_US |
| dc.contributor.department | Lincoln Laboratory | en_US |
| dc.contributor.department | Massachusetts Institute of Technology. Computer Science and Artificial Intelligence Laboratory | en_US |
| dc.contributor.department | Massachusetts Institute of Technology. Department of Electrical Engineering and Computer Science | en_US |
| dc.contributor.mitauthor | Evans, Isaac | |
| dc.contributor.mitauthor | Long, Fan | |
| dc.contributor.mitauthor | Otgonbaatar, Ulziibayar | |
| dc.contributor.mitauthor | Shrobe, Howard E | |
| dc.contributor.mitauthor | Rinard, Martin C | |
| dc.contributor.mitauthor | Okhravi, Hamed | |
| dc.contributor.mitauthor | Sidiroglou-Douskos, Stelios | |
| dc.relation.journal | Proceedings of the 22nd ACM SIGSAC Conference on Computer and Communications Security - CCS '15 | en_US |
| dc.eprint.version | Author's final manuscript | en_US |
| dc.type.uri | http://purl.org/eprint/type/ConferencePaper | en_US |
| eprint.status | http://purl.org/eprint/status/NonPeerReviewed | en_US |
| dspace.orderedauthors | Evans, Isaac; Long, Fan; Otgonbaatar, Ulziibayar; Shrobe, Howard; Rinard, Martin; Okhravi, Hamed; Sidiroglou-Douskos, Stelios | en_US |
| dspace.embargo.terms | N | en_US |
| dc.identifier.orcid | https://orcid.org/0000-0003-3322-656X | |
| dc.identifier.orcid | https://orcid.org/0000-0002-6232-3118 | |
| dc.identifier.orcid | https://orcid.org/0000-0002-9993-9135 | |
| dc.identifier.orcid | https://orcid.org/0000-0001-8095-8523 | |
| mit.license | OPEN_ACCESS_POLICY | en_US |