-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathprocessrom.py
More file actions
143 lines (131 loc) · 4.75 KB
/
Copy pathprocessrom.py
File metadata and controls
143 lines (131 loc) · 4.75 KB
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
import idc
import idaapi
import re
def processrom(min, max):
if min > 0:
min = min - 1
curaddr = idc.find_unknown(min, idc.SEARCH_DOWN)
while curaddr < max:
if idc.add_func(curaddr) != True:
idc.create_insn(curaddr)
curaddr = idc.find_unknown(curaddr, idc.SEARCH_DOWN)
return
def defineoffset(min, max):
for addr in range(min, max, 4):
idc.op_plain_offset(addr,1,0)
def defineasstruct(name, min, max):
struct_id = idaapi.get_struc_id(name)
if struct_id == idaapi.BADADDR:
print("Structure {} does not exist".format(name))
return
print("Struct_id with name {} = {}".format(name, struct_id))
struct_size = idc.get_struc_size(struct_id)
print("size = {}".format(struct_size))
for addr in range(min, max, struct_size):
print("Set addr = {:02X} to struct".format(addr))
idc.SetType(addr, name)
def undefcode(min, max):
if min > 0:
min = min - 1
curaddr = idc.find_code(min, idc.SEARCH_DOWN)
while curaddr < max:
idc.del_items(curaddr)
curaddr = idc.find_code(curaddr, idc.SEARCH_DOWN)
return
def makedata(min, max, flags, size, tid):
curaddr = min
while curaddr < max:
idc.del_items(curaddr, size, idaapi.DELIT_SIMPLE)
idc.create_data(curaddr, flags, size, tid)
curaddr += size
return
def a2l(filename):
lastvarname = ""
lastaddress = ""
with open(filename) as fp:
f = fp.read()
measurements = f.split("/begin MEASUREMENT")
measurements.pop(0)
print("Found: %d measurement(s)" % len(measurements))
for m in measurements:
namefound = 0
addrfound = 0
name = ""
addr = ""
is_enum = False
bit_mask = 0
for l in m.split("\n"):
l = l.strip()
if (len(l) > 0):
if (namefound == 0):
name = l
namefound = 1
elif (l.startswith("BIT_MASK")):
is_enum = True
splitted = l.split(" ")
if len(splitted) < 2:
splitted = l.split("\t")
if len(splitted) > 1:
bit_mask = int(splitted[1], 16)
elif (l.startswith("ECU_ADDRESS")):
addr = l[12:]
addrfound = 1
break
if (addrfound != 1):
print("ERROR")
elif (is_enum):
enum_name = "enum_" + addr[2:]
enum_id = idc.get_enum(enum_name)
if (enum_id == 4294967295):
enum_id = idc.add_enum(-1, enum_name, 0)
idc.op_enum(int(addr, 0), -1, enum_id, 0)
idc.set_name(int(addr, 0), "", 0)
if (not idc.is_bf(enum_id)):
idc.set_enum_bf(enum_id, 1)
idc.add_enum_member(enum_id, name, bit_mask, bit_mask)
else:
idc.del_items(int(addr, 0), 1, idaapi.DELIT_SIMPLE)
idc.set_name(int(addr, 0), name, 1)
characteristics = f.split("/begin CHARACTERISTIC")
characteristics.pop(0)
print("Found: %d characteristics(s)" % len(characteristics))
for m in characteristics:
namefound = 0
addrfound = 0
name = ""
addr = ""
is_enum = False
bit_mask = 0
for l in m.split("\n"):
l = l.strip()
if (len(l) > 0):
if (namefound == 0):
name = l
namefound = 1
elif (l.startswith("/begin IF_DATA ASAP1B_CCP")):
print(l)
addr = l.split(" ")[5]
print(addr)
#addr = l[28:7]
addrfound = 1
break
if (addrfound != 1):
print("ERROR", name)
else:
print("addr", addr)
idc.del_items(int(addr, 0), 1, idaapi.DELIT_SIMPLE)
idc.set_name(int(addr, 0), name, 1)
return
def get_addr_from_disasm(line):
match = re.search("_+[0-9a-fA-F]+", line)
if match:
return int(match.group(0)[1:],16)
def set_memory_dword():
curaddr = get_screen_ea()
curline = idc.GetDisasm(get_screen_ea())
addr_to_set = get_addr_from_disasm(curline)
nextline = idc.GetDisasm(get_screen_ea() + 4)
addr_from_set = get_addr_from_disasm(nextline)
print(addr_to_set, addr_from_set)
if addr_to_set and addr_from_set:
patch_dword(addr_to_set, addr_from_set)