|
This article is cited in 3 scientific papers (total in 3 papers)
Theory of data
About detection of code reuse attacks
Yu. V. Kosolapov Southern Federal University,
8a Milchakova str., Rostov-on-Don 344090, Russia
Abstract:
When exploiting software vulnerabilities such as buffer overflows, code reuse techniques are often used today. Such attacks allow you to bypass the protection against the execution of code in the stack, which is implemented at the software and hardware level in modern information systems. At the heart of these attacks lies the detection, in the vulnerable program of suitable areas, of executable code — gadgets — and chaining these gadgets into chains. The article proposes a way to protect applications from attacks that use code reuse. For this purpose, features that distinguish the chains of gadgets from typical chains of legal basic blocks of the program are highlighted. The appearance of an atypical chain of the base block during program execution may indicate the execution of a malicious code. An algorithm for identifying atypical chains has been developed. A feature of the algorithm is that it is focused on identifying all currently known techniques of re-execution of the code. The developed algorithm is based on a modified QEMU virtualization system. One of the hallmarks of the chain of gadgets is the execution at the end of the chain of instructions of the processor used to call the function of the operating system. For the Linux operating system based on the x86/64 architecture, experiments have been conducted showing the importance of this feature in detecting the execution of the malicious code.
Keywords:
code reuse, software vulnerability.
Received: 17.12.2018 Revised: 13.05.2019 Accepted: 15.05.2019
Citation:
Yu. V. Kosolapov, “About detection of code reuse attacks”, Model. Anal. Inform. Sist., 26:2 (2019), 213–228
Linking options:
https://www.mathnet.ru/eng/mais674 https://www.mathnet.ru/eng/mais/v26/i2/p213
|
|