如何解决错误:在 ModelSim 中模拟时“未能在分层名称“return”中找到“return”
我正在编写一个 verilog 程序。当我编译时,没有错误。但是当我模拟这个程序时,出现错误:"MixColumns.v(14): (vopt-7063) 未能在分层名称'return'中找到'return'。" 我该怎么做才能解决这个问题?非常感谢你 这是我的 Verilog 代码
module MixColumns(
input [127:0] before_MixColumns,output reg [127:0] after_MixColumns
);
function [7:0] mul_2;
input [7:0] a;
begin
mul_2 = (a[7] == 1) ? ((a << 1) ^ 8'b00011011) : (a << 1);
end
endfunction
function reg [7:0] mul_3 (input [7:0] a);
return (a ^ mul_2(a));
endfunction
function reg [31:0] matrix_mul_word (input [31:0] a);
begin
matrix_mul_word[31:24] = mul_2(a[31:24]) ^ mul_3(a[23:16]) ^ a[15:8] ^ a[7:0] ;
matrix_mul_word[23:16] = a[31:24] ^ mul_2(a[23:16]) ^ mul_3(a[15:8]) ^ a[7:0] ;
matrix_mul_word[15:8] = a[31:24] ^ a[23:16] ^ mul_2(a[15:8]) ^ mul_3(a[7:0]) ;
matrix_mul_word[7:0] = mul_3(a[31:24]) ^ a[23:16] ^ a[15:8] ^ mul_2(a[7:0]) ;
end
endfunction
always @*
begin
after_MixColumns[127:96] = matrix_mul_word(before_MixColumns[127:96]);
after_MixColumns[95:64] = matrix_mul_word(before_MixColumns[95:64] );
after_MixColumns[63:32] = matrix_mul_word(before_MixColumns[63:32] );
after_MixColumns[31:0] = matrix_mul_word(before_MixColumns[31:0] );
end
endmodule
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。