Commit 4594d41f authored by Taddeus Kroes's avatar Taddeus Kroes

Added debug option to dead code elimination.

parent 555624cb
...@@ -217,8 +217,6 @@ def fold_constants(block): ...@@ -217,8 +217,6 @@ def fold_constants(block):
rd, rs, rt = s rd, rs, rt = s
rs_known = rs in register rs_known = rs in register
rt_known = rt in register rt_known = rt in register
print 'rs:', rs, type(rs)
print 'rt:', rt, type(rt)
if (rs_known or isinstance(rs, int)) and \ if (rs_known or isinstance(rs, int)) and \
(rt_known or isinstance(rt, int)): (rt_known or isinstance(rt, int)):
...@@ -399,14 +397,19 @@ def eliminate_dead_code(block): ...@@ -399,14 +397,19 @@ def eliminate_dead_code(block):
for reg in s.get_def(): for reg in s.get_def():
if reg in unused: if reg in unused:
# Statement is redefined later, so this statement is useless # Statement is redefined later, so this statement is useless
s.remove = True if block.debug:
#print 'reg %s is in %s, remove:' % (reg, unused), \ s.stype = 'comment'
# block.pointer - 1, s s.options['block'] = False
s.name = ' Dead code: %s %s' \
% (s.name, ', '.join(map(str, s)))
else:
s.remove = True
else: else:
unused.add(reg) unused.add(reg)
unused -= set(s.get_use()) unused -= set(s.get_use())
block.apply_filter(lambda s: not hasattr(s, 'remove')) if not block.debug:
block.apply_filter(lambda s: not hasattr(s, 'remove'))
return changed return changed
...@@ -25,7 +25,7 @@ def write_statements(statements): ...@@ -25,7 +25,7 @@ def write_statements(statements):
indent_level = 1 indent_level = 1
elif s.is_comment(): elif s.is_comment():
line = '\t' * indent_level + '#' + s.name line = '\t' * indent_level + '#' + s.name
current_comment = True current_comment = s.options.get('block', True)
elif s.is_directive(): elif s.is_directive():
line = '\t' + s.name line = '\t' + s.name
elif s.is_command(): elif s.is_command():
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment