Miasm2
 All Classes Namespaces Files Functions Variables Typedefs Properties Macros
Public Member Functions | Public Attributes | Static Public Attributes | Properties | Private Member Functions | Private Attributes | List of all members
miasm2.expression.expression.ExprCond Class Reference
+ Inheritance diagram for miasm2.expression.expression.ExprCond:
+ Collaboration diagram for miasm2.expression.expression.ExprCond:

Public Member Functions

def __init__
 
def __str__
 
def get_r
 
def get_w
 
def __contains__
 
def visit
 
def copy
 
def depth
 
def graph_recursive
 
def set_size
 
def __getitem__
 
def get_size
 
def is_function_call
 
def __repr__
 
def __hash__
 
def pre_eq
 
def __eq__
 
def __ne__
 
def __add__
 
def __sub__
 
def __div__
 
def __mod__
 
def __mul__
 
def __lshift__
 
def __rshift__
 
def __xor__
 
def __or__
 
def __and__
 
def __neg__
 
def __invert__
 
def replace_expr
 
def canonize
 
def msb
 
def zeroExtend
 
def signExtend
 
def graph
 
def set_mask
 

Public Attributes

 arg
 

Static Public Attributes

 is_term = False
 
 is_simp = False
 
 is_canon = False
 
 is_eval = False
 

Properties

 cond = property(lambda self: self._cond)
 
 src1 = property(lambda self: self._src1)
 
 src2 = property(lambda self: self._src2)
 
 size = property(lambda self: self._size)
 
 mask = property(lambda self: ExprInt(-1, self.size))
 

Private Member Functions

def _exprhash
 
def _exprrepr
 

Private Attributes

 _src2
 
 _size
 

Detailed Description

An ExprCond stand for a condition on an Expr

Use cases:
 - var1 < var2
 - min(var1, var2)
 - if (cond) then ... else ...

Definition at line 571 of file expression.py.

Constructor & Destructor Documentation

def miasm2.expression.expression.ExprCond.__init__ (   self,
  cond,
  src1,
  src2 
)
Create an ExprCond
@cond: Expr, condition
@src1: Expr, value if condition is evaled to not zero
@src2: Expr, value if condition is evaled zero

Definition at line 581 of file expression.py.

582  def __init__(self, cond, src1, src2):
583  """Create an ExprCond
584  @cond: Expr, condition
585  @src1: Expr, value if condition is evaled to not zero
586  @src2: Expr, value if condition is evaled zero
587  """
588 
589  assert(src1.size == src2.size)
591  self._cond, self._src1, self._src2 = cond, src1, src2
592  self._size = self.src1.size

Member Function Documentation

def miasm2.expression.expression.Expr.__add__ (   self,
  a 
)
inherited

Definition at line 192 of file expression.py.

193  def __add__(self, a):
194  return ExprOp('+', self, a)

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.__and__ (   self,
  a 
)
inherited

Definition at line 219 of file expression.py.

220  def __and__(self, a):
221  return ExprOp('&', self, a)

+ Here is the caller graph for this function:

def miasm2.expression.expression.ExprCond.__contains__ (   self,
  e 
)

Definition at line 617 of file expression.py.

618  def __contains__(self, e):
619  return (self == e or
620  self._cond.__contains__(e) or
621  self._src1.__contains__(e) or
622  self._src2.__contains__(e))
def miasm2.expression.expression.Expr.__div__ (   self,
  a 
)
inherited

Definition at line 198 of file expression.py.

199  def __div__(self, a):
200  return ExprOp('/', self, a)
def miasm2.expression.expression.Expr.__eq__ (   self,
  other 
)
inherited

Definition at line 183 of file expression.py.

184  def __eq__(self, other):
185  res = self.pre_eq(other)
186  if res is not None:
187  return res
188  return repr(self) == repr(other)

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.__getitem__ (   self,
  i 
)
inherited

Definition at line 138 of file expression.py.

