Example #1
0
 def __process_array(self, context, array, top = False):
     hierarchy = analyze_hierarchy(context)
     for module in itervalues(hierarchy[array.name]):
         if module.name in self._visited:
             continue
         self._visited.add(module.name)
         if module.module_class.is_tile:
             netify_tile(module, self._directs)
         elif module.module_class.is_array:
             self.__process_array(context, module)
     netify_array(array, top)
Example #2
0
def test_io_leaf_array(tmpdir):
    io = Iopad()
    block = IOBlock('mock_block', io, 4)
    glb = Global('clk', is_clock = True)
    sgmts = [Segment('L1', 4, 1)]
    lib = Library()
    gen = VerilogGenerator()
    fc = BlockFCValue(BlockPortFCValue(0.5), BlockPortFCValue(1.0))

    # 1. add some ports
    block.create_global(glb)
    block.create_input('outpad', 1)
    block.create_output('inpad', 1)

    # 2. create tile
    tile = Tile('mock_tile', block, Orientation.west)

    # 3. cboxify
    cboxify(lib, tile, sgmts, fc, Orientation.east)

    # 4. populate and generate connections
    for (position, orientation), cbox_inst in iteritems(tile.cbox_instances):
        populate_connection_box(cbox_inst.model, sgmts, tile.block, orientation, position)
        generate_fc(cbox_inst.model, sgmts, tile.block, orientation, fc, position)

    # 5. netify
    netify_tile(tile)

    # 6. create array
    array = Array('mock_array', tile.width, tile.height, coverage = ChannelCoverage(north = True, east = True))

    # 7. place tile
    array.instantiate_element(tile, (0, 0))

    # 8. sboxify
    sboxify(lib, array)

    # 9. populate and generate connections
    for env, sbox in iteritems(lib.sboxes):
        populate_switch_box(sbox, sgmts, env)
        generate_wilton(sbox, sgmts, cycle_free = True)

    # 10. netify
    netify_array(array)

    # 11. switchify!
    for box in chain(itervalues(lib.cboxes), itervalues(lib.sboxes)):
        switchify(lib, box)

    # 12. generate files
    for module in chain(itervalues(lib.switches), itervalues(lib.sboxes), iter((array, ))):
        gen.generate_module(tmpdir.join(module.name + '.v').open(OpenMode.wb), module)
Example #3
0
def test_logic_tile(tmpdir):
    clk = Global('clk', is_clock=True)
    sgmts = [Segment('L1', 4, 1), Segment('L2', 1, 2)]
    lib = Library()
    gen = VerilogGenerator()
    block = LogicBlock('mock_block', 1, 3)
    fc = BlockFCValue(BlockPortFCValue(0.5), BlockPortFCValue(1.0), {
        "cin": BlockPortFCValue(0),
        "cout": BlockPortFCValue(0)
    })

    # 1. add some ports
    block.create_global(clk, Orientation.south, position=(0, 0))
    block.create_input('addr', 10, Orientation.west, (0, 0))
    block.create_input('din', 8, Orientation.west, (0, 1))
    block.create_input('we', 1, Orientation.west, (0, 2))
    block.create_output('dout', 8, Orientation.east, (0, 0))
    cin = block.create_input('cin', 1, Orientation.south, position=(0, 0))
    cout = block.create_output('cout', 1, Orientation.north, position=(0, 2))

    # 2. direct tunnels
    directs = [DirectTunnel('carrychain', cout, cin, (0, -3))]

    # 3. create tile
    tile = Tile('mock_tile', block)

    # 4. cboxify
    cboxify(lib, tile, sgmts, fc)

    # 5. populate and generate connections
    for (position, orientation), cbox_inst in iteritems(tile.cbox_instances):
        populate_connection_box(
            cbox_inst.model, sgmts, tile.block, orientation, position,
            orientation.case((0, 0), (0, 0), (0, -1), (-1, 0)))
        generate_fc(cbox_inst.model, sgmts, tile.block, orientation,
                    fc, position,
                    orientation.case((0, 0), (0, 0), (0, -1), (-1, 0)))
        switchify(lib, cbox_inst.model)

    # 7. netify
    netify_tile(tile, directs)

    # 8. generate files
    for module in chain(itervalues(lib.switches), itervalues(lib.cboxes),
                        iter((tile, ))):
        gen.generate_module(
            tmpdir.join(module.name + '.v').open(OpenMode.wb), module)
Example #4
0
def test_io_tile(tmpdir):
    io = Iopad()
    block = IOBlock('mock_block', io, 4)
    glb = Global('clk', is_clock=True)
    sgmts = [Segment('L1', 4, 1), Segment('L2', 1, 2)]
    lib = Library()
    gen = VerilogGenerator()
    fc = BlockFCValue(BlockPortFCValue(0.5), BlockPortFCValue(1.0))

    # 1. add some ports
    block.create_global(glb)
    block.create_input('outpad', 1)
    block.create_output('inpad', 1)

    # 2. create tile
    tile = Tile('mock_tile', block, Orientation.west)

    # 3. cboxify
    cboxify(lib, tile, sgmts, fc, Orientation.east)

    # 4. populate and generate connections
    for (position, orientation), cbox_inst in iteritems(tile.cbox_instances):
        populate_connection_box(cbox_inst.model, sgmts, tile.block,
                                orientation, position)
        generate_fc(cbox_inst.model, sgmts, tile.block, orientation, fc,
                    position)
        switchify(lib, cbox_inst.model)

    # 5 switchify!
    switchify(lib, block)

    # 6. netify
    netify_tile(tile)

    # 7. generate files
    for module in chain(itervalues(lib.switches), itervalues(lib.cboxes),
                        iter((tile, ))):
        gen.generate_module(
            tmpdir.join(module.name + '.v').open(OpenMode.wb), module)
