test_liveness.py 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. import unittest
  2. from src.statement import Statement as S
  3. from src.dataflow import BasicBlock as B
  4. from src.liveness import create_gen_kill, create_in_out
  5. class TestLiveness(unittest.TestCase):
  6. def setUp(self):
  7. pass
  8. def tearDown(self):
  9. pass
  10. def test_create_gen_kill(self):
  11. s1 = S('command', 'addu', '$3', '$1', '$2')
  12. s2 = S('command', 'addu', '$1', '$3', 10)
  13. s3 = S('command', 'subu', '$3', '$1', 5)
  14. s4 = S('command', 'li', '$4', '0x00000001')
  15. block = B([s1, s2, s3, s4])
  16. create_gen_kill(block)
  17. self.assertEqual(block.live_gen, set(['$1', '$2']))
  18. self.assertEqual(block.live_kill, set(['$3', '$1', '$4']))
  19. #def test_create_in_out(self):
  20. # s11 = S('command', 'li', 'a', 3)
  21. # s12 = S('command', 'li', 'b', 5)
  22. # s13 = S('command', 'li', 'd', 4)
  23. # s14 = S('command', 'li', 'x', 100)
  24. # s15 = S('command', 'beq', 'a', 'b', 'L1')
  25. # b1 = B([s11, s12, s13, s14, s15])
  26. # s21 = S('command', 'addu', 'c', 'a', 'b')
  27. # s22 = S('command', 'li', 'd', 2)
  28. # b2 = B([s21, s22])
  29. # s31 = S('label', 'L1')
  30. # s32 = S('command', 'li', 'c', 4)
  31. # s33 = S('command', 'mult', 'b', 'd')
  32. # s34 = S('command', 'mflo', 'temp')
  33. # s35 = S('command', 'addu', 'return', 'temp', 'c')
  34. # b3 = B([s31, s32, s33, s34, s35])
  35. # create_in_out([b1, b2, b3])
  36. # self.assertEqual(b1.live_gen, set([s11.sid, s12.sid, s13.sid, s14.sid]))
  37. # self.assertEqual(b1.live_kill, set([s22.sid]))
  38. # self.assertEqual(b2.live_gen, set([s21.sid, s22.sid]))
  39. # self.assertEqual(b2.live_kill, set([s13.sid, s32.sid]))
  40. # self.assertEqual(b3.live_gen, set([s32.sid, s34.sid, s35.sid]))
  41. # self.assertEqual(b3.live_kill, set([s21.sid]))
  42. # self.assertEqual(b1.live_in, set())
  43. # self.assertEqual(b1.live_out, set([s11.sid, s12.sid, s13.sid]))
  44. # self.assertEqual(b2.live_in, set([s11.sid, s12.sid]))
  45. # self.assertEqual(b2.live_out, set([s12.sid, s22.sid]))
  46. # self.assertEqual(b3.live_in, set([s12.sid, s22.sid]))
  47. # self.assertEqual(b3.live_out, set())