LOOP REWIND - Return Type
Description
This message reports that the code is violating loop rewind optimization rules.
Explanation
Loop rewind optimization requires the function return to either be void or have a return statement.
The following example will fail optimization.
int decoderInput(hls::stream<mag_type> &inputStream, hls::stream<dataPair> &pairedData)//, hls::stream<int> &windex)
{
static count_type cnt;
mag_type val, val_next;
dataPair tempData;
int n=0;
decoderInput_whileloop:while(1)
{
#pragma HLS PIPELINE II=1 rewind
if(!inputStream.empty())
{
if(cnt==0)
{
tempData.even = inputStream.read();
cnt =1;
}
else
{
tempData.odd=inputStream.read();
pairedData.write(tempData);
cnt=0;
}
}
else
{
break;
}
}
}
Solution
The loop rewind optimization requires the function return type to either be void or have a return statement.