| /* { dg-do compile } */ |
| /* { dg-options "-ffast-math -O3 -fdump-tree-vrp-thread1-details" } */ |
| |
| int I = 50, J = 50; |
| int S, L; |
| const int *pL; |
| const int *pS; |
| |
| void bar (float, float); |
| |
| void foo (int K) |
| { |
| int k, i, j; |
| static float LD, SD; |
| for (k = 0 ; k < K; k++) |
| { |
| for( i = 0 ; i < ( I - 1 ) ; i++ ) |
| { |
| if( ( L < pL[i+1] ) && ( L >= pL[i] ) ) |
| break ; |
| } |
| |
| if( i == ( I - 1 ) ) |
| L = pL[i] ; |
| LD = (float)( L - pL[i] ) / |
| (float)( pL[i + 1] - pL[i] ) ; |
| |
| for( j = 0 ; j < ( J-1 ) ; j++ ) |
| { |
| if( ( S < pS[j+1] ) && ( S >= pS[j] ) ) |
| break ; |
| } |
| |
| if( j == ( J - 1 ) ) |
| S = pS[j] ; |
| SD = (float)( S - pS[j] ) / |
| (float)( pS[j + 1] - pS[j] ) ; |
| |
| bar (LD, SD); |
| } |
| } |
| /* { dg-final { scan-tree-dump-times "Threaded jump " 2 "vrp-thread1" } } */ |