-
Notifications
You must be signed in to change notification settings - Fork 10
Home
The goal of this project is to improve the Clang Static Analyzer to be able to detect bugs that span multiple translation units (TUs). CTU analysis has been presented at EuroLLVM '17 (see the submitted Extended abstract for a more in-depth overview.)
To use CTU static analysis, you need to build a version of Clang which supports this feature. (See in Compilation.) Invoking the analyzer requires some special arguments (for an in-depth explanation, see Approach), we suggest using CodeChecker to invoke the analyzer. (See Cross Translation Unit analysis with CodeChecker.) scan-build-py
is currently in the process of supporting CTU.
To analyze your project in strict mode (error on import failures) pass this parameter to clang:
-Werror=odr
You can build a version of Clang by checking out our repository. The commits below tell you which LLVM and clang-tools-extra Git commit to use. To build clang, use the same procedure as usual, but with the commits described below.
The ctu-os
branch collects commits and changes that are currently undergoing review by the community.
ctu-master
and ctu-clang5
contain extra functionality that are continuously aimed to make CTU more viable, especially for C++ projects. -master
follows the master
version of Clang, while -clang5
is branched from the (currently release-candidated) Clang 5.0 version. We suggest using ctu-clang5
to build your Clang binaries from.
Branch ctu-clang5
-> LLVM commit b20d324de517c95e5cb01e88f78855b3d0e10d51
Branch ctu-master
-> LLVM commit 1de13c0dfce98ff01dda7f27c75f4f6bc628877c
Branch ctu-os
-> LLVM commit 7dab9bfe3016988a518ea5868cbf0457d335a356
Branch ctu-clang5
-> CTE commit 619d067acc7165aed1bb8ff86f9579ec666777fa
Branch ctu-master
-> CTE commit 1faaa79f8b8a989bf813dcbd2590265433531ae1
Branch ctu-os
-> CTE commit cdfb024e2f69e1466479278579623167799bca5f
Today, Clang SA can perform (context-sensitive) inter-procedural analysis by "inlining" the called function into the callers context. This means that function parameters (including all constraints) are passed to the called function and the return value of the function is passed back to the caller. This works well for function calls within a translation unit, but when the symbolic execution reaches a function that is implemented in another TU, the analyzer engine handles it as "unknown".
In this project we are working on a method which enables CTU analysis by inlining external function definitions using Clang's existing ASTImporter
functionality.
The EuroLLVM '17 Extended abstract contains a more in-depth description in white paper style.
To perform the analysis we need to run Clang on the whole source code two times.
We generate a binary AST dump (using Clang's -cc1 -emit-pch
feature) of each TU into a temporary directory called preanalyze-dir. We collect the Unified Symbol Resolution (USR) of all externally linkable functions into a text file (externalFnMap.txt
).
We run the Clang Static Analysis for all translation units, and if during inlining an externally defined function is reached, we look up the definition of that function in the corresponding AST file (based on the info in externalFnMap.txt
) and import the function definition into the caller's context using the ASTImpoter
library.
We have run comparative analysis on several open source projects, such as openssl, FFMpeg, Git, Xerces, tmux, etc. We found several additional bugs compared to the normal (non cross-translation-unit capable) analysis.
See the results on cc.elte.hu/
, with memory usage and result comparison.
This work is based on earlier work of Aleksei Sidorin, Artem Dergachev, et al. See http://lists.llvm.org/pipermail/cfe-dev/2015-October/045730.html.
- Home
- Usage of CTU Analysis
- Compilation
- Develop and debug CTU
EuroLLVM
'17 Extended abstract- Open source project analyzed with CTU
- External resources