VIVADO的差分转单端IBUFDS的使用

   外部控制器与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;所以会报错。

你可能感兴趣的:(笔记)