以下Verilog HDL代码符合wishbone总线B3标准协议,在Altera和Xilinx的开发工具上可以实现综合,自动推断并采用片上RAM资源,可以完成内存内容的初始化。

 /*
 ************************************************************************************************
 *    File   : ram_wb.v
 *    Module : ram_wb
 *    Author : Lyu Yang
 *    Date   : 01,01,1970
 *    Description : wishbone generic ram
 ************************************************************************************************
 */

 // synthesis translate_off
 `timescale 1ns / 1ps
 // synthesis translate_on
 `timescale 1ns / 100ps
 module ram_wb (
     clk_i,
     rst_i,
     cyc_i,
     stb_i,
     we_i,
     sel_i,
     adr_i,
     dat_i,
     dat_o,
     cti_i,
     ack_o
 );

 ;
 ;

 // clock
 input                   clk_i;
 // async reset
 input                   rst_i;

 // wishbone signals
 input                   cyc_i;
 input                   stb_i;
 input                   we_i;
 :]           sel_i;
 :] adr_i;
 :]          dat_i;
 :]          dat_o;
 :]           cti_i;
 output  reg             ack_o;

 :]          wr_data;

 // mux for data to ram
 :] = sel_i[] ? dat_i[:] : dat_o[:];
 :] = sel_i[] ? dat_i[:] : dat_o[:];
 : ] = sel_i[] ? dat_i[: ] : dat_o[: ];
 : ] = sel_i[] ? dat_i[ : ] : dat_o[ : ];

 ram #(
     .dat_width(),
     .adr_width(adr_width),
     .mem_size(mem_size)
 ) ram0 (
     .dat_i(wr_data),
     .dat_o(dat_o),
     .adr_i(adr_i[adr_width+:]),
     .we_i(we_i & ack_o),
     .clk(clk_i)
 );

 // ack_o
 always @ (posedge clk_i or posedge rst_i)
 if (rst_i)
     ack_o <= 'b0;
 else if (!ack_o)
     begin
         if (cyc_i & stb_i)
             ack_o <= 'b1;
     end
 'b111))
     ack_o <= 'b0;

 endmodule

 //////////////////////////////////////////////////////////////////////////
 module ram
 (
     clk,
     we_i,
     adr_i,
     dat_i,
     dat_o
 );

 ;
 ;
 ;

 :]      dat_i;
 :]      adr_i;
 input                        we_i;
 :] dat_o;
 input                      clk;   

 :] ram [:mem_size - ];

 initial $readmemh("data.txt", ram);

 always @ (posedge clk)
 begin
     dat_o <= ram[adr_i];
     if (we_i)
         ram[adr_i] <= dat_i;
 end 

 endmodule // ram
      

  使用Verilog中的$readmemh(filepath, data)或者$readmemb(filepath, data)功能,不仅在仿真中可以实现内存内容的初始化,现在的综合工具可以分析并得出适合各家工具的初始化文件并完成综合。

  另外,data.txt中数据内容的描述格式为:@十六进制地址[空白间隔 Tab Space \n]十六进制数据。例如,笔者在写Nios II处理器bootloader时候,片上存储bootloader程序的初始化文件部分为:

@00000000
00808014
@00000001
1001483a
@00000002
10bff804
@00000003
00bffd16
@00000004
00400034kljdaklj

  需要注意的是,地址可以不写,如果不写的话工具读取的时候认为地址从0开始连续分布。如果内容少于所需,那么剩余部分填充内容不确定(一般为0)。

