FPGA学习笔记1.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
FPGA学习笔记 XilinxFPGA开发流程的熟悉(ISE使用) 工欲善其事必先利其器,FPGA学习先从开发环境的熟悉开始,整体了解整个开发流程,了解一个完整的设计流程包括电路设计与输入、功能仿真、设计综合、综合后仿真(静态时序仿真)、设计实现、布线后仿真(时序仿真)和下载、板调试等主要步骤,如下图所示。 图1 整体过程示意图 我以全加器作为熟悉过程实例。 1:verilog源码输入: `timescale 1ns / 1ps module Fu_Str(A,B,Cin,Sum,Cout); input A,B,Cin; output Sum,Cout; wire S1,T1,T2,T3; xor X1(S1,A,B), X2(Sum,S1,Cin); And A1(T3,A,B), A2(T2,B,Cin), A3(T1,A,Cin); or o1(Cout,T1,T2,T3); endmodule 2 Test Bench Wavform: 功能仿真: 程序测试: `timescale 1ns / 1ps module FuAdder; // Inputs reg A; reg B; reg Cin; // Outputs wire Sum; wire Cout; integer i,j; // Instantiate the Unit Under Test (UUT) Fu_Str uut ( .A(A), .B(B), .Cin(Cin), .Sum(Sum), .Cout(Cout) ); initial begin // Initialize Inputs A = 0; B = 0; Cin = 0; for(i=1;i10;i=i+1) #10 A=i; end initial begin for(j=1;j10;j=j+1) #10 B=j; end initial begin $monitor($time,,,%d+%d+%d={%d,%d},A,B,Cin,Sum,Cout); #100 $finish;// Wait 100 ns for global reset to finish end endmodule 运行结果: 0 0+0+0={0,0} 10 1+1+0={0,1} 20 0+0+0={0,0} 30 1+1+0={0,1} 40 0+0+0={0,0} 50 1+1+0={0,1} 60 0+0+0={0,0} 70 1+1+0={0,1} 80 0+0+0={0,0} 90 1+1+0={0,1} Stopped at time : 100.000 ns 3 综合: RLT Schematic: 双击查看内部结构: 半加器实验 1源码: `timescale 1ns / 1ps module HalfAdder(A,B,SUM,Carry); input A,B; output SUM,Carry; assign #2 SUM=A^B; assign #5 Carry=AB; endmodule 功能仿真 输入波形: 输出波形: 原理图: 内部结构: 时序仿真: 8位移位寄存器 源码: module shifter(din, clk, clr, dout); input din, clk, clr; output [7:0] dout; reg [7:0] dout; always @(posedge clk) begin if (clr) dout = 8h0; // 同步清0 else begin dout = dout1; //输出信号左移一位 dout[0] = din; // 输入信号补充到输出信号的最低位 end end 功能仿真 波形输入: 波形输出: 原理图 内部结构: 主要过程只是学习熟悉开发环境 Verilog语言学习 其他从略,主要关注几种线网中多个驱动源驱动一个连线时,线网有效值的取值表 只是一个很粗浅的

文档评论(0)

hong333666 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档