SystemC学习(3)— APB_SRAM的建模与测试

SystemC学习(3)— APB_SRAM的建模与测试

一、前言

二、APB_SRAM建模

编写APB_SRAM模型文件apb_sram.h文件如下所示:

#ifndef __APB_SRAM_H
#define __APB_SRAM_H#include "systemc.h"const int ADDR_SIZE = 32;
const int DATA_SIZE = 32;SC_MODULE(apb_sram){sc_in<bool> apb_pclk;sc_in<bool> apb_presetn;sc_in<bool> apb_psel;sc_in<bool> apb_penable;sc_in<bool> apb_pwrite;sc_in<sc_uint<ADDR_SIZE> > apb_paddr;sc_in<sc_uint<DATA_SIZE> > apb_pwdata;sc_out<sc_uint<DATA_SIZE> > apb_prdata;sc_out<bool> apb_pready;sc_out<bool> apb_pslverr;sc_bv<DATA_SIZE> mem[4096];SC_CTOR(apb_sram){SC_METHOD(prc_apb_sram);    sensitive << apb_pclk.pos();sensitive << apb_presetn.neg();}void prc_apb_sram(){if(!apb_presetn){apb_prdata = 0;apb_pready = 0;apb_pslverr = 0;}else if((apb_psel.read()==1) && (apb_penable.read()==0) && (apb_pwrite.read()==0)) {apb_prdata = mem[(apb_paddr.read()>>2)];}else if((apb_psel.read()==1) && (apb_penable.read()==1) && (apb_pwrite.read()==0)) {apb_pready = 1;}else if((apb_psel.read()==1) && (apb_penable.read()==1) && (apb_pwrite.read()==1)) {mem[(apb_paddr.read()>>2)] = apb_pwdata;apb_pready = 1;}else {apb_prdata = apb_prdata;apb_pready = 0;}}
};#endif

三、测试平台

编写“driver.h”如下所示:

#ifndef __DRIVER_H
#define __DRIVER_H#include "apb_sram.h"SC_MODULE(driver){sc_in<bool> apb_pclk;sc_out<bool> apb_presetn;sc_out<bool> apb_psel;sc_out<bool> apb_penable;sc_out<bool> apb_pwrite;sc_out<sc_uint<ADDR_SIZE> > apb_paddr;sc_out<sc_uint<DATA_SIZE> > apb_pwdata;sc_in<sc_uint<DATA_SIZE> > apb_prdata;sc_in<bool> apb_pready;sc_in<bool> apb_pslverr;SC_CTOR(driver){SC_THREAD(prc_test);sensitive << apb_pclk.pos();}void prc_test(){apb_presetn.write(0);apb_psel.write(0);apb_penable.write(0);apb_pwrite.write(0);apb_paddr.write(0);apb_pwdata.write(0);wait();wait();apb_presetn.write(1);wait();wait();// writefor(int i=0; i<16; i++) {apb_psel.write(1);apb_penable.write(0);apb_pwrite.write(1);apb_paddr.write(i*4);apb_pwdata.write(i);wait();apb_penable.write(1);wait();while(apb_pready.read() != 1){wait();}apb_psel.write(0);apb_penable.write(0);wait();wait();}// readfor(int i=0; i<16; i++) {apb_psel.write(1);apb_penable.write(0);apb_pwrite.write(0);apb_paddr.write(i*4);wait();apb_penable.write(1);wait();while(apb_pready.read() != 1){wait();}apb_psel.write(0);apb_penable.write(0);wait();wait();}sc_stop();}};#endif

四、测试运行

使用如下命令进行编译:

g++ main.cpp -I${SYSTEMC_HOME}/include/ -L${SYSTEMC_HOME}/lib-linux64 -lsystemc -o run.x

运行命令:

./run.x

打开test.vcd 文件可看到波形如下所示:
在这里插入图片描述

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

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

相关文章

Spring Boot Configuration和AutoConfiguration加载逻辑和加载顺序调整

在spring中&#xff0c; AutoConfiguration也是一个种Configuration&#xff0c;只是AutoConfiguration是不能使用proxy的。 而且spring对于两者的加载顺序也不是一视同仁&#xff0c;是有顺序的。spring会先加载SpringBootApplication可达的且标注了Configuration的类&#x…

