Subversive-C: Abusing and Protecting Dynamic Message Dispatch

  • Julian Lettner ,
  • Benjamin Kollenda ,
  • Andrei Homescu ,
  • Per Larsen ,
  • Felix Schuster ,
  • Lucas Davi ,
  • Ahmad-Reza Sadeghi ,
  • Thorsten Holz ,
  • Michael Franz

2016 USENIX Annual Technical Conference (USENIX ATC 16) |

Published by USENIX Association

The lower layers in the modern computing infrastructure are written in languages threatened by exploitation of memory management errors. Recently deployed exploit mitigations such as control-flow integrity (CFI) can prevent traditional return-oriented programming (ROP) exploits but are much less effective against newer techniques such as Counterfeit Object-Oriented Programming (COOP) that execute a chain of C++ virtual methods. Since these methods are valid control-flow targets, COOP attacks are hard to distinguish from benign computations. Code randomization is likewise ineffective against COOP. Until now, however, COOP attacks have been limited to vulnerable C++ applications which makes it unclear whether COOP is as general and portable a threat as ROP. This paper demonstrates the first COOP-style exploit for Objective-C, the predominant programming language on Apple’s OS X and iOS platforms. We also retrofit the Objective-C runtime with the first practical and efficient defense against our novel attack. Our defense is able to protect complex, real-world software such as iTunes without recompilation. Our performance experiments show that the overhead of our defense is low in practice.