在ZYNQ7 Processing System IP核中集成的UART控制器是一个中全双工异步接收器和发送器,支持广泛的可编程波特率和I/O信号格式,可以适应自动奇偶校验生成和多主机检测模式。
UART操作由配置和模式寄存器控制。使用状态寄存器、中断状态寄存器和调制解调器状态寄存器来读取FIFO队列、调制解调器信号以及其他控制器功能的状态。
UART控制器的系统视图如下图所示。
data:image/s3,"s3://crabby-images/24a98/24a988f2449f98172e5f161d5e7b649c1c3277d8" alt=""
其在PL侧的用法如下:
1 配置IP核
新建工程,FPGA芯片选择xc7z030ffg676-2,
data:image/s3,"s3://crabby-images/d1aa2/d1aa2e12ca60ad2116e815e3dc0e1754a48ea00c" alt=""
创建一个Block Design,添加ZYNQ7 Processing System IP核,
data:image/s3,"s3://crabby-images/3274c/3274c8b4b5e7f079ee3b22e9b6514d41e90044a8" alt=""
双击ZYNQ7 Processing System IP核,点击MIO Configuration,选择右侧的UART0并配置其管脚,
data:image/s3,"s3://crabby-images/b887d/b887d0ee226acb6eb33d205b7908eb142f7a6698" alt=""
点击Clock Configuration,选择右侧的FCLK_CLK0,并将其输出时钟改为100MHz。
data:image/s3,"s3://crabby-images/3c782/3c7825d6f0df531780210ff891ac53c765a3aae9" alt=""
点击Run Block Automation,选中processing_system7_),点击OK。
data:image/s3,"s3://crabby-images/b56f8/b56f83ae28bc8b8bff678195e95465a6b3b22eb3" alt=""
将ZYNQ7 Processing System IP核输出的FCLK_CLK0连接到其输入M_AXI_GP0_ACLK上。
data:image/s3,"s3://crabby-images/8ac28/8ac2858db54f86811e9ed91b6bc09f9a789b0b72" alt=""
保存工程,右键点击design_1,点击Generate Output Products...
data:image/s3,"s3://crabby-images/d2097/d2097f914f631653f30400a50c1597ccec978913" alt=""
点击Generate,
data:image/s3,"s3://crabby-images/44b37/44b374104e7c8de96155a97655abf0b292a7106a" alt=""
等Generate Output Product完成,如下图所示
data:image/s3,"s3://crabby-images/23feb/23febb9cae2267e4a938a4ea3989ff4fea832573" alt=""
右键点击design_1,点击Create HDL Wrapper...
data:image/s3,"s3://crabby-images/1a0d1/1a0d1eb5736369f78e367f803ff7bf9725db5c3d" alt=""
选择默认的Let Vivado manage wrapper and auto-update,
data:image/s3,"s3://crabby-images/0b6dc/0b6dcb4853277b70526bd0c48206ff342b318b4e" alt=""
点击Generate Bitstream,
data:image/s3,"s3://crabby-images/d3e0f/d3e0f2193290730267358fa45e51365422535da8" alt=""
成功生成bit文件后,点击Cancel。
data:image/s3,"s3://crabby-images/9da46/9da46fa69095e8b7a07411d503db8fb34ca125f0" alt=""
点击File------Export------Export Hardware...
data:image/s3,"s3://crabby-images/091dc/091dc591c8b9fa22bf1fc375b0bd544e90eac7e0" alt=""
选中Include bitstream,点击OK。
data:image/s3,"s3://crabby-images/83e71/83e710dad58f2114855ff55dd57af90d2282d82e" alt=""
2 在SDK上搭建工程
点击File------Launch SDK。
data:image/s3,"s3://crabby-images/5270b/5270baccd81fcff1da4438fdc61477680e26a508" alt=""
在SDK中点击File------New------Application Project,
data:image/s3,"s3://crabby-images/b0bae/b0baebcb14c6433dc625e31c4433ecf02ac459ea" alt=""
输入工程名,点击Next,
data:image/s3,"s3://crabby-images/79cc4/79cc42e48ba6e4875907f52932b6214d81fd5b54" alt=""
选择Hello World,点击Finish。
data:image/s3,"s3://crabby-images/4bb23/4bb2330d56789c46fbcb147a5445f681b0d13510" alt=""
点击Run------Debug Configuration,点击Xilinx C/C++ application(System Debugger)下的System Debugger on Local,配置如下:
data:image/s3,"s3://crabby-images/25f1b/25f1b899bff1ef0c9c30a4e3a0c2ef75fb4680c2" alt=""
3 加电运行
按《Xilinx SDK操作步骤详细介绍》一文详细操作步骤,波特率设置为115200,会接收到hello world字符串显示界面。