Ruan, YefengKalyanasundaram, SivapriyaZou, Xukai2017-02-162017-02-162016-07Ruan, Y., Kalyanasundaram, S., & Zou, X. (2015). Survey of return‐oriented programming defense mechanisms. Security and Communication Networks, 9 (10), 1247–1265. http://dx.doi.org/10.1002/sec.1406https://hdl.handle.net/1805/11922A prominent software security violation-buffer overflow attack has taken various forms and poses serious threats until today. One such vulnerability is return-oriented programming attack. An return-oriented programming attack circumvents the dynamic execution prevention, which is employed in modern operating systems to prevent execution of data segments, and attempts to execute unintended instructions by overwriting the stack exploiting the buffer overflow vulnerability. Numerous defense mechanisms have been proposed in the past few years to mitigate/prevent the attack – compile time methods that add checking logic to the program code before compilation, dynamic methods that monitor the control-flow integrity during execution and randomization methods that aim at randomizing instruction locations. This paper discusses (i) these different static, dynamic, and randomization techniques proposed recently and (ii) compares the techniques based on their effectiveness and performances.enIUPUI Open Access PolicyROPbuffer overflowcontrol flow integritySurvey of Return-Oriented Programming Defense MechanismsArticle