The patent badge is an abbreviated version of the USPTO patent document. The patent badge does contain a link to the full patent document.

The patent badge is an abbreviated version of the USPTO patent document. The patent badge covers the following: Patent number, Date patent was issued, Date patent was filed, Title of the patent, Applicant, Inventor, Assignee, Attorney firm, Primary examiner, Assistant examiner, CPCs, and Abstract. The patent badge does contain a link to the full patent document (in Adobe Acrobat format, aka pdf). To download or print any patent click here.

Date of Patent:
May. 30, 2017

Filed:

Sep. 13, 2016
Applicant:

International Business Machines Corporation, Armonk, NY (US);

Inventors:

Omer Y. Boehm, Haifa, IL;

Eitan D. Farchi, Pardes Hana, IL;

Oded Margalit, Ramat Gan, IL;

Yousef Shajrawi, Haifa, IL;

Michael Vinov, Nofit, IL;

Attorney:
Primary Examiner:
Int. Cl.
CPC ...
G06F 11/00 (2006.01); G06F 21/56 (2013.01); G06F 3/06 (2006.01);
U.S. Cl.
CPC ...
G06F 21/566 (2013.01); G06F 3/064 (2013.01); G06F 3/0623 (2013.01); G06F 3/0673 (2013.01);
Abstract

Mitigating return-oriented programming (ROP) attacks. Program code and associated components are received and loaded into memory. From the program code and associated components, a predetermined number of sequences of machine language instructions that terminate in a return instruction are selected. The sequences of machine language instructions include: machine language instruction sequences that are equivalent to a conditional statement 'if-then-else return,' sequences of machine language instructions corresponding to known malicious code sequences, and sequences of machine language instructions corresponding to machine language instructions in known toolkits for assembling malicious code sequences. For each selected machine language instruction sequence, memory blocks containing the selected machine language instruction sequence are rearranged using address space layout randomization (ASLR); then, upon expiration of an expected time interval required to locate the selected machine language instruction sequence by inspecting the rearranged memory blocks, the rearranging is repeated, thereby mitigating ROP attacks.


Find Patent Forward Citations

Loading…