Este ejemplo implementa un pin bidireccional sincronizado en Verilog HDL. El valor de OE determina si el licitador es una aportación, un valor inp o un triple estado, lo que impulsa el valor b.
Para obtener más información sobre el uso de este ejemplo en su proyecto, vaya a:
bidir.v
module bidirec (oe, clk, inp, outp, bidir);
// Port Declaration
input oe;
input clk;
input [7:0] inp;
output [7:0] outp;
inout [7:0] bidir;
reg [7:0] a;
reg [7:0] b;
assign bidir = oe ? a : 8'bZ ;
assign outp = b;
// Always Construct
always @ (posedge clk)
begin
b <= bidir;
a <= inp;
end
endmodule