- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)