什么是 FPGA
初学者常困惑 FPGA 与单片机的区别。简单来说,FPGA(Field Programmable Gate Array,现场可编程门阵列)允许从底层构建电路,而单片机是固定架构的芯片。例如,单片机像组装好的乐高套装,FPGA 则像零散积木块,可通过硬件描述语言(如 Verilog)定义任意数字电路。
Vivado 环境搭建
安装包获取
访问 Xilinx 官网下载 Vivado Design Suite(社区版免费)。建议选择 2020.1 之后的版本,安装时勾选 Vivado HL Design Edition 及对应器件支持(如 Artix-7 系列)。
硬件准备
建议先用在线仿真器练习,基础扎实后再入手开发板,如 Nexys A7、Basys3 或 DE10-Nano。
第一个工程创建
打开 Vivado,点击 Create Project,选择 RTL Project 并添加新 Verilog 文件。器件型号通常选 xc7a35tcsg324-1(对应多数入门开发板)。
Verilog 核心语法
// 基础结构模板
module my_module(
input wire clk, // 时钟信号
input wire rst_n, // 复位信号(低有效)
output reg led // LED 输出
);
// 组合逻辑用 assign
assign a = b & c;
// 时序逻辑用 always 块
always @(posedge clk or negedge rst_n) begin
if(!rst_n) begin
led <= 1'b0; // 复位时 LED 灭
end else begin
led <= ~led; // 翻转 LED 状态
end
end
endmodule
必须掌握的 10 个核心语法:
module/endmodule:电路模块定义input/output:输入输出端口wire/reg:线网与寄存器assign:组合逻辑赋值always:过程块(时序逻辑)posedge/negedge:时钟边沿检测if/else:条件判断case:多路选择parameter:参数定义#:延时控制(仅仿真用)
LED 流水灯实战
代码实现
module led_run(
input clk_100MHz, // 开发板上的 100MHz 时钟
input rst_n, // 复位按键(低电平有效)
output reg [3:0] leds // 4 位 LED 输出
);
// 分频器:100MHz -> 1Hz
reg [26:0] counter;
always @(posedge clk_100MHz or negedge rst_n) begin
if(!rst_n) begin
counter <= 0;
end else begin
counter <= (counter == 27'd99_999_999) ? 0 : counter + 1;
end
end
// LED 流水效果
always @(posedge clk_100MHz or negedge rst_n) begin
if(!rst_n) begin
leds <= 4'b0001; // 初始状态
end else if(counter == 27'd99_999_999) begin
leds <= {leds[2:0], leds[3]}; // 循环左移
end
end
endmodule
Modelsim 仿真
创建 testbench 文件进行验证:


