view python/tcodegen.py @ 277:046017431c6a

Started register allocator
author Windel Bouwman
date Thu, 26 Sep 2013 21:14:25 +0200
parents 6f2423df0675
children 9fca39eebe50
line wrap: on
line source


"""
  Test individual parts of the code generation for arm using the c3 frontend.
"""

import c3
import ppci
import codegenarm
import outstream
import ir

testsrc = """
package test2;

var int phaa, foo, bar;

function int insanemath(int a, int b)
{
  var int c;
  c = 0;
  var int i;
  i = 9;
  while (i > 1)
  {
      c = a + b + 1 + c;
      i = i - 1;
      if (c > 90)
      {
         return 42;
      }
  }
  return c;
}

function void tesssst(int henkie)
{
   var int a, b, cee;
   a = 2 * 33 - 12;
   b = a * 2;
   a = b + a;
   cee = a;
   cee = cee * 2 + cee;
   insanemath(2, 3);
   if (cee + a > b and b - a+b== 3*6-insanemath(b, 2))
   {
      var int x = a;
      x = b - a + insanemath(3, 4) - insanemath(33, insanemath(2, 0));
      a = x * (x + a);
   }
   else
   {
      a = b + (a + b);
   }
   var int y;
   y = a - b * 53;
}
"""

testsrc = """
package test3;

function int ab(int a, int b)
{
  var int c;
  c = 0;
  c = c + a + b;
  return c; 
}

function void tesssst()
{
   var int a, b;
   a = 2;
   b = 3;
   ab(ab(a, b) + ab(9,b), 0);
}
"""
def dump_cfg(cga, cfg_file):
    print('digraph G {', file=cfg_file)
    #print('edge [constraint=none]', file=cfg_file)
    print('rankdir=TB', file=cfg_file)
    for f in cga.frames:
        print('subgraph cluster_{} {{'.format(f.name), file=cfg_file)
        print('label={};'.format(f.name), file=cfg_file)
        print('color=lightgrey;', file=cfg_file)
        print('style=filled;', file=cfg_file)
        f.cfg.to_dot(cfg_file)
        print('}', file=cfg_file)
    print('}', file=cfg_file)

def dump_ig(cga, ig_file):
    print('digraph G {', file=ig_file)
    print('edge [arrowhead=none]', file=ig_file)
    for f in cga.frames:
        print('subgraph cluster_{} {{'.format(f.name), file=ig_file)
        print('label={};'.format(f.name), file=ig_file)
        print('color=lightgrey;', file=ig_file)
        print('style=filled;', file=ig_file)
        f.ig.to_dot(ig_file)
        print('}', file=ig_file)
    print('}', file=ig_file)

if __name__ == '__main__':
    diag = ppci.DiagnosticsManager()
    builder = c3.Builder(diag)
    irc = builder.build(testsrc)
    if not irc:
        diag.printErrors(testsrc)
    irc.check()
    irc.dump()
    with open('ir.gv', 'w') as f:
        ir.dumpgv(irc, f)
    outs = outstream.TextOutputStream()
    cga = codegenarm.ArmCodeGenerator(outs)
    ir2 = cga.generate(irc)

    with open('cfg.gv', 'w') as cfg_file:
        dump_cfg(cga, cfg_file)

    with open('ig.gv', 'w') as ig_file:
        dump_ig(cga, ig_file)
        
    for f in ir2:
        print(f)
        for i in f.instructions:
            print('   {}'.format(i))

    outs.dump()