139  def __getitem__(self, i):
140  if not isinstance(i, slice):
141  raise TypeError("Expression: Bad slice: %s" % i)
142  start, stop, step = i.indices(self.size)
143  if step != 1:
144  raise ValueError("Expression: Bad slice: %s" % i)
145  return ExprSlice(self, start, stop)
def miasm2.expression.expression.Expr.__hash__ (   self)
inherited

Definition at line 165 of file expression.py.

166  def __hash__(self):
167  if self._hash is None:
168  self._hash = self._exprhash()
169  return self._hash

+ Here is the call graph for this function:

def miasm2.expression.expression.Expr.__invert__ (   self)
inherited

Definition at line 225 of file expression.py.

226  def __invert__(self):
227  s = self.size
228  return ExprOp('^', self, ExprInt(mod_size2uint[s](size2mask(s))))

+ Here is the call graph for this function:

def miasm2.expression.expression.Expr.__lshift__ (   self,
  a 
)
inherited

Definition at line 207 of file expression.py.

208  def __lshift__(self, a):
209  return ExprOp('<<', self, a)
def miasm2.expression.expression.Expr.__mod__ (   self,
  a 
)
inherited

Definition at line 201 of file expression.py.

202  def __mod__(self, a):
203  return ExprOp('%', self, a)
def miasm2.expression.expression.Expr.__mul__ (   self,
  a 
)
inherited

Definition at line 204 of file expression.py.

205  def __mul__(self, a):
206  return ExprOp('*', self, a)

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.__ne__ (   self,
  a 
)
inherited

Definition at line 189 of file expression.py.

190  def __ne__(self, a):
191  return not self.__eq__(a)

+ Here is the call graph for this function:

def miasm2.expression.expression.Expr.__neg__ (   self)
inherited

Definition at line 222 of file expression.py.

223  def __neg__(self):
224  return ExprOp('-', self)
def miasm2.expression.expression.Expr.__or__ (   self,
  a 
)
inherited

Definition at line 216 of file expression.py.

217  def __or__(self, a):
218  return ExprOp('|', self, a)

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.__repr__ (   self)
inherited

Definition at line 160 of file expression.py.

161  def __repr__(self):
162  if self._repr is None:
163  self._repr = self._exprrepr()
164  return self._repr

+ Here is the call graph for this function:

def miasm2.expression.expression.Expr.__rshift__ (   self,
  a 
)
inherited

Definition at line 210 of file expression.py.

211  def __rshift__(self, a):
212  return ExprOp('>>', self, a)
def miasm2.expression.expression.ExprCond.__str__ (   self)

Definition at line 597 of file expression.py.

598  def __str__(self):
599  return "(%s?(%s,%s))" % (str(self._cond), str(self._src1), str(self._src2))
def miasm2.expression.expression.Expr.__sub__ (   self,
  a 
)
inherited

Definition at line 195 of file expression.py.

196  def __sub__(self, a):
197  return ExprOp('+', self, ExprOp('-', a))
def miasm2.expression.expression.Expr.__xor__ (   self,
  a 
)
inherited

Definition at line 213 of file expression.py.

214  def __xor__(self, a):
215  return ExprOp('^', self, a)

+ Here is the caller graph for this function:

def miasm2.expression.expression.ExprCond._exprhash (   self)
private

Definition at line 609 of file expression.py.

610  def _exprhash(self):
611  return hash((EXPRCOND, hash(self.cond),
612  hash(self._src1), hash(self._src2)))

+ Here is the caller graph for this function:

def miasm2.expression.expression.ExprCond._exprrepr (   self)
private

Definition at line 613 of file expression.py.

614  def _exprrepr(self):
615  return "%s(%r, %r, %r)" % (self.__class__.__name__,
616  self._cond, self._src1, self._src2)

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.canonize (   self)
inherited

Definition at line 247 of file expression.py.

