APB Slave设计实践

2023-10-21 22:30
文章标签 设计 实践 apb slave

本文主要是介绍APB Slave设计实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

APB接口描述

APB写传输

APB读传输

APB Slave 设计

APB Slave testbench


APB接口描述

APB写传输

APB读传输

APB Slave 设计

module apb_slave(//input signalspclk,presetn,psel,penable,pwrite,pwdata,paddr,//output signalsprdata);input         pclk   ;
input         presetn;
input         psel   ;
input         penable;
input         pwrite ;
input  [31:0] pwdata ;
input  [31:0] paddr  ;
output [31:0] prdata ;parameter REG1_ADDR  = 8'h00;
parameter REG2_ADDR  = 8'h04;
parameter REG3_ADDR  = 8'h08;reg [31:0] prdata    ;
wire       apb_write ;
wire       apb_read  ;
reg [31:0] reg1      ;
reg [31:0] reg2      ;
reg [31:0] reg3      ;
reg [31:0] dummy_reg ;assign apb_write = pwrite && psel && penable ;
assign apb_read  = (!pwrite) && psel && penable;//register write
always @(posedge pclk or negedge presetn)
beginif(!presetn)beginreg1 <= 32'b0;reg2 <= 32'b0;reg3 <= 32'b0;endelse if(apb_write)begincase (paddr[7:0])REG1_ADDR : reg1      <= pwdata ;REG2_ADDR : reg2      <= pwdata ;REG3_ADDR : reg3      <= pwdata ;default   : dummy_reg <= pwdata ;endcaseend
end//register read
always @(*)
beginif(apb_read)begincase (paddr[7:0])REG1_ADDR : prdata <= reg1 ;REG2_ADDR : prdata <= reg2 ;REG3_ADDR : prdata <= reg3 ;default   : prdata <= dummy_reg ;endcaseendelseprdata = 32'b0;
endendmodule
`timescale 1ns/1ps
module apb_slave_tb;reg       pclk   ;
reg       presetn;
reg       psel   ;
reg       penable;
reg       pwrite ;
reg [31:0] pwdata;
reg [31:0] paddr ;
wire[31:0] prdata;reg [31:0] rdata; //Rigster address
parameter REG1_ADDR  = 8'h00;
parameter REG2_ADDR  = 8'h04;
parameter REG3_ADDR  = 8'h08;apb_slave U_apb_slave(.pclk          (pclk),.presetn        (presetn),.psel           (psel),.penable        (penable),.pwrite         (pwrite),.pwdata         (pwdata),.paddr          (paddr),.prdata         (prdata));//clock generate
initial beginpclk = 0 ;forever#10 pclk = ~pclk;
end//reset generate
initial beginpresetn = 0;#128;presetn = 1;
end//initial statement
initial
beginpsel      = 1'b0;penable   = 1'b0;pwrite    = 1'b0;paddr     = 32'b0;pwdata    = 32'b0;wait(presetn);apb_write(REG1_ADDR,32'h12345678);
apb_read (REG1_ADDR,rdata);
#100;
apb_write(REG2_ADDR,32'h55aaaa55);
apb_read (REG2_ADDR,rdata);
#100;
apb_write(REG3_ADDR,32'h5201314a);
apb_read (REG3_ADDR,rdata);#1000;
$finish;
endtask apb_write(input [7:0] addr,input [31:0]wdata);begin@(posedge pclk);  //T2#1;pwrite = 1'b1;psel   = 1'b1;penable= 1'b0;paddr  = addr;pwdata = wdata;@(posedge pclk);  //T3#1;penable= 1'b1;@(posedge pclk);  //T4#1;pwrite = 1'b0;psel   = 1'b0;penable= 1'b0;pwdata = 32'h0;@(posedge pclk);@(posedge pclk);end
endtasktask apb_read(input [7:0] addr,output [31:0]rdata);begin@(posedge pclk);  //T2#1;pwrite = 1'b0;psel   = 1'b1;penable= 1'b0;paddr  = addr;@(posedge pclk);  //T3#1;penable= 1'b1;@(posedge pclk);  //T4#1;rdata  = prdata;psel   = 1'b0;penable= 1'b0;@(posedge pclk);end
endtaskinitial begin $fsdbDumpfile("apb_slave.fsdb");$fsdbDumpvars(0);endendmodule

APB Slave testbench

这篇关于APB Slave设计实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

jdk1.8的Jenkins安装配置实践

《jdk1.8的Jenkins安装配置实践》Jenkins是一款流行的开源持续集成工具,支持自动构建、测试和部署,通过Jenkins,开发团队可以实现代码提交后自动进行构建、测试,并将构建结果分发到测... 目录Jenkins介绍Jenkins环境搭建Jenkins安装配置Jenkins插件安装Git安装配

SpringBoot的全局异常拦截实践过程

《SpringBoot的全局异常拦截实践过程》SpringBoot中使用@ControllerAdvice和@ExceptionHandler实现全局异常拦截,@RestControllerAdvic... 目录@RestControllerAdvice@ResponseStatus(...)@Except

mysql_mcp_server部署及应用实践案例

《mysql_mcp_server部署及应用实践案例》文章介绍了在CentOS7.5环境下部署MySQL_mcp_server的步骤,包括服务安装、配置和启动,还提供了一个基于Dify工作流的应用案例... 目录mysql_mcp_server部署及应用案例1. 服务安装1.1. 下载源码1.2. 创建独立

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

MySQL存储过程实践(in、out、inout)

《MySQL存储过程实践(in、out、inout)》文章介绍了数据库中的存储过程,包括其定义、优缺点、性能调校与撰写,以及创建和调用方法,还详细说明了存储过程的参数类型,包括IN、OUT和INOUT... 目录简述存储过程存储过程的优缺点优点缺点存储过程的创建和调用mysql 存储过程中的关键语法案例存储

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7