我是靠谱客的博主 冷艳钢笔,最近开发中收集的这篇文章主要介绍展开Verilog BUS信号名的方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

假如我有一些信号需要展开,信号的格式如下所示:

input.file

Hello/My/name/is/AAAAA[9:0]
Hello/My/name/is/BBBBB[0:7]
Hello/My/name/is/CCCCC[3:3]
Hello/My/name/is/DDDDD

展开之后的格式如下所示:

Hello/My/name/is/AAAAA[9]
Hello/My/name/is/AAAAA[8]
Hello/My/name/is/AAAAA[7]
~~~此处省略若干行~~~
Hello/My/name/is/CCCCC[1]
Hello/My/name/is/CCCCC[0]
Hello/My/name/is/CCCCC[3]
Hello/My/name/is/DDDDD

下面的python脚本(python2)可以实现这个功能:

expand_bus_bits.py

#!/usr/bin/python

import re

fh = open('./input.file')
for line in  fh.readlines():
#    print line
    m = re.match(r'(.*)[(d+):(d+)]', line)
    if m:
        signal_name =  m.group(1)
        index0      =  int(m.group(2))
        index1      =  int(m.group(3))
#        print signal_name
#        print index0
#        print index1
#        print signal_name + "[" + str(index0) + ":" + str(index1) + "]"
        if (index0 > index1):
            while (index0 >= index1):
                print signal_name + "[" + str(index0)  + "]"
                index0 = index0 - 1
        elif (index0 < index1):
            while (index0 <= index1):
                print signal_name + "[" + str(index1)  + "]"
                index1 = index1 - 1
        else:
            print signal_name + "[" + str(index0)  + "]"
    else:
        print line

执行的结果默认输出到屏幕上。

下面是输出的结果:
这里写图片描述

最后

以上就是冷艳钢笔为你收集整理的展开Verilog BUS信号名的方法的全部内容,希望文章能够帮你解决展开Verilog BUS信号名的方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部