248  def canonize(self):
249  "Canonize the Expression"
250 
251  def must_canon(e):
252  return not e.is_canon
253 
254  def canonize_visitor(e):
255  if e.is_canon:
256  return e
257  if isinstance(e, ExprOp):
258  if e.is_associative():
259  # ((a+b) + c) => (a + b + c)
260  args = []
261  for arg in e.args:
262  if isinstance(arg, ExprOp) and e.op == arg.op:
263  args += arg.args
264  else:
265  args.append(arg)
266  args = canonize_expr_list(args)
267  new_e = ExprOp(e.op, *args)
268  else:
269  new_e = e
270  elif isinstance(e, ExprCompose):
271  new_e = ExprCompose(canonize_expr_list_compose(e.args))
272  else:
273  new_e = e
274  new_e.is_canon = True
275  return new_e
276 
277  return self.visit(canonize_visitor, must_canon)

+ Here is the call graph for this function:

def miasm2.expression.expression.ExprCond.copy (   self)

Definition at line 634 of file expression.py.

635  def copy(self):
636  return ExprCond(self._cond.copy(),
637  self._src1.copy(),
638  self._src2.copy())
def miasm2.expression.expression.ExprCond.depth (   self)

Definition at line 639 of file expression.py.

640  def depth(self):
641  return max(self._cond.depth(),
642  self._src1.depth(),
643  self._src2.depth()) + 1
def miasm2.expression.expression.ExprCond.get_r (   self,
  mem_read = False,
  cst_read = False 
)

Definition at line 600 of file expression.py.

601  def get_r(self, mem_read=False, cst_read=False):
602  out_src1 = self._src1.get_r(mem_read, cst_read)
603  out_src2 = self._src2.get_r(mem_read, cst_read)
604  return self._cond.get_r(mem_read,
605  cst_read).union(out_src1).union(out_src2)
def miasm2.expression.expression.Expr.get_size (   self)
inherited

Definition at line 146 of file expression.py.

147  def get_size(self):
148  raise DeprecationWarning("use X.size instead of X.get_size()")
def miasm2.expression.expression.ExprCond.get_w (   self)

Definition at line 606 of file expression.py.

607  def get_w(self):
608  return set()
def miasm2.expression.expression.Expr.graph (   self)
inherited
Return a DiGraph instance standing for Expr tree
Instance's display functions have been override for better visibility
Wrapper on graph_recursive

Definition at line 319 of file expression.py.

320  def graph(self):
321  """Return a DiGraph instance standing for Expr tree
322  Instance's display functions have been override for better visibility
323  Wrapper on graph_recursive"""
324 
325  # Create recursively the graph
326  graph = DiGraphExpr()
327  self.graph_recursive(graph)
328 
329  return graph

+ Here is the call graph for this function:

def miasm2.expression.expression.ExprCond.graph_recursive (   self,
  graph 
)

Definition at line 644 of file expression.py.

645  def graph_recursive(self, graph):
646  graph.add_node(self)
647  for arg in [self._cond, self._src1, self._src2]:
648  arg.graph_recursive(graph)
649  graph.add_uniq_edge(self, arg)
650 
def miasm2.expression.expression.Expr.is_function_call (   self)
inherited
Returns true if the considered Expr is a function call

Definition at line 155 of file expression.py.

156  def is_function_call(self):
157  """Returns true if the considered Expr is a function call
158  """
159  return False
def miasm2.expression.expression.Expr.msb (   self)
inherited

Definition at line 278 of file expression.py.

279  def msb(self):
280  "Return the Most Significant Bit"
281  s = self.size
282  return self[s - 1:s]

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.pre_eq (   self,
  other 
)
inherited
Return True if ids are equal;
False if instances are obviously not equal
None if we cannot simply decide

Definition at line 170 of file expression.py.

171  def pre_eq(self, other):
172  """Return True if ids are equal;
173  False if instances are obviously not equal
174  None if we cannot simply decide"""
175 
176  if id(self) == id(other):
177  return True
178  if self.__class__ is not other.__class__:
179  return False
180  if hash(self) != hash(other):
181  return False
182  return None

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.replace_expr (   self,
  dct = None 
)
inherited
Find and replace sub expression using dct
@dct: dictionnary of Expr -> *

