IC验证——perl脚本ccode_standard——c代码寄存器配置标准化

目录

1 脚本名称

2 脚本路径

3 脚本参数说明

4 脚本操作说明

5 脚本代码


1 脚本名称

ccode_standard

2 脚本路径

/scripts/bin/ccode_standard

3 脚本参数说明

次序

参数名

说明

1

address

(./rfdig;.;..;./boot)

指定脚本执行路径(可以为脚本所在路径的任意相对路径)

help

脚本使用帮助,打印说明信息

2

all

运行脚本后,脚本会解析全部rbus.cfg,并对参数1指定的目录中的.c文件进行寄存器配置代码标准化修改

module_name_seca.cfg

运行脚本后,脚本会解析参数2指定的rbus.cfg,并对参数1指定的目录中的.c文件进行寄存器配置代码标准化修改

示例

命令:ccode_standard  help

输出ccode_standard使用帮助信息

命令:ccode_standard  ./rfdig  rfdig_seca.cfg

对当前路径下的rfdig文件夹及其子文件夹下所有的.c文件中,有关rfdig_seca.cfg中的寄存器配置代码进行标准化修改;

命令:ccode_standard  .  crg_seca.cfg

对当前路径下的所有文件夹及其子文件夹下的所有.c文件中,所有有关crg_seca.cfg中的寄存器配置代码进行标准化修改;

命令:ccode_standard  .  all

对当前路径下的所有文件夹及其子文件夹下的所有.c文件中,所有模块的寄存器配置代码进行标准化修改;

说明

配置文件module_name_seca.cfg是被验模块寄存器的详细配置文件;脚本索引该文件的具体路径为:

$PROJ_SRC/design/scripts/rbus_scripts/rbus_cfg/

使用该脚本前请先gen_rbus;

4 脚本操作说明

        该脚本用于将如下所示的代码标准化,加速ST用例调整,该脚本可以反复多次调用,不会产生异常问题:

  1. 使用脚本前,首先gen_rbus,source,产生脚本需要解析的rbus.cfg文件,以及环境变量$ENV{PROJ_SRC};
  2. 根据脚本存放路径,指定脚本工作目录,如下例所示,脚本存放于case目录,我想修改rfdig文件夹下的.c文件,参考rfdig_seca.cfg;执行:ccode_standard  ./rfdig  rfdig_seca.cfg  >  1.log
  3. 如图所示,脚本只替换了有关rfdig的寄存器,iomux,crg等没有替换:

  4. 如下例所示,脚本存放于case目录,我想修改rfdig/rfdig_tc017文件夹下的.c文件,参考所有rbus.cfg文件;
  5. 执行:ccode_standard  ./rfdig/rfdig_m33_tc017  all  >  1.log

  6. 如图所示,脚本不仅替换了有关rfdig的寄存器,iomux,crg等都有替换:

  7.  

5 脚本代码

