forked from grayhatacademy/ghidra_scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
MipsRopFind.py
35 lines (26 loc) · 849 Bytes
/
MipsRopFind.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# Find MIPS ROP gadgets that contain a user specified instruction.
#@author fuzzywalls
#@category TNS
#@menupath TNS.Mips Rops.Gadgets.Find
import re
from utils import mipsrop, utils
utils.allowed_processors(currentProgram, 'MIPS')
op1 = None
op2 = None
op3 = None
search = askString(
'MIPS ROP Find', 'What instruction do you want to search for?')
try:
search = re.sub(' +', ' ', search)
mnem, operands = search.split(' ', 1)
operands = operands.replace(' ', '')
operands = operands.split(',')
op1, op2, op3 = operands + [None] * (3 - len(operands))
except ValueError:
mnem = search
if not mnem.startswith('.*'):
mnem = '.*' + mnem
search_ins = mipsrop.MipsInstruction(mnem, op1, op2, op3)
mips_rop = mipsrop.MipsRop(currentProgram)
results = mips_rop.find_instructions([search_ins])
results.pretty_print()