File: bitwise-shift-state-update.c

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (42 lines) | stat: -rw-r--r-- 1,753 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// RUN: %clang_analyze_cc1 -analyzer-checker=core.BitwiseShift \
// RUN:    -analyzer-config core.BitwiseShift:Pedantic=true \
// RUN:    -analyzer-checker=debug.ExprInspection \
// RUN:    -analyzer-config eagerly-assume=false \
// RUN:    -verify=expected,c \
// RUN:    -triple x86_64-pc-linux-gnu -x c %s \
// RUN:    -Wno-shift-count-negative -Wno-shift-negative-value \
// RUN:    -Wno-shift-count-overflow -Wno-shift-overflow \
// RUN:    -Wno-shift-sign-overflow
//
// RUN: %clang_analyze_cc1 -analyzer-checker=core.BitwiseShift \
// RUN:    -analyzer-config core.BitwiseShift:Pedantic=true \
// RUN:    -analyzer-checker=debug.ExprInspection \
// RUN:    -analyzer-config eagerly-assume=false \
// RUN:    -verify=expected,cxx \
// RUN:    -triple x86_64-pc-linux-gnu -x c++ -std=c++14 %s \
// RUN:    -Wno-shift-count-negative -Wno-shift-negative-value \
// RUN:    -Wno-shift-count-overflow -Wno-shift-overflow \
// RUN:    -Wno-shift-sign-overflow

// Tests for validating the state updates provided by the BitwiseShift checker.
// These clang_analyzer_value() tests are in a separate file because
// debug.ExprInspection repeats each 'warning' with an superfluous 'note', so
// note level output (-analyzer-output=text) is not enabled in this file.

void clang_analyzer_value(int);
void clang_analyzer_eval(int);

int state_update_generic(int left, int right) {
  int x = left << right;
  clang_analyzer_value(left); // expected-warning {{32s:{ [0, 2147483647] } }}
  clang_analyzer_value(right); // expected-warning {{32s:{ [0, 31] } }}
  return x;
}

int state_update_exact_shift(int arg) {
  int x = 65535 << arg;
  clang_analyzer_value(arg);
  // c-warning@-1 {{32s:{ [0, 15] } }}
  // cxx-warning@-2 {{32s:{ [0, 16] } }}
  return x;
}