外部控制器与FPGA通信的输入输出都是采用的差分信号,所以在FPGA内部处理的时候,对于输入信号需要差分转单端,输出信号需要单端转差分。
直接使用IBUFDS和OBUFDS来实现。
` //差分转单端
IBUFDS RXD_FPGA_diff
(
.I(RXD_P_FPGA),
.IB(RXD_N_FPGA),
.O(RXD_FPGA)
);
`
//单端转差分
OBUFDS TXD_FPGA_diff
(
.O(TXD_P_FPGA),
.OB(TXD_N_FPGA),
.I(TXD_FPGA)
);
不过IBUFDS模块在仿真时报错,如下
[VRFC 10-529] concurrent assignment to a non-net RXD_FPGA is not permitted [“F:/PP/VIVADO/QF81705/QF81705.srcs/sources_1/new/FPGA_COMM_RX.v”:59]
原来是因为我把 RXD_FPGA和TXD_FPGA都定义为的reg信号。但是IBUFDS里面的.O是输出信号,应该使用的ASSIGN,所以只能定义为 wire RXD_FPGA;所以会报错。