2018-03-02 09:41:19 +08:00
|
|
|
// RUN: %clang_analyze_cc1 -analyzer-checker=core,debug.ExprInspection -analyzer-config unroll-loops=true,cfg-loopexit=true -verify -std=c++11 -analyzer-config exploration_strategy=unexplored_first_queue %s
|
2018-02-27 09:31:56 +08:00
|
|
|
// RUN: %clang_analyze_cc1 -analyzer-checker=core,debug.ExprInspection -analyzer-config unroll-loops=true,cfg-loopexit=true,exploration_strategy=dfs -verify -std=c++11 -DDFS=1 %s
|
2017-07-26 03:23:23 +08:00
|
|
|
|
|
|
|
void clang_analyzer_numTimesReached();
|
2017-08-28 18:34:50 +08:00
|
|
|
void clang_analyzer_warnIfReached();
|
2017-07-26 03:23:23 +08:00
|
|
|
|
|
|
|
int getNum();
|
|
|
|
void foo(int &);
|
2017-08-28 18:50:28 +08:00
|
|
|
|
2017-07-26 03:23:23 +08:00
|
|
|
int simple_unroll1() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{9}}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_unroll2() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{9}}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
2017-08-19 18:24:52 +08:00
|
|
|
|
|
|
|
for (int j = 0; j <= 9; ++j) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{10}}
|
|
|
|
a[j] = 42;
|
|
|
|
}
|
|
|
|
|
2017-07-26 03:23:23 +08:00
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
[analyzer] Unroll the loop when it has a unsigned counter.
Summary:
The original implementation in the `LoopUnrolling.cpp` didn't consider the case where the counter is unsigned. This case is only handled in `simpleCondition()`, but this is not enough, we also need to deal with the unsinged counter with the counter initialization.
Since `IntegerLiteral` is `signed`, there is a `ImplicitCastExpr<IntegralCast>` in `unsigned counter = IntergerLiteral`. This patch add the `ignoringParenImpCasts()` in the `IntegerLiteral` matcher.
Reviewers: szepet, a.sidorin, NoQ, george.karpenkov
Reviewed By: szepet, george.karpenkov
Subscribers: xazax.hun, rnkovacs, cfe-commits, MTC
Differential Revision: https://reviews.llvm.org/D45086
llvm-svn: 328919
2018-03-31 20:46:46 +08:00
|
|
|
int simple_unroll3_unsigned() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
for (unsigned i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{9}}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_unroll4_unsigned() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
unsigned i;
|
|
|
|
for (i = (0); i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{9}}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2017-07-26 03:23:23 +08:00
|
|
|
int simple_no_unroll1() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
foo(i);
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_no_unroll2() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
i += getNum();
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_no_unroll3() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
2017-08-28 18:34:50 +08:00
|
|
|
for (int i = 0; i < 9; i++) {
|
2017-07-26 03:23:23 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
(void)&i;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_no_unroll4() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
int &j = i;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_no_unroll5() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
int &j{i};
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-03-27 20:16:56 +08:00
|
|
|
int no_unroll_assignment() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i = i + 1;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment2() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i *= 2;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment3() {
|
|
|
|
for (int i = 128; i > 0; i--) {
|
|
|
|
i /= 2;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment4() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i -= 2;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment5() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i += 1;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment6() {
|
|
|
|
for (int i = 128; i > 0; i--) {
|
|
|
|
i >>= 1;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment7() {
|
|
|
|
for (int i = 0; i < 512; i++) {
|
|
|
|
i <<= 1;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment8() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i %= 8;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment9() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i &= 31;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment10() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i |= 2;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int no_unroll_assignment11() {
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
i ^= 2;
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2017-08-28 18:34:50 +08:00
|
|
|
int make_new_branches_loop_cached() {
|
|
|
|
for (int i = 0; i < 8; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
2018-03-27 20:16:56 +08:00
|
|
|
if (getNum()) {
|
|
|
|
(void)i; // Since this Stmt does not change the State the analyzer
|
|
|
|
// won't make a new execution path but reuse the earlier nodes.
|
|
|
|
}
|
2017-08-28 18:34:50 +08:00
|
|
|
}
|
|
|
|
clang_analyzer_warnIfReached(); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int make_new_branches_loop_uncached() {
|
|
|
|
int l = 2;
|
|
|
|
for (int i = 0; i < 8; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{10}}
|
2018-03-27 20:16:56 +08:00
|
|
|
if (getNum()) {
|
2017-08-28 18:34:50 +08:00
|
|
|
++l;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
clang_analyzer_warnIfReached(); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int make_new_branches_loop_uncached2() {
|
|
|
|
int l = 2;
|
|
|
|
for (int i = 0; i < 8; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{10}}
|
2018-03-27 20:16:56 +08:00
|
|
|
if (getNum()) {
|
2017-08-28 18:34:50 +08:00
|
|
|
++l;
|
|
|
|
}
|
|
|
|
(void)&i; // This ensures that the loop won't be unrolled.
|
|
|
|
}
|
|
|
|
clang_analyzer_warnIfReached(); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-19 18:24:52 +08:00
|
|
|
int escape_before_loop_no_unroll1() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int i;
|
|
|
|
int &j = i;
|
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int escape_before_loop_no_unroll2() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int i;
|
|
|
|
int *p = &i;
|
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int escape_before_loop_no_unroll3() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int i;
|
|
|
|
foo(i);
|
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2017-07-26 03:23:23 +08:00
|
|
|
int nested_outer_unrolled() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int j = 0;
|
|
|
|
for (int i = 0; i < 9; i++) {
|
2017-08-28 18:34:50 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{1}}
|
|
|
|
for (j = 0; j < 9; ++j) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
2017-07-26 03:23:23 +08:00
|
|
|
a[j] = 22;
|
2018-03-27 20:16:56 +08:00
|
|
|
(void)&j; // ensures that the inner loop won't be unrolled
|
2017-07-26 03:23:23 +08:00
|
|
|
}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int nested_inner_unrolled() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int j = 0;
|
|
|
|
for (int i = 0; i < getNum(); i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
for (j = 0; j < 8; ++j) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{32}}
|
|
|
|
a[j] = 22;
|
|
|
|
}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int nested_both_unrolled() {
|
|
|
|
int a[9];
|
|
|
|
int k = 42;
|
|
|
|
int j = 0;
|
|
|
|
for (int i = 0; i < 7; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{7}}
|
|
|
|
for (j = 0; j < 6; ++j) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{42}}
|
|
|
|
a[j] = 22;
|
|
|
|
}
|
|
|
|
a[i] = 42;
|
|
|
|
}
|
|
|
|
int b = 22 / (k - 42); // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_known_bound_loop() {
|
|
|
|
for (int i = 2; i < 12; i++) {
|
|
|
|
// This function is inlined in nested_inlined_unroll1()
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{90}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int simple_unknown_bound_loop() {
|
|
|
|
for (int i = 2; i < getNum(); i++) {
|
2018-02-27 09:31:56 +08:00
|
|
|
#ifdef DFS
|
2019-08-02 04:41:13 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{16}}
|
2018-02-27 09:31:56 +08:00
|
|
|
#else
|
2019-08-02 04:41:13 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{8}}
|
2018-02-27 09:31:56 +08:00
|
|
|
#endif
|
2017-07-26 03:23:23 +08:00
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int nested_inlined_unroll1() {
|
|
|
|
int k;
|
|
|
|
for (int i = 0; i < 9; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{9}}
|
|
|
|
k = simple_known_bound_loop(); // no reevaluation without inlining
|
|
|
|
}
|
|
|
|
int a = 22 / k; // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int nested_inlined_no_unroll1() {
|
|
|
|
int k;
|
|
|
|
for (int i = 0; i < 9; i++) {
|
2019-08-02 04:41:13 +08:00
|
|
|
#ifdef DFS
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{18}}
|
2018-06-06 14:25:51 +08:00
|
|
|
#else
|
2019-08-02 04:41:13 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{14}}
|
2018-06-06 14:25:51 +08:00
|
|
|
#endif
|
2017-08-28 18:34:50 +08:00
|
|
|
k = simple_unknown_bound_loop(); // reevaluation without inlining, splits the state as well
|
2017-07-26 03:23:23 +08:00
|
|
|
}
|
|
|
|
int a = 22 / k; // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
2017-08-22 00:32:57 +08:00
|
|
|
|
|
|
|
int recursion_unroll1(bool b) {
|
|
|
|
int k = 2;
|
|
|
|
for (int i = 0; i < 5; i++) {
|
2017-08-28 18:34:50 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{13}}
|
2018-03-27 20:16:56 +08:00
|
|
|
if (i == 0 && b) // Splits the state in the first iteration but the recursion
|
|
|
|
// call will be unrolled anyway since the condition is known there.
|
2017-08-22 00:32:57 +08:00
|
|
|
recursion_unroll1(false);
|
2017-08-28 18:34:50 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{14}}
|
2017-08-22 00:32:57 +08:00
|
|
|
}
|
|
|
|
int a = 22 / k; // no-warning
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int recursion_unroll2(bool b) {
|
|
|
|
int k = 0;
|
|
|
|
for (int i = 0; i < 5; i++) {
|
2017-08-28 18:34:50 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{9}}
|
2018-03-27 20:16:56 +08:00
|
|
|
if (i == 0 && b)
|
2017-08-22 00:32:57 +08:00
|
|
|
recursion_unroll2(false);
|
2017-08-28 18:34:50 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{9}}
|
2017-08-22 00:32:57 +08:00
|
|
|
}
|
|
|
|
int a = 22 / k; // expected-warning {{Division by zero}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int recursion_unroll3(bool b) {
|
|
|
|
int k = 2;
|
|
|
|
for (int i = 0; i < 5; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{10}}
|
2017-08-28 18:50:28 +08:00
|
|
|
if (i == 4 && b) {
|
2017-08-22 00:32:57 +08:00
|
|
|
recursion_unroll3(false);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{10}}
|
|
|
|
}
|
|
|
|
int a = 22 / k;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int recursion_unroll4(bool b) {
|
|
|
|
int k = 2;
|
|
|
|
for (int i = 0; i < 5; i++) {
|
2017-08-28 18:34:50 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{13}}
|
2018-03-27 20:16:56 +08:00
|
|
|
if (i == 0 && b) {
|
2017-08-22 00:32:57 +08:00
|
|
|
recursion_unroll4(false);
|
|
|
|
continue;
|
|
|
|
}
|
2017-08-28 18:34:50 +08:00
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{13}}
|
2017-08-22 00:32:57 +08:00
|
|
|
}
|
|
|
|
int a = 22 / k;
|
|
|
|
return 0;
|
|
|
|
}
|
2017-08-28 18:21:24 +08:00
|
|
|
|
|
|
|
int loop_exit_while_empty_loop_stack() {
|
|
|
|
if (getNum())
|
|
|
|
for (int i = 1; i < 8; i++)
|
|
|
|
;
|
|
|
|
return 0;
|
|
|
|
}
|
2017-08-28 18:34:50 +08:00
|
|
|
|
2017-08-28 18:50:28 +08:00
|
|
|
int num_steps_on_limit() {
|
|
|
|
for (int i = 0; i < 128; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{128}}
|
|
|
|
}
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{1}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int num_steps_over_limit1() {
|
|
|
|
for (int i = 0; i < 129; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int num_steps_on_limit2() {
|
|
|
|
for (int i = 0; i < 2; i++) {
|
|
|
|
for (int j = 0; j < 64; j++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{128}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int num_steps_over_limit2() {
|
|
|
|
for (int i = 0; i < 2; i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{1}}
|
|
|
|
for (int j = 0; j <= 64; j++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int num_steps_on_limit3() {
|
|
|
|
for (int i = 0; i < getNum(); i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
for (int j = 0; j < 32; j++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{128}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int num_steps_over_limit3() {
|
|
|
|
for (int i = 0; i < getNum(); i++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{1}}
|
|
|
|
for (int j = 0; j < 33; j++) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2017-10-28 20:19:08 +08:00
|
|
|
|
|
|
|
void pr34943() {
|
|
|
|
for (int i = 0; i < 6L; ++i) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{6}}
|
|
|
|
}
|
|
|
|
}
|
2020-05-22 19:53:59 +08:00
|
|
|
|
|
|
|
void parm_by_value_as_loop_counter(int i) {
|
|
|
|
for (i = 0; i < 10; ++i) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{10}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void parm_by_ref_as_loop_counter(int &i) {
|
|
|
|
for (i = 0; i < 10; ++i) {
|
|
|
|
clang_analyzer_numTimesReached(); // expected-warning {{4}}
|
|
|
|
}
|
|
|
|
}
|