我製作了兩個verilog模塊。第一個數字取9位數字,並返回第一個出現位置1。Verilog模塊實例化和空開始結尾
module findPositionOf_1(
input [8:0] data,
output reg [3:0] position
);
always @(data)
begin
if(data==9'b0000_00000)
position=4'b0000;
else if(data[0]==1)
position=4'b0000;
else if(data[1]==1)
position=4'b0001;
else if(data[2]==1)
position=4'b0010;
else if(data[3]==1)
position=4'b0011;
else if(data[4]==1)
position=4'b0100;
else if(data[5]==1)
position=4'b0101;
else if(data[6]==1)
position=4'b0110;
else if(data[7]==1)
position=4'b0111;
else if(data[8]==1)
position=4'b1000;
end
endmodule
第二模塊返回1.第二次出現它調用第一模塊首先改變該位爲零,再次找到的1
module findPositionOf_2nd_1(
input [8:0] r1_data,
output [3:0] position1
);
reg [3:0] pos,pos2;
reg [8:0] temp;
integer i;
always @(r1_data)
begin
findPositionOf_1 f1(.data(r1_data), .position(pos));
i=pos;
temp=r1_data;
temp[i]=0;
findPositionOf_1 f2(temp,pos2);
if(pos2==4'b0000)
position1=0;
else
position1=pos2;
end
endmodule
我正在發生以下編譯期間出現錯誤。請幫忙。
找不到'checkPositionOf_1'。實例化'f1'必須是可見的檢查器 。 發現一個空的正文開始/結束塊。 SystemVerilog中允許使用此 ,但在Verilog中不允許。請 尋找任何流浪分號。
爲什麼不能實例化發生在always塊。我對verilog很陌生。 – panshul