Definition at line 233 of file expression.py.

234  def replace_expr(self, dct=None):
235  """Find and replace sub expression using dct
236  @dct: dictionnary of Expr -> *
237  """
238  if dct is None:
239  dct = {}
240 
241  def my_replace(e, dct):
242  if e in dct:
243  return dct[e]
244  return e
245 
246  return self.visit(lambda e: my_replace(e, dct))

+ Here is the call graph for this function:

def miasm2.expression.expression.Expr.set_mask (   self,
  value 
)
inherited

Definition at line 330 of file expression.py.

331  def set_mask(self, value):
332  raise ValueError('mask is not mutable')
def miasm2.expression.expression.Expr.set_size (   self,
  value 
)
inherited

Definition at line 125 of file expression.py.

126  def set_size(self, value):
127  raise ValueError('size is not mutable')
def miasm2.expression.expression.Expr.signExtend (   self,
  size 
)
inherited
Sign extend to size
@size: int

Definition at line 295 of file expression.py.

296  def signExtend(self, size):
297  """Sign extend to size
298  @size: int
299  """
300  assert(self.size <= size)
301  if self.size == size:
302  return self
303  ad_size = size - self.size
304  c = ExprCompose([(self, 0, self.size),
305  (ExprCond(self.msb(),
306  ExprInt(size2mask(ad_size), ad_size),
307  ExprInt(0, ad_size)),
308  self.size, size)
309  ])
310  return c

+ Here is the call graph for this function:

def miasm2.expression.expression.ExprCond.visit (   self,
  cb,
  tv = None 
)

Definition at line 624 of file expression.py.

625  def visit(self, cb, tv=None):
626  cond = self._cond.visit(cb, tv)
627  src1 = self._src1.visit(cb, tv)
628  src2 = self._src2.visit(cb, tv)
629  if (cond == self._cond and
630  src1 == self._src1 and
631  src2 == self._src2):
632  return self
633  return ExprCond(cond, src1, src2)

+ Here is the caller graph for this function:

def miasm2.expression.expression.Expr.zeroExtend (   self,
  size 
)
inherited
Zero extend to size
@size: int

Definition at line 283 of file expression.py.

284  def zeroExtend(self, size):
285  """Zero extend to size
286  @size: int
287  """
288  assert(self.size <= size)
289  if self.size == size:
290  return self
291  ad_size = size - self.size
292  n = ExprInt(0, ad_size)
293  return ExprCompose([(self, 0, self.size),
294  (n, self.size, size)])

Member Data Documentation

miasm2.expression.expression.ExprCond._size
private

Definition at line 591 of file expression.py.

miasm2.expression.expression.ExprCond._src2
private

Definition at line 590 of file expression.py.

miasm2.expression.expression.Expr.arg
inherited

Definition at line 129 of file expression.py.

miasm2.expression.expression.Expr.is_canon = False
staticinherited

Definition at line 119 of file expression.py.

miasm2.expression.expression.Expr.is_eval = False
staticinherited

Definition at line 120 of file expression.py.

miasm2.expression.expression.Expr.is_simp = False
staticinherited

Definition at line 118 of file expression.py.

miasm2.expression.expression.Expr.is_term = False
staticinherited

Definition at line 117 of file expression.py.

Property Documentation

miasm2.expression.expression.ExprCond.cond = property(lambda self: self._cond)
static

Definition at line 593 of file expression.py.

miasm2.expression.expression.Expr.mask = property(lambda self: ExprInt(-1, self.size))
staticinherited

Definition at line 333 of file expression.py.

miasm2.expression.expression.Expr.size = property(lambda self: self._size)
staticinherited

Definition at line 131 of file expression.py.

miasm2.expression.expression.ExprCond.src1 = property(lambda self: self._src1)
static

Definition at line 594 of file expression.py.

miasm2.expression.expression.ExprCond.src2 = property(lambda self: self._src2)
static

Definition at line 595 of file expression.py.


The documentation for this class was generated from the following file: