SystemC入门之测试平台编写完整示例:带同步输出的多路选择器

本文主要是介绍SystemC入门之测试平台编写完整示例:带同步输出的多路选择器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内容:SystemC入门书中的简单测试平台编写示例。

模块文件编写

带锁存输出的4选1多路器模型。输出在信号clock的正跳变沿时刻被锁存。

sync_mux41.h文件

#include <systemc.h>SC_MODULE(sync_mux41)
{sc_in<bool> clock, reset;sc_in<sc_uint<2>> sel;sc_in<sc_uint<4>> inp;sc_out<bool> out;void prc_sync_mux41();SC_CTOR(sync_mux41){SC_METHOD(prc_sync_mux41);sensitive << clock.pos();sensitive << reset.neg();}};void sync_mux41::prc_sync_mux41()
{sc_uint<4> temp_inp;temp_inp =inp.read();if(reset ==0){out =0;}else{if(sel.read()==0) {out = temp_inp[0];}else if(sel.read()==1) {out = temp_inp[1];}else if(sel.read()==2) {out = temp_inp[2];}else {out = temp_inp[3];}}}

测试平台搭建

driver生成所有的可能的输入模式,每隔3ns向多路器施加其中一组输入模式。

sync_mux41_driver.h文件

#include <systemc.h>SC_MODULE(driver)
{sc_out<bool> d_reset;sc_out<sc_uint<2> > d_sel;sc_out<sc_uint<4> > d_inp;void prc_driver();SC_CTOR(driver){SC_THREAD(prc_driver);}
};void driver::prc_driver()
{d_reset =0;wait(7, SC_NS);d_reset =1;for(int i=0; i<=15; i++){d_inp =i;for(int j=0; j<=3; j++){d_sel = j;wait(3, SC_NS);}}
}

只要多路器输入和输出端口的值发生任何改变,模块monitor将打印出所有输入端口和输出端口的值。

sync_mux41_monitor.h文件

#include <systemc.h>SC_MODULE(monitor)
{sc_in<bool> m_clock, m_reset;sc_in<sc_uint <2> > m_sel;sc_in<sc_uint <4> > m_inp;sc_in<bool> m_out;void prc_monitor();SC_CTOR(monitor){SC_METHOD(prc_monitor);sensitive << m_clock << m_reset << m_sel << m_inp << m_out;}};void monitor::prc_monitor()
{cout<<"At time "<<sc_simulation_time()<<"::";cout<<"(clock, reset, sel, inp): ";cout<<m_clock.read()<<","<<m_reset.read()<<","<<m_sel.read()<<","<<m_inp.read();cout<<" out:"<<m_out.read()<<"\n";
}

sc_main生成用vcd格式的仿真波形记录文件,让仿真连续运行100ns。

sync_mux41_main.cpp文件

#include "sync_mux41_driver.h"
#include "sync_mux41_monitor.h"
#include "sync_mux41.h"const int CLOCK_PERIOD =2;int sc_main(int argc, char* argv[])
{sc_signal<bool> t_reset;sc_signal<sc_uint<4> > t_inp;sc_signal<sc_uint<2> > t_sel;sc_signal<bool> t_out;sc_clock t_clock("clock", CLOCK_PERIOD);sync_mux41 m1("SyncMuxer4x1");m1(t_clock, t_reset, t_sel, t_inp, t_out);driver d1("GenerateWaveforms");d1(t_reset, t_sel, t_inp);monitor mo1("MonitorWaveforms");mo1(t_clock, t_reset, t_sel, t_inp, t_out);sc_trace_file *tf =sc_create_vcd_trace_file("sync_mux41");sc_trace(tf, t_clock, "clock");sc_trace(tf, t_reset, "reset");sc_trace(tf, t_inp, "input");sc_trace(tf, t_sel, "select");sc_trace(tf, t_out, "output");sc_start(100, SC_NS);sc_close_vcd_trace_file(tf);return 0;}

测试平台输出:

这篇关于SystemC入门之测试平台编写完整示例:带同步输出的多路选择器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/881749

相关文章

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

SpringBoot中配置Redis连接池的完整指南

《SpringBoot中配置Redis连接池的完整指南》这篇文章主要为大家详细介绍了SpringBoot中配置Redis连接池的完整指南,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以... 目录一、添加依赖二、配置 Redis 连接池三、测试 Redis 操作四、完整示例代码(一)pom.

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me