Example #5
0
def test_complex_array(tmpdir):
    io = Iopad()
    clk = Global('clk', is_clock = True)
    clk.bind((0, 1), 0)
    sgmts = [Segment('L1', 4, 1), Segment('L2', 1, 2)]
    lib = Library()
    gen = VerilogGenerator()

    # 1. create IOB
    iob = IOBlock('mock_iob', io, 4)
    iob.create_global(clk)
    iob.create_input('outpad', 1)
    iob.create_output('inpad', 1)

    # 2. create IOB tiles
    iob_tiles = {}
    io_fc = BlockFCValue(BlockPortFCValue(0.5), BlockPortFCValue(1.0)) 
    for ori in Orientation:
        if ori.is_auto:
            continue
        tile = iob_tiles[ori] = Tile('mock_tile_io' + ori.name[0], iob, ori)
        cboxify(lib, tile, sgmts, io_fc, ori.opposite)
        for (position, orientation), cbox_inst in iteritems(tile.cbox_instances):
            generate_fc(cbox_inst.model, sgmts, tile.block, orientation, io_fc,
                    position, orientation.case((0, 0), (0, 0), (0, -1), (-1, 0)))
        netify_tile(tile)

    # 3. create CLB
    clb = LogicBlock('mock_clb')
    clb.create_global(clk, Orientation.west)
    clb.create_input('ina', 4, Orientation.south)
    clb.create_output('outa', 2, Orientation.south)
    clb.create_input('inb', 4, Orientation.north)
    clb.create_output('outb', 2, Orientation.north)
    cin = clb.create_input('cin', 1, Orientation.west)
    cout = clb.create_output('cout', 1, Orientation.east)

    # 4. direct tunnels
    directs = [DirectTunnel('carrychain', cout, cin, (-1, 0))]

    # 5. create CLB tiles
    clb_tile = Tile('mock_tile_clb', clb)
    clb_fc = BlockFCValue(BlockPortFCValue(0.25), BlockPortFCValue(0.5))
    cboxify(lib, clb_tile, sgmts, clb_fc)
    for (position, orientation), cbox_inst in iteritems(clb_tile.cbox_instances):
        generate_fc(cbox_inst.model, sgmts, clb_tile.block, orientation, clb_fc,
                position, orientation.case((0, 0), (0, 0), (0, -1), (-1, 0)))
    netify_tile(clb_tile, directs)

    # 6. create BRAM
    bram = LogicBlock('mock_bram', 1, 3)
    bram.create_global(clk, Orientation.south, position = (0, 0))
    bram.create_input('we', 1, Orientation.south, (0, 0))
    bram.create_input('din', 1, Orientation.west, (0, 0))
    bram.create_output('dout', 1, Orientation.east, (0, 0))
    bram.create_input('addr_l', 4, Orientation.west, (0, 1))
    bram.create_input('addr_h', 4, Orientation.west, (0, 2))

    # 7. create BRAM tiles
    bram_tile = Tile('mock_tile_bram', bram)
    bram_fc = BlockFCValue(BlockPortFCValue(0.25, {'din': 0.5, 'we': 0.5}), BlockPortFCValue(0.5))
    cboxify(lib, bram_tile, sgmts, bram_fc)
    for (position, orientation), cbox_inst in iteritems(bram_tile.cbox_instances):
        generate_fc(cbox_inst.model, sgmts, bram_tile.block, orientation, bram_fc,
                position, orientation.case((0, 0), (0, 0), (0, -1), (-1, 0)))
    netify_tile(bram_tile, directs)

    # 8. repetitive sub-array
    subarray = Array('mock_sub_array', 3, 3, coverage = ChannelCoverage(north = True, east = True))
    subarray.instantiate_element(bram_tile, (2, 0))
    for x in range(2):
        for y in range(3):
            subarray.instantiate_element(clb_tile, (x, y))
    sboxify(lib, subarray)

    # 9. top array
    array = Array('mock_array', 8, 8)
    for i in range(1, 7):
        array.instantiate_element(iob_tiles[Orientation.north], (i, 7))
        array.instantiate_element(iob_tiles[Orientation.east], (7, i))
        array.instantiate_element(iob_tiles[Orientation.south], (i, 0))
        array.instantiate_element(iob_tiles[Orientation.west], (0, i))
    for x in range(1, 7, 3):
        for y in range(1, 7, 3):
            array.instantiate_element(subarray, (x, y))

    # 10. sboxes and more
    for env, sbox in iteritems(lib.sboxes):
        populate_switch_box(sbox, sgmts, env)
        generate_wilton(sbox, sgmts, cycle_free = True)
    netify_array(subarray)
    netify_array(array, True)

    # 11. switchify!
    for box in chain(itervalues(lib.cboxes), itervalues(lib.sboxes)):
        switchify(lib, box)

    # 12. generate files
    for module in chain(itervalues(lib.switches), itervalues(lib.sboxes), itervalues(lib.cboxes),
            itervalues(iob_tiles), iter((clb_tile, bram_tile, subarray, array))):
        gen.generate_module(tmpdir.join(module.name + '.v').open(OpenMode.wb), module)