| #!/usr/bin/env python3 |
| # -*- coding: utf-8 -*- |
| # |
| # Copyright (C) 2017-2020 The Project X-Ray Authors. |
| # |
| # Use of this source code is governed by a ISC-style |
| # license that can be found in the LICENSE file or at |
| # https://opensource.org/licenses/ISC |
| # |
| # SPDX-License-Identifier: ISC |
| """ Tool for generating Vivavo commands to highlight objects from a FASM file. |
| |
| Currently this tool only highlights pips directly referenced in the FASM file. |
| """ |
| |
| from __future__ import print_function |
| import os.path |
| import fasm |
| from prjxray import db |
| from prjxray import util |
| |
| |
| def main(): |
| import argparse |
| |
| parser = argparse.ArgumentParser( |
| description= |
| 'Outputs a Vivavo highlight_objects command from a FASM file.') |
| |
| util.db_root_arg(parser) |
| util.part_arg(parser) |
| parser.add_argument('fn_in', help='Input FPGA assembly (.fasm) file') |
| |
| args = parser.parse_args() |
| database = db.Database(args.db_root, args.part) |
| grid = database.grid() |
| |
| def inner(): |
| for line in fasm.parse_fasm_filename(args.fn_in): |
| if not line.set_feature: |
| continue |
| |
| parts = line.set_feature.feature.split('.') |
| tile = parts[0] |
| gridinfo = grid.gridinfo_at_tilename(tile) |
| |
| tile_type = database.get_tile_type(gridinfo.tile_type) |
| |
| for pip in tile_type.pips: |
| if pip.net_from == parts[2] and pip.net_to == parts[1]: |
| yield '{}/{}'.format(tile, pip.name) |
| |
| print( |
| 'highlight_objects [concat {}]'.format( |
| ' '.join('[get_pips {}]'.format(pip) for pip in inner()))) |
| |
| |
| if __name__ == '__main__': |
| main() |