第一部分 基础普及 2
笔记1 初识FPGA 2
一、关于FPGA的一些基本概念 2
二、关于FPGA的基本结构 6
笔记2 应用领域 11
一、逻辑黏合与实时控制 11
二、信号采集处理与协议实现 12
三、原型验证系统、片上系统与其他应用 12
笔记3 开发流程 14
一、需求分析到模块划分 15
二、设计输入到综合优化 15
三、实现到时序收敛 16
四、仿真测试到板级调试 16
第二部分 基本语法 20
笔记4 语法学习的经验之谈 20
笔记5 可综合的语法子集 23
一、模块声明类语法:module…endmodule 23
二、端口声明:input,output,inout 23
三、参数定义:parameter 24
四、信号类型:wire,reg等 25
五、比较判断:if…else,case…default…endcase 26
六、循环语句:for 27
七、任务定义:task…endtask 27
八、连续赋值:assign,问号表达式(?:) 27
九、always模块 28
十、运算操作符 28
十一、赋值符号:=和<= 29
笔记6 代码书写规范 30
一、代码书写规范 30
二、标识符 30
三、格式 32
四、注释 32
笔记7 代码风格 33
一、代码风格概述 33
二、寄存器电路的设计方式 33
三、同步以及时钟的设计原则 37
四、双向引脚的控制代码 39
五、提升系统性能的代码风格 40
第三部分 设计技巧与思想 48
笔记8 漫谈状态机设计 48
一、状态机的基本概念 48
二、3种不同状态机写法 49
笔记9 复位设计 57
一、异步复位与同步复位 57
二、复位与亚稳态 59
三、异步复位、同步释放 60
四、PLL配置后的复位设计 61
笔记10 FPGA重要设计思想及工程应用 63
一、速度和面积互换原则 63
二、乒乓操作及串/并转换设计 64
三、流水线设计 65
四、逻辑复制与模块复用 67
五、模块化设计 68
六、时钟设计技巧 71
笔记11 基于FPGA的跨时钟域信号处理 74
一、同步设计思想 75
二、单向控制信号检测 79
三、专用握手信号 81
四、搞定亚稳态 84
五、借助于存储器 88
第四部分 仿真测试 92
笔记12 简单的Testbench设计 92
一、Testbench概述 92
二、基本Testbench的搭建 93
笔记13 Testbench书写技巧 98
一、封装有用的子程序 98
二、关于变量的定义 99
三、HDL的并行性 100
四、结构化Testbench 101
五、读/写紊乱状态 105
六、防止同时调用task 107
笔记14 测试用例设计 109
一、模拟串口自收发通信 109
二、乘法器全覆盖测试 113
三、可重用MCU读/写设计 117
第五部分 时序分析 122
笔记15 时序分析基础 122
一、基本的时序分析理论 122
二、时钟、建立时间和保持时间 126
三、基本时序路径分析 129
四、reg2reg路径的时序分析 132
笔记16 reg2pin时序分析案例 135
笔记17 pin2reg时序分析案例 141
笔记18 基于TimeQuest的时序分析 147
一、从Technology Map Viewer分析Clock Setup Slack 147
二、基于TimeQuest的reg2reg之Th分析 149
三、添加时序例外 151
四、多周期约束的基本用法 153
五、Quartus Ⅱ流水线均衡负载设置实例 157
六、读SRAM时序约束分析 162
七、源同步接口的时序模型 165
八、recovery时序优化一例 170
九、基于Chip Planner的时序优化一例 175
第六部分 实践经验与感悟 182
笔记19 系统架构思想 182
一、FPGA到底能做什么 182
二、DMA无处不在 184
三、图片显示速度测试报告 187
四、仲裁逻辑设计要点 190
五、硬件加速:用起来很美 192
六、数据吞吐量预估一例 195
七、秒杀FPGA片间通信 197
八、FPGA+CPU:并行处理大行其道 200
笔记20 实践应用技巧 203
一、被综合掉的寄存器 203
二、Verilog中宏定义位宽带来的问题 204
三、Verilog代码可移植性设计 208
四、Cyclone器件全局时钟尽在掌控 211
五、Cyclone Ⅲ原型开发调试 215
六、M4K使用率 218
七、榨干FPGA片上存储资源 218
八、存储器实现方式转换 225
九、关于MAX Ⅱ上电和复位的一点讨论 229
十、基于Altera FPGA的LVDS配置实例 232
十一、用FPGA的差分输入实现A/D转换 237
十二、守株待兔,收效显著 238
笔记21 板级调试 241
一、复用引脚,陷阱多多 241
二、EPCS芯片的信号完整性问题 242
三、都是I/O弱上拉惹的祸 244
四、被忽略的硬件常识——I/O电气特性 246
五、PLL专用输出引脚带来的反思 248
六、毛刺滤波的一些方法 249
七、基于FPGA的LVDS差分阻抗设计应用实例 252
八、使用FPGA时钟展频技术搞定RE测试 262
第七部分 项目案例 268
笔记22 DIY逻辑分析仪 268
一、背景介绍 268
二、功能需求及模块划分 269
三、数据采集、触发及存储 272
四、基于VGA的显示界面设计 274
笔记23 DIY数码相框 277
一、背景介绍 277
二、功能需求及模块划分 278
三、SPI接口控制 281
四、SD卡数据存储结构与FAT16文件系统 283
五、SD卡初始化及读操作 293
六、SDRAM控制器设计 296
七、BMP格式图片显示 297
第八部分 网络杂文 308
笔记24 苦练基本功 308
一、datasheet要看原版 308
二、开发工具要熟练 309
三、焊接功底要扎实 309
四、不要厌烦写文档 310
笔记25 永远忠于年轻时的梦想 313
笔记26 年轻正当时 315
笔记27 FPGA工程师:持守梦想or屈于现实 317
参考文献 320