Skip to content

Commit

Permalink
Fix typo found by codespell - API breaking change
Browse files Browse the repository at this point in the history
  • Loading branch information
DimitriPapadopoulos committed Mar 18, 2024
1 parent 2b1273e commit 0eff902
Show file tree
Hide file tree
Showing 4 changed files with 123 additions and 123 deletions.
113 changes: 0 additions & 113 deletions example/expression/interfer.py

This file was deleted.

113 changes: 113 additions & 0 deletions example/expression/interfere.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,113 @@
from miasm.analysis.data_flow import State
from miasm.expression.expression import *

"""
Test memory interferences
A memory interference may appear when two ExprMem objects relate to the same area of memory: editing one may impact the other.
"""

a32 = ExprId('a', 32)
b32 = ExprId('b', 32)

a64 = ExprId('a', 64)
b64 = ExprId('b', 64)

mem_a32_32 = ExprMem(a32, 32)
mem_b32_32 = ExprMem(b32, 32)

mem_a64_32 = ExprMem(a64, 32)

mem_a32_m1_8 = ExprMem(a32 + ExprInt(-1, 32), 8)
mem_a32_p0_8 = ExprMem(a32, 8)
mem_a32_p1_8 = ExprMem(a32 + ExprInt(1, 32), 8)
mem_a32_p2_8 = ExprMem(a32 + ExprInt(2, 32), 8)
mem_a32_p3_8 = ExprMem(a32 + ExprInt(3, 32), 8)
mem_a32_p4_8 = ExprMem(a32 + ExprInt(4, 32), 8)


mem_a32_m4_32 = ExprMem(a32 + ExprInt(-4, 32), 32)
mem_a32_m3_32 = ExprMem(a32 + ExprInt(-3, 32), 32)
mem_a32_m2_32 = ExprMem(a32 + ExprInt(-2, 32), 32)
mem_a32_m1_32 = ExprMem(a32 + ExprInt(-1, 32), 32)
mem_a32_p0_32 = ExprMem(a32, 32)
mem_a32_p1_32 = ExprMem(a32 + ExprInt(1, 32), 32)
mem_a32_p2_32 = ExprMem(a32 + ExprInt(2, 32), 32)
mem_a32_p3_32 = ExprMem(a32 + ExprInt(3, 32), 32)
mem_a32_p4_32 = ExprMem(a32 + ExprInt(4, 32), 32)


mem_a64_m4_32 = ExprMem(a64 + ExprInt(-4, 64), 32)
mem_a64_m3_32 = ExprMem(a64 + ExprInt(-3, 64), 32)
mem_a64_m2_32 = ExprMem(a64 + ExprInt(-2, 64), 32)
mem_a64_m1_32 = ExprMem(a64 + ExprInt(-1, 64), 32)
mem_a64_p0_32 = ExprMem(a64, 32)
mem_a64_p1_32 = ExprMem(a64 + ExprInt(1, 64), 32)
mem_a64_p2_32 = ExprMem(a64 + ExprInt(2, 64), 32)
mem_a64_p3_32 = ExprMem(a64 + ExprInt(3, 64), 32)
mem_a64_p4_32 = ExprMem(a64 + ExprInt(4, 64), 32)


state = State()


assert state.may_interfere(set([mem_a32_32]), mem_b32_32) == True
assert state.may_interfere(set([mem_b32_32]), mem_a32_32) == True

# Test 8 bit accesses
assert state.may_interfere(set([mem_a32_m1_8]), mem_a32_32) == False
assert state.may_interfere(set([mem_a32_p0_8]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p1_8]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p2_8]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p3_8]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p4_8]), mem_a32_32) == False

assert state.may_interfere(set([mem_a32_32]), mem_a32_m1_8) == False
assert state.may_interfere(set([mem_a32_32]), mem_a32_p0_8) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p1_8) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p2_8) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p3_8) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p4_8) == False


# Test 32 bit accesses
assert state.may_interfere(set([mem_a32_m4_32]), mem_a32_32) == False
assert state.may_interfere(set([mem_a32_m3_32]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_m2_32]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_m1_32]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p0_32]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p1_32]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p2_32]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p3_32]), mem_a32_32) == True
assert state.may_interfere(set([mem_a32_p4_32]), mem_a32_32) == False

assert state.may_interfere(set([mem_a32_32]), mem_a32_m4_32) == False
assert state.may_interfere(set([mem_a32_32]), mem_a32_m3_32) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_m2_32) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_m1_32) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p0_32) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p1_32) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p2_32) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p3_32) == True
assert state.may_interfere(set([mem_a32_32]), mem_a32_p4_32) == False