Wishbone B3总线Generic RAM写法的更多相关文章

  1. OR1200处理器中Wishbone总线接口模块WB_BIU介绍

    下面内容摘自<步步惊芯--软核处理器内部设计分析>一书 WB_BIU模块是OR1200处理器与外部Wishbone总线连接的接口模块.15.1节给出了WB_BIU模块的对外连接关系,并指出 ...

  2. Wishbone接口通用RAM

    /* ************************************************************************************************ ...

  3. 自己动手写事件总线(EventBus)

    本文由云+社区发表 事件总线核心逻辑的实现. EventBus的作用 Android中存在各种通信场景,如Activity之间的跳转,Activity与Fragment以及其他组件之间的交互,以及在某 ...

  4. RAM建模和初始化

    冯诺依曼提出的存储计算,计算存储,因此,几乎所有的CPU和ASIC都会使用存储器,它们的类型很多,包括异步RAM.同步RAM.ZBT RAM.DDR DRAM.ROM等.由于大部分的异步RAM和SRA ...

  5. OpenRisc-44-or1200的pipeline整体分析

    引言 我们在前面分析了ORPSoC,or1200_top,和or1200_cpu的整体架构,在最近,我们也分析了or1200的pipeline(流水线)中的两级,EX级和IF级. 但是,我们还没有从宏 ...

  6. 《Linux 性能及调优指南》1.4 硬盘I/O子系统

    翻译:飞哥 (http://hi.baidu.com/imlidapeng) 版权所有,尊重他人劳动成果,转载时请注明作者和原始出处及本声明. 原文名称:<Linux Performance a ...

  7. OpenRisc-47-or1200的WB模块分析

    引言 “善妖善老,善始善终”,说的是无论什么事情要从有头有尾,别三分钟热度. 对于or1200的流水线来说,MA阶段是最后一个阶段,也是整条流水线的收尾阶段,负责战场的清扫工作.比如,把运算指令的运算 ...

  8. python 读取csv文件

    python中有一个读写csv文件的包,直接import csv即可 新建test.csv 1.写 import csv with open("test.csv","w& ...

  9. JIRA中的标记语言的语法参考

    前言 看到网上有的文章说JIRA是使用Textile这门标记语言,有些语法和Wikitext和Markdown相像.JIRA在2017年进行了一次大更新,某些语法可能和以前不大一样,这里纪录一下常用的 ...

随机推荐

  1. vue css动画

    .toggle-cart-enter-active, .toggle-cart-leave-active { transition: all .3s ease-out; } .toggle-cart- ...

  2. 《java并发编程实战》读书笔记5--任务执行, Executor框架

    第6章 任务执行 6.1 在线程中执行任务 第一步要找出清晰的任务边界.大多数服务器应用程序都提供了一种自然的任务边界选择方式:以独立的请求为边界. -6.6.1 串行地执行任务 最简单的任务调度策略 ...

  3. scp命令详解—跨服务器复制文件

    scp在跨机器复制的时候为了提高数据的安全性,使用了ssh连接和加密方式,如果机器之间配置了ssh免密码登录,那在使用scp的时候密码都不用输入. 在服务器104.238.161.75上操作,将服务器 ...

  4. 主机批量扫描工具fping,hping安装及使用

    https://blog.csdn.net/weixin_39762926/article/details/79476196?utm_source=blogxgwz0 https://blog.csd ...

  5. 关于rem的一点总结【原创】

    关于rem的一点总结 最近在写一个关于小说阅读的webApp,由于没有借用任何框架,所以很多底层的内容都需要自己去解决,幸好的是这次只是关于移动端的内容,还不至于去向着jquery的方向码代码.言归正 ...

  6. loadrunner测试TCP协议服务器性能

    loadrunner测试TCP协议服务器性能 . 性能loadrunner测试c 最近对服务器的性能感兴趣,于是开始研究了一阵子loadrunner如何做采用TCP协议交互的服务器的性能测试,对loa ...

  7. CentOS7用yum安装MySQL与启动

    首先CentOS7 已经不支持mysql,因为收费了你懂得,所以内部集成了mariadb,而安装mysql的话会和mariadb的文件冲突,所以需要先卸载掉mariadb,以下为卸载mariadb,安 ...

  8. AndroidManifest.xml文件详解(uses-feature)

    http://blog.csdn.net/think_soft/article/details/7596796 语法(SYNTAX): <uses-featureandroid:name=&qu ...

  9. CSU - 1337 (搞笑版费马大定理 )

    费马大定理:当n>2时,不定方程an+bn=cn没有正整数解.比如a3+b3=c3没有正整数解.为了活跃气氛,我们不妨来个搞笑版:把方程改成a3+b3=c3,这样就有解了,比如a=4, b=9, ...

  10. 【转】python assert用法

    1.assert语句用来声明某个条件是真的.2.如果你非常确信某个你使用的列表中至少有一个元素,而你想要检验这一点,并且在它非真的时候引发一个错误,那么assert语句是应用在这种情形下的理想语句.3 ...