CodeS:构建用于文本到 SQL 的开源语言模型

发布于&#xff1a;2024 年 10 月 29 日 #RAG #Text2 SQL #NL2 SQL 语言模型在将自然语言问题转换为 SQL 查询&#xff08;文本到 SQL &#xff09;的任务中显示出良好的性能。然而&#xff0c;大多数最先进的 &#xff08;SOTA&#xff09; 方法都依赖于强大但闭源的大型语言…

社区交流系统设计与实现

社区交流系统设计与实现 1. 系统概述 社区交流系统是一个基于PHP和SQL的Web应用程序&#xff0c;旨在为用户提供一个互动交流的平台。该系统允许用户注册、发布帖子、回复帖子、查看其他用户的帖子和回复&#xff0c;以及管理个人资料&#xff0c;提高用户之间的互动和信息共享…

什么是字节序、大小端、高低字节、高低地址?

目录 1. 什么是字节序&#xff08;Endianness&#xff09;&#xff1f; 2. 什么是大小端&#xff08;Big-Endians and Little-Endian&#xff09;&#xff1f; 3. 什么时候需要用到大小端的概念&#xff1f; 4. 如何确认系统的大小端模式&#xff1f; 5. 什么是大小端定义…

为什么 C 语言数组是从 0 开始计数的?

C 语言等大多数编程语言的数组从 0 开始而不从 1 开始&#xff0c;有两个原因&#xff1a; 第一&#xff1a;地址计算更方便 C 语言从 0 开始的话&#xff0c;array[i] 的地址就正好是&#xff1a; (array i) 如果是从 1 开始的话&#xff0c;就是 (array i - 1) 多一次计…

锁升级及线程池相关

锁升级 在JVM底层实现锁的过程中&#xff0c;有三类锁&#xff1a;偏斜锁、轻量级锁、重量级锁 在Java6之前&#xff0c;synchronized的实现完全依靠重量级锁&#xff08;系统内的互斥锁&#xff09;&#xff0c;从用户态转为内核态非常消耗资源。在Java6之后&#xff0c;提供…

vue3+less使用主题定制(多主题定制)可切换主题

假如要使用两套主题&#xff1a;蓝色、红色 例如&#xff1a; 首先确保自己的vue3项目有less&#xff0c;这边不多做接入解释 1、在src目录下建一个styles文件夹&#xff0c;在syles文件夹下面新建两个less文件&#xff1a;theme.less和variables.less&#xff1b; theme.le…

Java面试经典 150 题.P80. 删除有序数组中的重复项 II(004)

本题来自&#xff1a;力扣-面试经典 150 题 面试经典 150 题 - 学习计划 - 力扣&#xff08;LeetCode&#xff09;全球极客挚爱的技术成长平台https://leetcode.cn/studyplan/top-interview-150/ 题解&#xff1a; class Solution {public int removeDuplicates(int[] nums)…

【QNAP威联通NAS系统恢复进阶教程】如果 .conf 和 md9 无法自动组装,如何恢复 NAS?

创作立场&#xff1a;原创不易&#xff0c;拒绝搬运~ hello大家好&#xff0c;我是你们的老伙伴&#xff0c;稳重的大王~ 从本期开始&#xff0c;大王将在日常教程中&#xff0c;分享一些QNAP系统故障的排除以及解决办法&#xff0c;进阶教程需要具备一定的linux基础&#xf…

【JavaEE】【多线程】进阶知识

目录 一、常见的锁策略1.1 悲观锁 vs 乐观锁1.2 重量级锁 vs 轻量级锁1.3 挂起等待锁 vs 自旋锁1.4 普通互斥锁 vs 读写锁1.5 可重入锁 vs 不可重入锁1.6 不公平锁 vs 公平锁 二、synchronized特性2.1 synchronized的锁策略2.2 synchronized加锁过程2.3 其它优化措施 三、CAS3.…

玄机-应急响应- Linux入侵排查

