EDA实验·Libero设计流程

前言

广东工业大学计算机学院EDA数字逻辑实验软件Libero完整设计流程,本文以74HC148进行举例讲解

新建工程

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

在这里插入图片描述
选好后直接点击finish

输入设计代码

在这里插入图片描述
双击Create HDL
在这里插入图片描述
点击OK

输入功能描述代码,该HDL代码文件保存于项目文件夹"\hdl"子目录下(以74HC148的功能描述代码为例)

//74HC148代码
 module encoder8_3_1(din, EI, GS, EO, dout);
     input [7:0] din;  
     input EI;  
     output [2:0] dout;  
     output GS;  
     output EO;  
     reg [2:0] dout;
     reg GS, EO;
     always @(din or EI)
      if(EI) begin dout <= 3'b111; GS <= 1; EO <= 1; end  
      else if (din[7] == 0) begin dout <= 3'b000; GS <= 0; EO <= 1; end
      else if (din[6] == 0) begin dout <= 3'b001; GS <= 0; EO <= 1; end
      else if (din[5] == 0) begin dout <= 3'b010; GS <= 0; EO <= 1; end
      else if (din[4] == 0) begin dout <= 3'b011; GS <= 0; EO <= 1; end
      else if (din[3] == 0) begin dout <= 3'b100; GS <= 0; EO <= 1; end
      else if (din[2] == 0) begin dout <= 3'b101; GS <= 0; EO <= 1; end
      else if (din[1] == 0) begin dout <= 3'b110; GS <= 0; EO <= 1; end
      else if (din[0] == 0) begin dout <= 3'b111; GS <= 0; EO <= 1; end
      else if (din == 8'b11111111) begin dout <= 3'b111; GS <= 1; EO <= 0; end 
      else begin dout <= 3'b111; GS <= 1; EO <= 1; end  
endmodule

在这里插入图片描述
点击√:检查代码是否有误
在这里插入图片描述

输入测试平台代码

双击Create HDL Testbench
在这里插入图片描述
在这里插入图片描述
点击OK
输入测试平台代码,该HDL Testbench代码文件保存于项目文件夹"\stimulus"子目录下(以74HC148的测试平台代码为例)

`timescale 1ns/1ps
 module testbench8_3_1();
      reg EI;
      reg [7:0] din;
      wire EO;
      wire GS;
      wire [2:0] dout;
      encoder8_3_1 i1 (.EI(EI), .EO(EO), .GS(GS), .din(din), .dout(dout));
    initial                                                
        begin                                                  
          EI = 1;
          din = 8'b11111111;
           #10 EI = 0;
           #10 din = 8'b01010101;
           #10 din = 8'b10101010; 
           #10 din = 8'b11010101;
           #10 din = 8'b11101010;
           #10 din = 8'b11110101;
           #10 din = 8'b11111010;
           #10 din = 8'b11111101;
           #10 din = 8'b11111110;
           #10 din = 8'b11111111;          
        end                      
 endmodule

点击√:检查代码是否有误
在这里插入图片描述

对应名称设置

在这里插入图片描述
点击图片右上角的设置
在这里插入图片描述
点击DO file

将名称对应地设置好
在这里插入图片描述
点击Save进行保存,然后关闭该窗口
在这里插入图片描述

仿真(综合前)

在这里插入图片描述
点击Simulate,会自动显示出波形图
在这里插入图片描述
将滑块拉至最左边,通过放大镜/放小镜进行缩放显示

用完后记得关闭窗口

综合

在这里插入图片描述
双击Synthesize

仿真(综合后)

在这里插入图片描述
点击Synthesize的Simulate,会自动显示出波形图

用完后记得关闭窗口

布局布线约束

在这里插入图片描述
点击Create/Edit I/O Attributes
在这里插入图片描述
在这里插入图片描述
点击Layout
在这里插入图片描述
点击OK
在这里插入图片描述
Layout已被点绿
在这里插入图片描述
点击Back-Annotate
在这里插入图片描述
点击OK
在这里插入图片描述
Back-Annotate已被点绿

在这里插入图片描述
点击Programing File
在这里插入图片描述
点击Finish
在这里插入图片描述
点击Generate
在这里插入图片描述
Programing File已被点绿

在这里插入图片描述
点击I/O Attributes Editor
在这里插入图片描述
IN:接输入
OUT:接输出
Pin Number:接线口

可以自定义接线口,编写完成后Ctrl+s保存,将Layout、Back-Annotate、Programing File重新点绿

对照着接完线后记得关闭窗口

仿真(布局布线后)

在这里插入图片描述
点击Simulate,会自动显示出波形图

用完后记得关闭窗口

烧录

在这里插入图片描述
右键点击"Progrm Device",选择Open Interactively

在这里插入图片描述
点击Refresh刷新出烧录设备及其参数

在这里插入图片描述
点击PROGRAM进行烧录,等待烧录完成即可

注意:若显示的是RUN而不是PROGRAM,需手动加载编程文件
在这里插入图片描述
点击Configuration
在这里插入图片描述
点击Load
在这里插入图片描述
点击PDB文件,点击打开
在这里插入图片描述
显示出PROGRAM

  • 38
    点赞
  • 173
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值