0

我正在关注教程。在第 24 页上,我没有得到教程中提到的 Makefile。当我运行./thruwire它说:bash: ./thruwire: Invalid argument

这是我的 thruwire.v:

module thruwire(i_sw, o_led);
    input   wire    i_sw;
    output  wire    o_led;
    
    assign o_led = i_sw;
endmodule

在生成了这个 verilog 文件后,我运行了这些命令来创建 obj_dir 目录:

verilator -Wall -cc thruwire.v
cd obj_dir
make -f Vthruwire.mk

然后,我在我的主目录中创建了一个文件 thruwire.cpp(所以是 obj_dir 上面的那个),如下所示:

#include <stdio.h>
#include <stdlib.h>
#include "Vthruwire.h"
#include "verilated.h"

int main(int argc, char **argv)
{
    Verilated::commandArgs(argc, argv);
    
    Vthruwire *tb = new Vthruwire;
    
    for(int k = 0; k < 20; k++)
    {
        tb->i_sw = k&1;
        
        tb->eval();
        
        printf("k = %2d, ", k);
        printf("i_sw = %2d, ", tb->i_sw);
        printf("led = %2d, ", tb->o_led);
    }
}

我返回一个目录并编译如下所有内容:

cd ..
g++ -I /usr/share/verilator/include -I obj_dir /usr/share/verilator/include/verilated.cpp thruwire.cpp obj_dir/Vthruwire__ALL.a -o thruwire

到目前为止,我已经完成了教程中提到的所有内容,直到幻灯片 24。但是,我的项目目录中没有 Makefile,根据教程应该是这样。当我运行 ./thruwire 时,我得到所说的错误。

我对这一切都很陌生,请帮帮我。我错过了什么吗?

我尝试使用 --exe 标志,因为文档说将为我生成一个模拟可执行文件。但它在运行时给了我同样的错误。我尝试自己指定参数并一起从主函数中删除参数,但它一直给我这个错误。

我正在虚拟盒子图像中运行模拟。我最近使用本指南缩小了 .vdi 。我不知道这是否与它有关。

4

1 回答 1

-1

我的工具箱坏了。正如评论中所讨论的那样,工作工具箱不会给出这些错误(不幸的是,用户删除了它们)。我想尝试自己构建整个工具包并不是一个好主意,除非你真的知道自己在做什么。我找到了一个可以轻松使用而没有问题的cad 套件。它具有预编译和工作所需的所有工具。

于 2021-11-04T20:18:47.273 回答