-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.txt
75 lines (41 loc) · 3.11 KB
/
README.txt
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
=== CLANG CMS ===
These are the CMS clang static analyzer checkers to crawl C/C++ code for constructs which my become problematic when running multi-threaded code or do violate CMS Framework Rules.
by Thomas Hauth - Thomas.Hauth@cern.ch and
Patrick Gartung - gartung@fnal.gov
== Available Checkers ==
threadsafety.ConstCastAway "Checks for casts which remove const qualifier"
threadsafety.ConstCast "Checks for indirect casts which remove const qualifier"
threadsafety.StaticLocal "Checks for non-const method local statics"
threadsafety.MutableMember "Checks for members with the mutable keyword"
threadsafety.GlobalStatic "Checks for global non-const statics"
optional.ClassChecker "Checks data classes for thread safety issues"
optional.FunctionChecker "Reports functions which access non-const statics"
== Compile LLVM / clang ==
The minimum required version of llvm/clang required to compile the module is v3.5
The minimum required version of gcc/g++ required to compile llvm/clang is v4.7
Follow the directions to obtain and compile LLVM/clang here:
http://clang.llvm.org/get_started.html#build
If you are compiling on RHEL6 or similar systems install the devtoolset-1.1 package.
If you are compiling on Ubuntu 14 systems install build-essentials package group.
Build and install llvm/clang on your system. Note the location if the install directory.
Now, checkout the repository which contains the CMS checkers :
git clone https://github.com/gartung/clang_cms.git
and run
PATH=(llvm install path)/bin:$PATH
cmake .
make
inside the clang_cms folder. If you need to disable the CMS-specific filters, comment out lines in src/ClangCmsCheckerPluginRegister.cpp. If you encounter problems with missing files or directories, you may need to edit the file CMakeLists.txt to adapt it to your specific build configuration.
The CMS specific checkers have now been compiled into an external library in clang_cms/libclangSAplugin.so .
== Test on a small example ==
Export the path to the new clang binary ( Bash example ):
You will need to include the paths to clang, scan-build and scan-view in your path
export PATH=$PATH:(llvm install path)/bin/:(llvm install path)/tools/clang/tools/scan-build/:(llvm install path)/tools/clang/tools/scan-view/
To see a listing of all available checkers, also the CMS-specific ones, you can run the scan-build command:
scan-build -load-plugin libclangSAplugin.so
Test out the newly compiled and modified clang, cd into the clang_cms/test folder and run:
scan-build -load-plugin ../lib/libclangSAplugin.so -enable-checker threadsafety -enable-checker optional.ClassChecker -enable-checker optional.FunctionChecker make -B
This will produce a clang static analyzer html you can open in your favorite browser. You can find the location in the output line, something along the lines:
scan-build: 41 bugs found.
scan-build: Run 'scan-view /tmp/scan-build-2015-07-23-123119-18007-1' to examine bug reports.
firefox /tmp/scan-build-2015-07-23-123119-18007-1/index.html
If you also want to generate the reports for thread-safety, you also need to add the additional parameters to scan-build.