Print when evaluating terminators.

This commit is contained in:
cfreksen 2017-10-29 19:12:30 +01:00
parent 7213c32f93
commit 344609e54b
No known key found for this signature in database
GPG Key ID: EAC13EE101008978
2 changed files with 30 additions and 0 deletions

22
ll.py
View File

@ -106,3 +106,25 @@ def insn2s(insn):
# TODO # TODO
print('insn2s: Unknown insn: {}' print('insn2s: Unknown insn: {}'
.format(insn)) .format(insn))
def terminator2s(terminator):
if isinstance(terminator, Ret):
if terminator.oper is None:
return ('ret {}'
.format(ty2s(terminator.ty)))
else:
return ('ret {} {}'
.format(ty2s(terminator.ty),
oper2s(terminator.oper)))
elif isinstance(terminator, Br):
return ('br label %{}'
.format(terminator.label))
elif isinstance(terminator, Cbr):
return ('br {} {}, label %{}, label %{}'
.format(ty2s(terminator.ty),
oper2s(terminator.oper),
terminator.then_label,
terminator.else_label))
else:
print('terminator2s: Unknown terminator {}'
.format(terminator))

View File

@ -69,12 +69,19 @@ def terminate(terminator, blocks, stack_frames, ssa_env, global_env, memory):
if id is not None and id in ssa_env: if id is not None and id in ssa_env:
del ssa_env[id] del ssa_env[id]
print('Evaluating {}'
.format(ll.terminator2s(terminator)))
if isinstance(terminator, ll.Ret): if isinstance(terminator, ll.Ret):
oper = terminator.oper oper = terminator.oper
if oper is None: if oper is None:
oper_v = None oper_v = None
else: else:
oper_v = eval_oper(oper, ssa_env, global_env) oper_v = eval_oper(oper, ssa_env, global_env)
# TODO
print('Returning {}'
.format(oper_v))
if len(stack_frames) == 0: if len(stack_frames) == 0:
new_insns = [] new_insns = []
new_terminator = None new_terminator = None
@ -97,6 +104,7 @@ def terminate(terminator, blocks, stack_frames, ssa_env, global_env, memory):
# blocks. # blocks.
clear_block_from_ssa_env(new_insns, ssa_env) clear_block_from_ssa_env(new_insns, ssa_env)
# TODO
print('Jumping unconditionally to {}' print('Jumping unconditionally to {}'
.format(label)) .format(label))