#! /usr/bin/perl -w#==========================================================
# PERL MODULE 
#==========================================================use Cwd;
use File::Path;
use File::Find;#==========================================================
# PERL FUNCTION GetOptions (get command parameters)
#==========================================================
$g_work_dir  = $ARGV[0];
$g_seca_fl   = $ARGV[1];#our $work_dir  = 'rfdig_m33_tc017';#==========================================================
# SCRIPT MAIN  
#==========================================================our @seca_fl_list;
our @seca_name;
our @seca_type;
our @seca_width;
our @seca_init_value;
our @seca_with_field;
our @seca_field_list_bgn;
our @seca_field_list_end;
our @seca_field_name;
our @seca_field_width;
our @seca_field_bgn_idx;
our @seca_field_end_idx;our $ccode_standard_mark = 0;Main();sub RegMem{@seca_name           = ();@seca_type           = ();@seca_width          = ();@seca_init_value     = ();@seca_with_field     = ();@seca_field_list_bgn = ();@seca_field_list_end = ();@seca_field_name     = ();@seca_field_width    = ();@seca_field_bgn_idx  = ();@seca_field_end_idx  = ();if (open(SECA_ID,"$g_seca_fl") or die "cannot open $g_seca_fl, no such file") {@seca_array = <SECA_ID>;my $i       = 0;my $j       = 0;my $rbus_ok = 0;foreach $seca_line (@seca_array) {$seca_line =~ s/[\n\r]*//g;if ($seca_line =~ m/^\s*field_(\S+)\s+\[(\S+)\]\s*$/) {if($rbus_ok eq 1) {$seca_with_field[$i-1]     = 1 ;$seca_field_list_bgn[$i-1] = $j;$rbus_ok                   = 0 ;}$seca_field_list_end[$i-1] = $j;my $field_name_tmp   = "\L$1";my $field_name_size  = push(@seca_field_name ,$field_name_tmp);my $field_port_tmp   = $2;if ($field_port_tmp =~ m/(\d+):(\d+)/) {push(@seca_field_bgn_idx,int($2));push(@seca_field_end_idx,int($1));push(@seca_field_width,(int($1)-int($2)+1));} else {push(@seca_field_bgn_idx,int($field_port_tmp));push(@seca_field_end_idx,int($field_port_tmp));push(@seca_field_width,1);}#print ("seca_with_field[",$i-1,"]     = ",$seca_with_field[$i-1]     ,"\n");#print ("seca_field_list_bgn[",$i-1,"] = ",$seca_field_list_bgn[$i-1] ,"\n");#print ("seca_field_list_end[",$i-1,"] = ",$seca_field_list_end[$i-1] ,"\n");#print ("seca_field_name[",$j,"]       = ",$seca_field_name[$j]       ,"\n");#print ("seca_field_width[",$j,"]      = ",$seca_field_width[$j]      ,"\n");#print ("seca_field_bgn_idx[",$j,"]    = ",$seca_field_bgn_idx[$j]    ,"\n");#print ("seca_field_end_idx[",$j,"]    = ",$seca_field_end_idx[$j]    ,"\n");$j = $j + 1;}if ($seca_line =~ m/^\s*rbus_(\S+)\s+(\S+)\s+(\w+)\s+(\d+)('\w+)\s+(\S+)\s*$/) {#print ("before match string: ",$`,     "\n");#print ("match string       : ",$&,     "\n");#print ("after  match string: ",$',     "\n");#print ("seca_postfix       : ",$1,     "\n");#print ("seca_type          : ",$2,     "\n");#print ("seca_scope         : ",$3,     "\n");#print ("seca_width         : ",int($4),"\n");#print ("seca_init_value    : ",$5,     "\n");#print ("seca_prefix        : ",$6,     "\n");#print ("seca_name          : ","$6_$1","\n");$seca_name[$i]             = "\L$6_$1";$seca_type[$i]             = $2;$seca_width[$i]            = int($4);$seca_init_value[$i]       = $5;$seca_with_field[$i] = 0;$i = $i+1;$rbus_ok = 1;}}}
}sub GenMacroDefine{#print "c file is              : $_[0]\n";#print "c macro_define file is : $_[1]\n";$ccode_standard_mark = 0;open(ORIEN_FILE,">>$_[1]");if (open(SOURCE_FILE,"$_[0]")) {@context = <SOURCE_FILE>;foreach $line (@context) {for ( $i = 0; $i < @seca_name; $i = $i +1) {if ($seca_with_field[$i] eq 1) {if ($line =~ m/^\s*(\w+)\[($seca_name[$i])\]\s*=\s*0x(\w+)\s*;.*$/) {$ccode_standard_mark = 1;print ORIEN_FILE "\n"."//"."$line";my $seca_field_list_num  = $seca_field_list_end[$i] - $seca_field_list_bgn[$i] + 1;for ($j = 0; $j < $seca_field_list_num; $j = $j+1) {my $seca_field_width_tmp = $seca_field_width[$seca_field_list_bgn[$i]+$j];my $seca_field_name_tmp  = "$seca_name[$i]"."_"."$seca_field_name[$seca_field_list_bgn[$i]+$j]";my $seca_field_mask_tmp  = "$seca_field_name_tmp"."_mask ((1<<$seca_field_width[$seca_field_list_bgn[$i]+$j])-1)";my $seca_field_shift_tmp = "$seca_field_name_tmp"."_shift $seca_field_bgn_idx[$seca_field_list_bgn[$i]+$j]";my $seca_field_bit_tmp   = "$seca_field_name_tmp"."_bit (1<<$seca_field_bgn_idx[$seca_field_list_bgn[$i]+$j])";if($seca_field_width_tmp eq 1){print ORIEN_FILE "#define $seca_field_bit_tmp\n";} else {print ORIEN_FILE "#define $seca_field_mask_tmp\n";print ORIEN_FILE "#define $seca_field_shift_tmp\n";}}}}}}close SOURCE_FILE;}close ORIEN_FILE;system ("awk '!a[\$0]++' $_[1] > $_[1]_tmp \&\& mv -f $_[1]_tmp $_[1]");
}sub AddMacroDefine{#print "old c file is : $_[0]\n";#print "new c file is : $_[1]\n";#print "add   file is : $_[2]\n";my $add_ready = 0;open(ORIEN_FILE,">$_[1]");if (open(SOURCE_FILE,"$_[0]")) {@context = <SOURCE_FILE>;foreach $line (@context) {if($line =~ m/^#include \"$_[2]\"$/) {} else {print ORIEN_FILE "$line";}if ($add_ready eq 0) {if ($line =~ m/^\s*\#include\s*\"\S+_define.c\"\s*$/) {print ORIEN_FILE "\#include "."\"$_[2]\"\n";$add_ready = 1;}}}close SOURCE_FILE;}close ORIEN_FILE;
}sub GenSubContent{#print "old c file is : $_[0]\n";#print "new c file is : $_[1]\n";open(ORIEN_FILE,">>$_[1]");if (open(SOURCE_FILE,"$_[0]")) {@context = <SOURCE_FILE>;foreach $line (@context) {my $line_match = 0;for ( $i = 0; $i < @seca_name; $i = $i + 1) {if ($seca_with_field[$i] eq 1) {if ($line =~ m/^(\s*)(\w+\[$seca_name[$i]\])\s*=\s*0x(\w+)\s*;.*$/) {my $reg_value = hex($3);if ($reg_value != 0) {$line_match = 1;print ORIEN_FILE "//"."$line";my $seca_field_list_num = $seca_field_list_end[$i] - $seca_field_list_bgn[$i] + 1;for ($j = 0; $j < $seca_field_list_num; $j = $j+1) {my $seca_field_name_tmp    = "$seca_name[$i]"."_"."$seca_field_name[$seca_field_list_bgn[$i]+$j]";my $seca_field_mask_tmp    = "$seca_field_name_tmp"."_mask";my $seca_field_value       = (($reg_value) >> ($seca_field_bgn_idx[$seca_field_list_bgn[$i]+$j])) & ((1<<$seca_field_width[$seca_field_list_bgn[$i]+$j])-1);my $seca_field_width_tmp   = $seca_field_width[$seca_field_list_bgn[$i]+$j];my $seca_field_shift_tmp   = "$seca_field_name_tmp"."_shift";my $seca_field_bit_tmp     = "$seca_field_name_tmp"."_bit";#print ("seca_field_mask_value = ",((1<<$seca_field_width[$seca_field_list_bgn[$i]+$j])-1),";");#print ("reg_value = ",$reg_value,";");#print ("seca_field_value = $seca_field_value\n");if($j eq 0){if ($j eq ($seca_field_list_num - 1)) {if($seca_field_width_tmp eq 1) {printf ORIEN_FILE ("%s%-40s ((%-50s * 0x%-8x)    %-51s) ;\n","$1","$2 =","$seca_field_bit_tmp",$seca_field_value,"                     ");} else {printf ORIEN_FILE ("%s%-40s ((%-50s & 0x%-8x) << %-51s) ;\n","$1","$2 =","$seca_field_mask_tmp",$seca_field_value,"$seca_field_shift_tmp");}} else {if($seca_field_width_tmp eq 1) {printf ORIEN_FILE ("%s%-40s ((%-50s * 0x%-8x)    %-51s) |\n","$1","$2 =","$seca_field_bit_tmp",$seca_field_value,"                     ");} else {printf ORIEN_FILE ("%s%-40s ((%-50s & 0x%-8x) << %-51s) |\n","$1","$2 =","$seca_field_mask_tmp",$seca_field_value,"$seca_field_shift_tmp");}}} elsif($j eq ($seca_field_list_num - 1)) {                                                                                              if($seca_field_width_tmp eq 1) {printf ORIEN_FILE ("%s%-40s ((%-50s * 0x%-8x)    %-51s) ;\n","$1","    ","$seca_field_bit_tmp",$seca_field_value,"                     ");} else {printf ORIEN_FILE ("%s%-40s ((%-50s & 0x%-8x) << %-51s) ;\n","$1","    ","$seca_field_mask_tmp",$seca_field_value,"$seca_field_shift_tmp");}} else {                                                                                                                                 if($seca_field_width_tmp eq 1) {printf ORIEN_FILE ("%s%-40s ((%-50s * 0x%-8x)    %-51s) |\n","$1","    ","$seca_field_bit_tmp",$seca_field_value,"                     ");} else {printf ORIEN_FILE ("%s%-40s ((%-50s & 0x%-8x) << %-51s) |\n","$1","    ","$seca_field_mask_tmp",$seca_field_value,"$seca_field_shift_tmp");}}}}}}}if ($line_match eq 0) {print ORIEN_FILE "$line";}}close SOURCE_FILE;}close ORIEN_FILE;
}sub CopyFile{#print "source file name is $_[0]\n";#print "orien  file name is $_[1]\n";open(ORIEN_FILE,">$_[1]");if (open(SOURCE_FILE,"$_[0]")) {@context = <SOURCE_FILE>;foreach $line (@context) {print ORIEN_FILE "$line";}close SOURCE_FILE;}close ORIEN_FILE;
}sub FindConfigFile{if (-f $File::Find::name) {if ($_ =~ m/^(\w+_sec[a-z]\.cfg)$/) {#print "find file is $1 \n";push(@seca_fl_list,$1); }}
}sub FindWanted{if (-f $File::Find::name) {if ($_ =~ m/(\S+)\.c$/) {print "process file: $File::Find::name \n";GenMacroDefine("$_","$1"."_macro_define.h");unlink "$1"."_macro_define.h";if($ccode_standard_mark eq 1) {unlink "$_".".tmp";GenSubContent("$_","$_".".tmp");#AddMacroDefine("$_".".tmp","$_","$1"."_macro_define.h");system ("mv -f $_.tmp $_");unlink "$_".".tmp";}}}
}sub Main{my $cur_dir  = getcwd;my $proj_src = $ENV{PROJ_SRC};my $seca_dir = "$ENV{PROJ_SRC}/design/scripts/rbus_scripts/rbus_cfg/";if($g_seca_fl eq "all") {chdir($seca_dir) or die "$seca_dir was not found!!! please gen_rbus firstly.";find(\&FindConfigFile,"$seca_dir");} else {push(@seca_fl_list,$g_seca_fl);}#for ($i = 0; $i < @seca_fl_list; $i = $i+1) {#    print "seca_fl_list[$i] = $seca_fl_list[$i] \n";#}for ($z = 0; $z < @seca_fl_list; $z = $z + 1) {print "read config_file : $seca_fl_list[$z]\n";$g_seca_fl = "$seca_dir"."$seca_fl_list[$z]";RegMem();chdir($cur_dir) or die "$cur_dir does not exist!!!";find(\&FindWanted,"$cur_dir/$g_work_dir");}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/628941.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【小笔记】用tsai库实现Rocket家族算法

2024.1.16 Rocket家族算法是用于时间序列分类的强baseline&#xff08;性能比较参考【小笔记】时序数据分类算法最新小结&#xff09;&#xff0c;Rocket/MiniRocket/MultiRocket官方都有开源实现&#xff0c;相比较而言&#xff0c;用tsai来实现有三个好处&#xff1a;1是快速…

WPF应用程序生存期以及相关事件

WPF 应用程序的生存期会通过 Application 引发的几个事件来加以标记&#xff0c;相关事件对应着应用程序何时启动、激活、停用和关闭。 应用程序生存期事件 • 独立应用程序(传统风格的 Windows 应用程序&#xff0c;这些应用程序作为要安装到客户端计算机并从客户端计算机运…

VitePress-01-从零开始的项目创建(npm版)

说明 本文介绍一下 VitePress的项目创建的步骤。 主要用到的命令工具是 npm。 本文的操作步骤是从无到有的创建一个完整的基本的【VitePress】项目。 环境准备 根据官方文档的介绍&#xff0c;截止本文发稿时&#xff0c;需要使用node.js 18 的版本。 可以使用node -v 的命令查…

关于java的封装

关于java的封装 我们在前面的文章中&#xff0c;了解到了类和对象的知识&#xff0c;以及做了创建对象的时候对内存的分析&#xff0c;我们本篇文章来了解一下面向对象的三大基本特征之一&#xff0c;封装&#x1f600;。 一、初识封装 封装就好比&#xff0c;我们把一些物品…

【操作系统】1. 操作系统概述

文章目录 【 1. 什么是操作系统 】【 2. 操作系统软件的分类 】【 3. 操作系统内核的抽象和特征 】3.1 操作系统内核的抽象3.2 操作系统内核的特征 【 1. 什么是操作系统 】 操作系统是管理硬件资源、控制程序运行、改善人机界面和为应用软件提供服务的一种系统 软件。一个服务…

<软考高项备考>《论文专题 - 71 风险管理(3)》

3 过程2-识别风险 3.1 问题 4W1H过程做什么是识别单个项目风险以及整体项目风险的来源&#xff0c;并记录风险特征的过程。作用:1、记录现有的单个项目风险&#xff0c;以及整体项目风险的来源:2、汇总相关信息&#xff0c;以便项目团队能够恰当地应对已识别的风险。为什么做…

怎么修改或移除WordPress后台仪表盘概览底部的版权信息和主题信息?

前面跟大家分享『WordPress怎么把后台左上角的logo和评论图标移除&#xff1f;』和『WordPress后台底部版权信息“感谢使用 WordPress 进行创作”和版本号怎么修改或删除&#xff1f;』&#xff0c;其实在WordPress后台仪表盘的“概览”底部还有一个WordPress版权信息和所使用的…

项目解决方案:“ZL铁路轨行车辆”实时视频监控系统

目 录 一、建设背景 1.1 政策背景 1.2 现状 二、建设目标 三、建设依据 四、建设原则 4.1经济高效性 4.2系统开放性 4.3系统继承性 4.4系统扩展性 4.5系统经济性 4.6系统安全性 五、系统架构 5.1系统架构图 5.2技术架构 1、DVS 2、中心管理服务…

【Java SE语法篇】11.异常

&#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ 文章目录 1. 异常的概念和体系结构1.1 异常的概念1.2 异常体系…

PTA——7-31 三角形判断

7-31 三角形判断 (15分) 给定平面上任意三个点的坐标(x​1​​,y​1​​)、(x​2​​,y​2​​)、(x​3​​,y​3​​)&#xff0c;检验它们能否构成三角形。 输入格式: 输入在一行中顺序给出六个[−100,100]范围内的数字&#xff0c;即三个点的坐标x​1​​、y​1​​、x​2​…

SUKER书客重磅发布全新系列:书客Sun立式护眼台灯,护眼养眼新境界

近日&#xff0c;国内知名的光学国货品牌——SUKER书客在2024年新品发布上&#xff0c;正式发布了全新系列的书客Sun立式护眼台灯。 SUKER书客作为近年来快速发展的创新型光学技术品牌&#xff0c;曾推出的一系列产品都取得了刷新行业标准的成绩&#xff0c;他们坚持以创新为动…

【51单片机系列】单片机与PC进行串行通信

一、单片机与PC机串行通信的设计 工业现场的测控系统中&#xff0c;常使用单片机进行监测点的数据采集&#xff0c;然后单片机通过串口与PC通信&#xff0c;把采集的数据串行传送到PC机上&#xff0c;再在PC机上进行数据处理。 PC机配置的都是RS-232标准串口&#xff0c;为D型…

YOLOv5改进 | 2023主干篇 | 多种轻量化卷积优化PP-HGNetV2改进主干(全网独家创新)

一、本文介绍 Hello,大家好,上一篇博客我们讲了利用HGNetV2去替换YOLOv5的主干,经过结构的研究我们可以发现在HGNetV2的网络中有大量的卷积存在,所以我们可以用一种更加轻量化的卷积去优化HGNetV2从而达到更加轻量化的效果(亲测优化后的HGNetV2网络比正常HGNetV2精度更高…

开发知识点-java基础

java基础知识整理 windows 多版本java jar包不能直接打开 需要java -jar问题解决 windows 多版本 控制面板 java15 download 多版本 https://www.cnblogs.com/chenmingjun/p/9941191.html https://gitee.com/shixinke/JC-jEnv/repository/archive/master.zip java jar包不…

React16源码: React中的renderRoot的源码实现

renderRoot 1 &#xff09;概述 renderRoot 是一个非常复杂的方法这个方法里处理很多各种各样的逻辑, 它主要的工作内容是什么&#xff1f;A. 它调用 workLoop 进行循环单元更新 遍历整个 Fiber Tree&#xff0c;把每一个组件或者 dom 节点对应的Fiber 节点拿出来单一的进行更…

万户 ezOFFICE ezflow_gd.jsp SQL注入漏洞复现

0x01 产品简介 万户OA ezoffice是万户网络协同办公产品多年来一直将主要精力致力于中高端市场的一款OA协同办公软件产品,统一的基础管理平台,实现用户数据统一管理、权限统一分配、身份统一认证。统一规划门户网站群和协同办公平台,将外网信息维护、客户服务、互动交流和日…

DC电源模块与AC电源模块的对比分析

DC电源模块与AC电源模块的对比分析 BOSHIDA DC电源模块和AC电源模块是两种常见的电源模块&#xff0c;它们在供电方式、稳定性、适用范围等方面有所不同&#xff0c;下面是它们的对比分析&#xff1a; 1. 供电方式&#xff1a; DC电源模块通过直流电源供电&#xff0c;通常使用…

【Linux】Linux 系统编程——which 命令

文章目录 1.命令概述2.命令格式3.常用选项4.相关描述5.参考示例 1.命令概述 which 命令用于定位执行文件的路径。当输入一个命令时&#xff0c;which 会在环境变量 PATH 所指定的路径中搜索每个目录&#xff0c;以查找指定的可执行文件。 2.命令格式 which [选项] 命令名3.常…

生产力与生产关系 —— 浅析爱泼斯坦事件 之 弱电控制强电原理

据网络文字与视频资料&#xff0c;爱泼斯坦事件是犹太精英阶层&#xff0c;为了掌控美国国家机器为犹太利益集团服务&#xff0c;而精心设下的一个局。本文先假设这个结论成立&#xff0c;并基于此展开讨论。 我们知道&#xff0c;弱电管理强电是电气工程中的一门专门学问&…

Mysql 数据库DDL 数据定义语言——数据库,数据表的创建

DDL&#xff1a;数据定义语言&#xff0c;用来定义数据库对象&#xff08;数据库&#xff0c;表&#xff0c;字段&#xff09;—Database Definition Language 1、登录数据库&#xff0c;输入用户名和密码 mysql -ufdd -p990107Wjl2、查看数据库 show databases;3、创建一个…