Vivado软件(用VerilogHDL)如何使用$readmemh和$readmemb函数

0 前言

博主我查了很多资料,虽然会使用Verilog的readmemh和readmemh和readmemhreadmemb函数,可是,在vivado软件中怎么用?文件放在哪里?没有一篇文章提及。

花了几个小时,终于研究明白了,特此记录下来,也希望为后来者提供帮助。

对于函数使用的讲解,不再赘述,其他博主写的很好了,点此查看即可。

这里重点强调,文件放在哪里!

1. 两种文件访问方式

1.1 默认路径访问

reg [31:0] rom [31:0];initial     $readmemh ( "rom.txt",rom);

对于上述表示方式rom.txt,这个文件的位置,必须放在指定文件夹内

  1. 打开vivado工程文件的路径
    在这里插入图片描述
    进入sim文件夹,然后依次进入sim_1behavxsim
  2. 在此文件夹内,建立rom.txt文件
    在这里插入图片描述
    在这里建立rom.txt文件即可,之后仿真的时候,就可以正常调用数据了。

1.2 绝对路径访问

    reg [31:0] rom [31:0];initial     $readmemh ( "D:/myCollege/ComputerOrganization/VerilogDesign/test_readmemh/rom.txt",rom);

如上所示,直接给出文件的绝对路径,这样就可以任意设定rom.txt文件的位置。

补充学习链接

注意:斜杠一定要是/,直接复制过来的win路径不是这个,需要修改。

1.3 相对路径访问

这个与win和Linux的cd命令,访问文件的方式一样,不再多说。
在这里插入图片描述
通过上面的指令,你就可以把数据文件放在最表面的位置,好找。
在这里插入图片描述

2 教训

在这里插入图片描述
在这里插入图片描述

  1. 大小写错了
  2. 报错没看懂
  3. 报错一直在找文件位置的问题,但是这玩意之前解决过阿……

首先,大小写不该错,但是真错了,是很难看的出来……

其次,报错含义:dataROm未声明可能C++能看到,到Verilog咋就看不懂了??以后心态放平和。

找错注意:2个属性,这个不是,那就是另外一个

最后,文件位置之前解决了,还记录在本文,第31行一共就2个属性,非抓第一个不放干嘛。

好了,以后不要再犯这种愚蠢的错误了。

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

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

相关文章

【汇编语言】王爽第六章程序6.3解答,8086汇编语言实现数据的倒序存放

程序很简单,就是利用栈,实现数据的倒序存放。 ; 将数据逆序存放 assume ds:data data segment dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h data endsassume ss:stack stack segmentdw 0,0,0,0,0,0,0,0 stack endsassume cs:code code segmen…

---------愿 青春与我皆不付---------------------

2019年8月4日晚 21点51 我愿以此用博客来记录我的学习之路 void mian(void) { while(1) { run(); } } 不负光阴 不负卿

【汇编语言】快速理解什么是寻址,什么是寻址方式

0 前言 有很多专业的资料讲述这些概念,但是,虽然很专业,但是初学者根本看不懂! 因此在这里,我用最简单的方式,告诉你 什么是寻址什么是寻址方式 1 计算机的极简模型 计算机的世界中,只有二…

【汇编语言】程序设计过程,如何避免数据类型匹配错误?

真言:操作数据,先看方式,再对应解决 0 前言 对于x86系列的汇编语言,AT&T格式需要使用后缀指明操作数的数据类型,Intel格式并没有这样的规定,但是,数据类型还是必须匹配,这就导…

【汇编语言】王爽实验5(5)(6)的解答 建立数据类型匹配的观念

0 前言 本文解答王爽《汇编语言》实验5的(5)(6)题 同时给出一些常见问题的解答 以及给出最易犯错的地方:数据类型不匹配的解决方案 1 题目解答 1.1 实验5(5) 1.1.1 题目 将data1和data2段…

【Java图文趣味版】快速搞定数组的声明、开辟空间和初始化赋值

0 前言 本文讲解java数组的基础知识,适合零基础小白。 1 数组的概念 所谓数组,就是一组同类型东西的集合,可以通过index(索引,下标)访问这一组东西的某一个元素。 就像下图这样,由于数组概念…

【java图文趣味版】数组元素的访问与遍历

0 前言 本文适合零基础小白。 本文接上一篇文章:快速搞定数组的声明、开辟空间和初始化赋值 重要的知识点 通过array index访问数组使用for each循环遍历数组使用Arrays.toString()方法打印数组 我们先创建一个数组,之后通过它来说明后面的知识。 …

