SystemC HLS合成错误
SystemC HLS Synthesis Error
@E [SYNCHK-77]顶部函数'method_coupling' (src/method_coupling.cpp:82)没有输出。可能原因有:(1)输出参数按值传递;(2)从未编写预期输出(参数或全局变量);(3)存在无限循环
当我尝试使用vivado HLS合成SystemC块时,我收到了上述错误。不幸的是,我找不到关于这个错误的任何文档,我希望有人能描述一下发生了什么。
我的模块如下:
#include "systemc.h"
#define NUM_REGIONS 10
SC_MODULE(method_coupling){
sc_in<bool> en;
sc_in<bool> clock;
sc_in<bool> reset;
sc_in<double> a;
sc_in<double> in_0;
sc_in<double> in_1;
sc_out<double> out[NUM_REGIONS];
sc_out<bool> done;
sc_in<bool> valid_data0;
sc_in<bool> valid_data1;
double input_0[NUM_REGIONS][NUM_REGIONS];
double input_1[NUM_REGIONS][NUM_REGIONS];
sc_fifo<double> fifo_input_0;
sc_fifo<double> fifo_input_1;
float sum;
int flag;
void init_0(){
while(true){
wait();
if(valid_data0.read() == 1) fifo_input_0.write(in_0.read());
}
}
void init_1(){
while(true){
wait();
if(valid_data1.read() == 1) fifo_input_1.write(in_1.read());
}
}
void do_coupling() {
int i;
for(i=0;i<NUM_REGIONS;i++){
out[i].write(0);
}
flag = 0;
while(flag == 0){
wait();
if(reset.read() == 1){
int i;
for(i = 0 ; i < NUM_REGIONS; i++){
out[i].write(0);
}
done.write(0);
}
else if(en.read() == 1){
int i,j;
done.write(0);
for(i=0; i<NUM_REGIONS;i++){
for(j=0; j<NUM_REGIONS;j++){
if(!(input_0[i][j] = fifo_input_0.read())) cout << "fifo0 is empty" << endl;
if(!(input_1[i][j] = fifo_input_1.read())) cout << "fifo1 is empty" << endl;
}
}
for(i = 0 ; i < NUM_REGIONS; i++){
sum = 0;
for(j = 0; j < NUM_REGIONS; j++){
sum += input_0[i][j]*input_1[i][j];
wait();
}
out[i].write(a.read()*sum);
wait();
}
done.write(1);
flag = 1;
break;
}
}
}
SC_CTOR(method_coupling): fifo_input_0 ("fifo_input_0", NUM_REGIONS*NUM_REGIONS), fifo_input_1 ("fifo_input_1", NUM_REGIONS*NUM_REGIONS) {
SC_THREAD(do_coupling){
//for(int i= 0; i<NUM_REGIONS; i++){
// sensitive << out[i];
//}
sensitive << en << reset << done << clock.pos();
}
SC_THREAD(init_0){
sensitive << valid_data0 << clock.pos();
}
SC_THREAD(init_1){
sensitive << valid_data1 << clock.pos();
}
}
};
我正在读取数据到fifo(特别是两个10x10双数组),然后我使用启用信号开始矩阵乘法操作。当10x10数组相乘后,我在末尾触发一个done信号。
我可以完全看到错误如何表明我有无限while循环,因此我现在使用while(flag == 0)而不是while true循环。
我认为你必须先检查一下你的代码。我不是SystemC专家,但我认为有很多东西是无法综合的。例如,你不能在HLS中使用SC_THREAD
进行合成。如果您希望合成您的代码,您应该以"硬件"的方式进行编码。
相关文章:
- 警告处理为错误这里有什么问题
- "error: no matching function for call to"构造函数错误
- boost::进程间消息队列引发错误
- C++,OpenCV,尝试显示图像时"OpenCV(4.3.0) Error: Assertion failed (size.width>0 && size.height>0)"此错误
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- QT在错误的班级中寻找空位
- vector.resize()中的分配错误
- 代码在main()中运行,但在函数中出现错误
- 释放错误后堆使用
- (C++)分析树以计算返回错误值的简单算术表达式
- Project Euler问题4的错误解决方案
- 我的字符计数代码计算错误.为什么
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 尝试导入pybind-opencv模块时出现libgtk错误
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- 在某些循环内使用vector.push_back时出现分段错误
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- SystemC HLS合成错误