Violation of Latency Constraint for Sub Loops

Description

The tool is informing the user that the parent loop contains sub-loops of different latencies

Explanation

The message is to inform the user that the code is violating latency optimization rules. These sub-loops latencies will be added to the total parent latency as shown in the below code.

Here the latency of the parent loop = sum(read_a+read_b+read_c) * No of parent loop iterations

  for (int i = 0; i < iterations; i++)
{
#pragma HLS LOOP_TRIPCOUNT min=c_len/c_n max=c_len/c_n
#pragma HLS LATENCY min=1 max=10
    read_a:
        for (int x = 0; x < N; ++x) {
         #pragma HLS LOOP_TRIPCOUNT min=c_n max=c_n
           #pragma HLS PIPELINE II=1
            result[x] = a[i * N + x];
        }
 
    read_b:
        for (int x = 0; x < N; ++x) {
           #pragma HLS LOOP_TRIPCOUNT min=c_n max=c_n
           #pragma HLS PIPELINE II=1
            result[x] += b[i * N + x];
        }
 
    write_c:
        for (int x = 0; x < N; ++x) {
           #pragma HLS LOOP_TRIPCOUNT min=c_n max=c_n
           #pragma HLS PIPELINE II=1
            c[i * N + x] = result[x];
        }
    }

Solution

When specifying latency constraint to the parent loop, consider taking into account the latency of the sub-loops when applying the latency constraint.