考虑一个具有两个 IP 内核的设计ip1.v
,ip2.v
每个内核声明一个(不同的)具有相同名称的模块。
例如,内容ip1.v
:
module ip1 (input A, B, C, output X);
wire T;
mygate gate_0 (.I0(A), .I1(B), .O(T));
mygate gate_1 (.I0(T), .I1(C), .O(X));
endmodule
module mygate (input I0, I1, output O);
assign O = I0 & I1;
endmodule
和内容ip2.v
:
module ip2 (input A, B, C, output X);
wire T;
mygate gate_0 (.I0(A), .I1(B), .O(T));
mygate gate_1 (.I0(T), .I1(C), .O(X));
endmodule
module mygate (input I0, I1, output O);
assign O = I0 | I1;
endmodule
然后是使用两个 IP 核的顶级模块 ( top.v
):
module top (input A, B, C, output X, Y);
ip1 ip1_inst (.A(A), .B(B), .C(C), .X(X));
ip2 ip2_inst (.A(A), .B(B), .C(C), .X(Y));
endmodule
我怎样才能处理这样的设计,以便每个 IP 内核都能看到它自己的版本mygate
?