一、web目录存在木马&#xff0c;请找到木马的密码提交 到web目录进行搜索 find ./ type f -name "*.php" | xargs grep "eval(" 发现有三个可疑文件 1.php看到密码 1 flag{1} 二、服务器疑似存在不死马&#xff0c;请找到不死马的密码提交 被md5加密的…

沈阳乐晟睿浩科技有限公司抖音小店运营创新

在当今这个数字化迅猛发展的时代&#xff0c;电子商务已经成为推动经济增长的重要引擎。而在电商的广阔舞台上&#xff0c;短视频与直播带货的崛起无疑是最为耀眼的明星之一。作为这一领域的佼佼者&#xff0c;抖音小店凭借其庞大的用户基础和独特的算法优势&#xff0c;吸引了…

使用Python和Parsel库爬取CSDN博客文章专栏并生成Markdown链接列表的导航

引言 今天&#xff0c;我将分享如何使用Python的requests和parsel库来爬取CSDN博客的文章&#xff0c;并生成一个Markdown格式的链接列表导航页。 我在整理这个专栏Linux基础操作合集的文章合集时&#xff0c;发现想要给这个专栏的文章做个导航合集页很麻烦&#xff0c;虽然直…

哪个牌子的宠物空气净化器好?口碑好的宠物空气净化器推荐!

哪个牌子的宠物空气净化器好&#xff1f;作为一名家电测评博主&#xff0c;我发现市面上宠物空气净化器的牌子越来越多了&#xff0c;很多厂家都看中了宠物行业的红利&#xff0c;想来分一杯羹&#xff0c;这就导致很多技术不成熟的产品流入了市场。今年我测试了50多台宠物空气…

数据清理——确保数据质量的关键步骤

简介 在数据分析和机器学习中&#xff0c;数据清理是预处理过程中的重要一环。良好的数据清理能够提高数据的质量&#xff0c;从而提升模型的准确性和可靠性。本篇文章将深入探讨数据清理的几个关键知识点&#xff0c;包括缺失值处理、数据不一致问题和噪声处理。通过详细的概…

isp框架代码理解

一、整体框架如下&#xff1a; 1 外层的src中 1.1 从camera.c->task.c&#xff1a;封装了3层&#xff0c;透传到某个功能的本级。 1.2 core.c和capability.c中实现&#xff1a;开机初始化加载参数。2. plat/src中 2.1 fun.c中继task.c又透传了一层&#xff1b;以及最后功能…

状态机模型

文章目录 一、大盗阿福二、股票买卖 IV三、股票买卖 V四、设计密码4.1kmp题目4.2设计密码 一、大盗阿福 题目链接 #include<iostream> #include<cstring> #include<algorithm> using namespace std; const int N 1e5 10; int f[N][2]; int main() {int…

MATLAB——矩阵操作

内容源于b站清风数学建模 数学建模清风老师《MATLAB教程新手入门篇》https://www.bilibili.com/video/BV1dN4y1Q7Kt/ 目录 1.MATLAB中的向量 1.1向量创建方法 1.2向量元素的引用 1.3向量元素修改和删除 2.MATLAB矩阵操作 2.1矩阵创建方法 2.2矩阵元素的引用 2.3矩阵…

一:Linux学习笔记(第一阶段)-- 安装软件 vmware workstation 虚拟机软件 centos系统

目录 学习计划&#xff1a; 资源准备 虚拟机软件&#xff1a;就别自己找了 现在换网站了 下载比较费劲 Centos8&#xff1a; 阿里云镜像地址下载&#xff08;下载比较版 但是有不同版本&#xff09;&#xff1a;centos安装包下载_开源镜像站-阿里云 百度网盘地址&#xff…

如何在Linux系统中使用Zabbix进行监控

如何在Linux系统中使用Zabbix进行监控 Zabbix简介 安装Zabbix 在Debian/Ubuntu系统中安装 在CentOS/RHEL系统中安装 配置Zabbix数据库 创建数据库 导入数据库 配置Zabbix服务器 访问Zabbix Web界面 完成初始配置 配置Zabbix Agent 安装Agent 配置Agent 添加主机到Zabbix 创…