# Test 32 bit accesses with 64 bit memory address
assert state.may_interfere(set([mem_a64_m4_32]), mem_a64_32) == False
assert state.may_interfere(set([mem_a64_m3_32]), mem_a64_32) == True
assert state.may_interfere(set([mem_a64_m2_32]), mem_a64_32) == True
assert state.may_interfere(set([mem_a64_m1_32]), mem_a64_32) == True
assert state.may_interfere(set([mem_a64_p0_32]), mem_a64_32) == True
assert state.may_interfere(set([mem_a64_p1_32]), mem_a64_32) == True
assert state.may_interfere(set([mem_a64_p2_32]), mem_a64_32) == True
assert state.may_interfere(set([mem_a64_p3_32]), mem_a64_32) == True
assert state.may_interfere(set([mem_a64_p4_32]), mem_a64_32) == False

assert state.may_interfere(set([mem_a64_32]), mem_a64_m4_32) == False
assert state.may_interfere(set([mem_a64_32]), mem_a64_m3_32) == True
assert state.may_interfere(set([mem_a64_32]), mem_a64_m2_32) == True
assert state.may_interfere(set([mem_a64_32]), mem_a64_m1_32) == True
assert state.may_interfere(set([mem_a64_32]), mem_a64_p0_32) == True
assert state.may_interfere(set([mem_a64_32]), mem_a64_p1_32) == True
assert state.may_interfere(set([mem_a64_32]), mem_a64_p2_32) == True
assert state.may_interfere(set([mem_a64_32]), mem_a64_p3_32) == True
assert state.may_interfere(set([mem_a64_32]), mem_a64_p4_32) == False
18 changes: 9 additions & 9 deletions miasm/analysis/data_flow.py
Original file line number Diff line number Diff line change
Expand Up @@ -1877,7 +1877,7 @@ class State(object):
The state is represented using equivalence classes
Each assignment can create/destroy equivalence classes. Interferences
between expression is computed using `may_interfer` function
between expression is computed using `may_interfere` function
"""

def __init__(self):
Expand Down Expand Up @@ -1908,9 +1908,9 @@ def __ne__(self, other):
# required Python 2.7.14
return not self == other

def may_interfer(self, dsts, src):
def may_interfere(self, dsts, src):
"""
Return True is @src may interfer with expressions in @dsts
Return True is @src may interfere with expressions in @dsts
@dsts: Set of Expressions
@src: expression to test
"""
Expand Down Expand Up @@ -2084,8 +2084,8 @@ def eval_assignblock(self, assignblock):
# Remove interfering known classes
to_del = set()
for node in list(classes.nodes()):
if self.may_interfer(dsts, node):
# Interfer with known equivalence class
if self.may_interfere(dsts, node):
# Interfere with known equivalence class
self.equivalence_classes.del_element(node)
if node.is_id() or node.is_mem():
self.undefined.add(node)
Expand All @@ -2104,8 +2104,8 @@ def eval_assignblock(self, assignblock):
if node.is_id() or node.is_mem():
self.undefined.add(node)

# Don't create equivalence if self interfer
if self.may_interfer(dsts, src):
# Don't create equivalence if self interfere
if self.may_interfere(dsts, src):
if dst in self.equivalence_classes.nodes():
self.equivalence_classes.del_element(dst)
if dst.is_id() or dst.is_mem():
Expand Down Expand Up @@ -2137,7 +2137,7 @@ def merge(self, other):
undefined = set(node for node in self.undefined if node.is_id() or node.is_mem())
undefined.update(set(node for node in other.undefined if node.is_id() or node.is_mem()))
# Should we compute interference between srcs and undefined ?
# Nop => should already interfer in other state
# Nop => should already interfere in other state
components1 = classes1.get_classes()
components2 = classes2.get_classes()

Expand Down Expand Up @@ -2173,7 +2173,7 @@ def merge(self, other):
continue
if common:
# Intersection contains multiple nodes
# Here, common nodes don't interfer with any undefined
# Here, common nodes don't interfere with any undefined
nodes_ok.update(common)
out.append(common)
diff = component1.difference(common)
Expand Down
2 changes: 1 addition & 1 deletion test/test_all.py
Original file line number Diff line number Diff line change
Expand Up @@ -713,7 +713,7 @@ class ExampleExpression(Example):
["expr_random.py"],
["expr_translate.py"],
["expr_reduce.py"],
["interfer.py"],
["interfere.py"],
]:
testset += ExampleExpression(script)

Expand Down

0 comments on commit 0eff902

Please sign in to comment.