初来乍到,多多关照。

从今天开始就要开始写博客了,把学到的知识都在这里记录下来,希望可以坚持,并且学到东西。

【MySQL】AUTO_INCREMENT只能应用于数值类型的列,且该列需要被索引

MySQL中的自动增量AUTO_INCREMENT,是有使用条件的 该列(column)的数据类型必须是数值型(这点容易理解,数值才能自增)该列必须被索引,比如定义为主键(PRIMARY KEY) 感悟…

【数据库】数据模型基础概念(图文版)

0 前言 本文通过一个实例,来讲解数据模型的基础概念。 要求设计一个数据库的数据模型,统计出你的宿舍每个人(4个人)的信息,要求包括 个人信息:学号、姓名、班级、年级、学院选课情况:学号、课程…

利用SIGCHLD信号回收子进程

子进程执行结束之后,父进程如果不对其进行回收,子进程就会变为僵尸进程。 父进程可以通过调用wait()函数和waitpid()函数去回收子进程. 由于子进程结束时会发送SIGCHLD信号给父进程,不过此信号的默认动作为忽略,我们可以通过系统函…

【汇编语言】8086汇编语言的debug中,t和p命令的区别

单步跟踪命令(单步进入(step in)):t命令是单步执行,是真的单步执行,碰到任何地方,都会一步步执行,遇到子程序,也会进入里面一步步执行再返回 单步执行命令(单步通过(ste…

哲学家就餐问题(如何避免死锁)(多线程版)

哲学家就餐问题 多线程编程中&#xff0c;常常会遇到线程间访问共享资源的问题&#xff0c;如果处理不当则会发生死锁&#xff0c;某一个线程可能永远访问不到共享资源。 为了避免死锁的发生&#xff0c;提出哲学家就餐问题。 下面展示一些代码片段 #include <stdio.h>…

【汇编语言】汇编语言如何编程,如何避免出错

0 前言 这里以8086汇编语言举例。 1 重要方法&#xff1a;画流程图 这一点不再多说&#xff01;你懂的&#xff01;只要真的画流程图&#xff0c;并且按此翻译为汇编代码&#xff0c;程序出错几率就会减少很多。 2 框架思维&#xff1a;构建标准编程框架 这里只举例说明一…

【汇编语言】8086汇编字符串定义为何使用DB?其他数据类型不可以吗?(20200515复盘)

目录0 前言0.1 先告诉你结论1 8086汇编语言中的字符串1.1 字符串的定义与使用1.2 直接定义的细节1.2.1 使用DB数据类型1.2.2 使用其他数据类型1.3 直接使用的细节1.3.1 赋值给寄存器1.3.2 赋值给内存单元1.3.3 字符串直接使用的本质1.4 应用2 扩展&#xff1a;数据定义的方式3 …

哲学家就餐(避免死锁)(多进程版)

哲学家就餐&#xff08;避免死锁&#xff09;&#xff08;多进程版&#xff09; 哲学家就餐利用信号量在多进程之间实现 下面展示一些代码片段 #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <sys/wait.h> #include <sys…

【汇编语言】数据类型的匹配问题:自动匹配与手动匹配

0 前言 本文基于8086汇编语言&#xff0c;不过x86系列语言具备向下兼容特点&#xff0c;大多数情况都可以用。 与高级语言数据类型的自动转换和强制转换一样&#xff0c;汇编语言的数据类型也有 自动匹配和手动匹配。 下面&#xff0c;我来介绍一下汇编语言的相关原则。 1 …

生产者消费者模型(条件变量+互斥锁)

生产者消费者模型 线程同步典型的案例即为生产者消费者模型&#xff0c;而借助条件变量来实现这一模型&#xff0c;是比较常见的一种方法。假定有两个线程&#xff0c;一个模拟生产者行为&#xff0c;一个模拟消费者行为。两个线程同时操作一个共享资源&#xff0c;生产者向其…

【汇编语言】王爽实验8,分析一个奇怪的程序,学习笔记(20200517)

0 前言 先给出源程序 assume cs:code code segmentmov ax,4c00hint 21hstart:mov ax,0s:nopnopmov di,offset smov si,offset s2mov ax,cs:[si]mov cs:[di],axs0:jmp short ss1:mov ax,0int 21hmov ax,0s2:jmp short s1nopcode ends end start运行结果&#xff1a;本程序能够…