llvm-project/clang/lib/CodeGen
Peter Collingbourne 1a7488afaa Implement CFI type checks for non-virtual calls.
This uses the same class metadata currently used for virtual call and
cast checks.

The new flag is -fsanitize=cfi-nvcall. For consistency, the -fsanitize=cfi-vptr
flag has been renamed -fsanitize=cfi-vcall.

Differential Revision: http://reviews.llvm.org/D8756

llvm-svn: 233874
2015-04-02 00:23:30 +00:00
..
ABIInfo.h Fix invalid calling convention used for libcalls on ARM. 2014-12-02 16:04:58 +00:00
BackendUtil.cpp Clang follow-up to LLVM r232772 2015-03-19 22:43:38 +00:00
CGAtomic.cpp [OPENMP] Codegen for 'atomic update' construct. 2015-03-30 05:20:59 +00:00
CGBlocks.cpp Prefer SmallVector::append/insert over push_back loops. Clang edition. 2015-02-17 16:48:30 +00:00
CGBlocks.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGBuilder.h Removing LLVM_DELETED_FUNCTION, as MSVC 2012 was the last reason for requiring the macro. NFC; Clang edition. 2015-02-15 22:54:08 +00:00
CGBuiltin.cpp [SystemZ] Support transactional execution on zEC12 2015-04-01 12:54:25 +00:00
CGCUDANV.cpp [C++11] Add 'override' keyword to virtual methods that override their base class. 2014-03-12 06:41:41 +00:00
CGCUDARuntime.cpp Pass expressions instead of argument ranges to EmitCall/EmitCXXConstructorCall. 2014-08-21 20:26:47 +00:00
CGCUDARuntime.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGCXX.cpp Don't use a doc comment in a function body. 2015-01-12 21:22:27 +00:00
CGCXXABI.cpp Split catch IRgen into ItaniumCXXABI and MicrosoftCXXABI 2015-03-03 19:21:04 +00:00
CGCXXABI.h [MS ABI] Rework .xdata HandlerType emission 2015-03-29 21:55:10 +00:00
CGCall.cpp DebugInfo: Use new LLVM API for DebugLoc 2015-03-30 20:01:41 +00:00
CGCall.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGClass.cpp Implement CFI type checks for non-virtual calls. 2015-04-02 00:23:30 +00:00
CGCleanup.cpp Revert accidental commit. 2015-02-17 16:53:08 +00:00
CGCleanup.h Remove two unused methods. No behavior change. 2015-02-22 00:27:32 +00:00
CGDebugInfo.cpp DebugInfo: Use new LLVM API for DebugLoc 2015-03-30 20:01:41 +00:00
CGDebugInfo.h CodeGen: Update for LLVM API change in r228030 2015-02-03 21:25:34 +00:00
CGDecl.cpp Replace Sema's map of locally-scoped extern "C" declarations with a DeclContext 2015-03-07 00:04:49 +00:00
CGDeclCXX.cpp Fix addrspace when emitting constructors of static local variables 2015-03-25 20:06:28 +00:00
CGException.cpp [MS ABI] Disregard restrictive exception specifications 2015-04-01 04:45:52 +00:00
CGExpr.cpp Fix the LLVM type used when lowering initializer list reference temporaries to global variables. Reapplies r232454 with fix for PR22940. 2015-03-18 01:06:24 +00:00
CGExprAgg.cpp Sema: Parenthesized bound destructor member expressions can be called 2015-02-25 17:36:15 +00:00
CGExprCXX.cpp Implement CFI type checks for non-virtual calls. 2015-04-02 00:23:30 +00:00
CGExprComplex.cpp Sema: Parenthesized bound destructor member expressions can be called 2015-02-25 17:36:15 +00:00
CGExprConstant.cpp CodeGen: Correctly initialize bitfields with non-constant initializers 2015-03-14 22:24:38 +00:00
CGExprScalar.cpp [OPENMP] Codegen for 'atomic update' construct. 2015-03-30 05:20:59 +00:00
CGLoopInfo.cpp CodeGen: Update LoopAttributes for LLVM API change 2015-01-19 21:30:48 +00:00
CGLoopInfo.h Removing LLVM_DELETED_FUNCTION, as MSVC 2012 was the last reason for requiring the macro. NFC; Clang edition. 2015-02-15 22:54:08 +00:00
CGObjC.cpp Prefer SmallVector::append/insert over push_back loops. Clang edition. 2015-02-17 16:48:30 +00:00
CGObjCGNU.cpp Replace size() calls on containers with empty() calls where appropriate. NFC 2015-01-23 15:36:10 +00:00
CGObjCMac.cpp [Objective-C metadata patch]. Patch to allocate one more space for 2015-03-31 22:22:40 +00:00
CGObjCRuntime.cpp Update for llvm api change. 2014-06-04 18:51:46 +00:00
CGObjCRuntime.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGOpenCLRuntime.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGOpenCLRuntime.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGOpenMPRuntime.cpp [OPENMP] Improved codegen for implicit/explicit 'barrier' constructs. 2015-03-30 04:30:22 +00:00
CGOpenMPRuntime.h [OPENMP] Improved codegen for implicit/explicit 'barrier' constructs. 2015-03-30 04:30:22 +00:00
CGRecordLayout.h Removing LLVM_DELETED_FUNCTION, as MSVC 2012 was the last reason for requiring the macro. NFC; Clang edition. 2015-02-15 22:54:08 +00:00
CGRecordLayoutBuilder.cpp Removing LLVM_DELETED_FUNCTION, as MSVC 2012 was the last reason for requiring the macro. NFC; Clang edition. 2015-02-15 22:54:08 +00:00
CGStmt.cpp [OPENMP] Improved code for generating debug info + generation of all OpenMP regions in termination scope 2015-03-10 05:15:26 +00:00
CGStmtOpenMP.cpp [OPENMP] Codegen for 'atomic update' construct. 2015-03-30 05:20:59 +00:00
CGVTT.cpp Use a trivial comdat for C++ tables. 2015-01-15 23:18:01 +00:00
CGVTables.cpp Implement CFI type checks for non-virtual calls. 2015-04-02 00:23:30 +00:00
CGVTables.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGValue.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CMakeLists.txt Revert "Wrap clang module files in a Mach-O, ELF, or COFF container." 2015-02-25 02:44:04 +00:00
CodeGenABITypes.cpp Implement the __builtin_call_with_static_chain GNU extension. 2014-12-12 23:41:25 +00:00
CodeGenAction.cpp Add InlineAsmDiagnosticHandler for bitcode input 2015-02-12 02:06:55 +00:00
CodeGenFunction.cpp C++14: Disable sized deallocation by default due to ABI breakage 2015-03-20 00:31:07 +00:00
CodeGenFunction.h [SystemZ] Support transactional execution on zEC12 2015-04-01 12:54:25 +00:00
CodeGenModule.cpp DebugInfo: Use new LLVM API for DebugLoc 2015-03-30 20:01:41 +00:00
CodeGenModule.h [MS ABI] Rework .xdata HandlerType emission 2015-03-29 21:55:10 +00:00
CodeGenPGO.cpp InstrProf: Make profile variables private to reduce binary size overhead 2015-03-20 06:34:38 +00:00
CodeGenPGO.h InstrProf: Use LLVM's -instrprof pass for profiling 2014-12-08 19:04:51 +00:00
CodeGenTBAA.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CodeGenTBAA.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CodeGenTypes.cpp Use nullptr to silence -Wsentinel when self-hosting on Windows 2014-12-01 22:02:27 +00:00
CodeGenTypes.h MS ABI: Generate default constructor closures 2015-03-13 22:36:55 +00:00
CoverageMappingGen.cpp InstrProf: Handle whitespace and comments at the ends of macros 2015-03-25 04:13:49 +00:00
CoverageMappingGen.h [cleanup] Re-sort *all* #include lines with llvm/utils/sort_includes.py 2015-01-14 11:29:14 +00:00
EHScopeStack.h Disambiguate call for GCC. 2015-03-12 23:46:55 +00:00
ItaniumCXXABI.cpp Implement CFI type checks for non-virtual calls. 2015-04-02 00:23:30 +00:00
Makefile
MicrosoftCXXABI.cpp [MS ABI] Rework .xdata HandlerType emission 2015-03-29 21:55:10 +00:00
ModuleBuilder.cpp Wrap to 80 columns. No behavior change. 2015-01-17 02:27:54 +00:00
README.txt
SanitizerMetadata.cpp IR: Update clang for Metadata/Value split in r223802 2014-12-09 18:39:32 +00:00
SanitizerMetadata.h Removing LLVM_DELETED_FUNCTION, as MSVC 2012 was the last reason for requiring the macro. NFC; Clang edition. 2015-02-15 22:54:08 +00:00
TargetInfo.cpp [SystemZ] Fix some ABI corner cases 2015-03-30 13:49:01 +00:00
TargetInfo.h Under duress, move check for target support of __builtin_setjmp/ 2015-03-11 23:46:32 +00:00

README.txt

IRgen optimization opportunities.

//===---------------------------------------------------------------------===//

The common pattern of
--
short x; // or char, etc
(x == 10)
--
generates an zext/sext of x which can easily be avoided.

//===---------------------------------------------------------------------===//

Bitfields accesses can be shifted to simplify masking and sign
extension. For example, if the bitfield width is 8 and it is
appropriately aligned then is is a lot shorter to just load the char
directly.

//===---------------------------------------------------------------------===//

It may be worth avoiding creation of alloca's for formal arguments
for the common situation where the argument is never written to or has
its address taken. The idea would be to begin generating code by using
the argument directly and if its address is taken or it is stored to
then generate the alloca and patch up the existing code.

In theory, the same optimization could be a win for block local
variables as long as the declaration dominates all statements in the
block.

NOTE: The main case we care about this for is for -O0 -g compile time
performance, and in that scenario we will need to emit the alloca
anyway currently to emit proper debug info. So this is blocked by
being able to emit debug information which refers to an LLVM
temporary, not an alloca.

//===---------------------------------------------------------------------===//

We should try and avoid generating basic blocks which only contain
jumps. At -O0, this penalizes us all the way from IRgen (malloc &
instruction overhead), all the way down through code generation and
assembly time.

On 176.gcc:expr.ll, it looks like over 12% of basic blocks are just
direct branches!

//===---------------------------------------------------------------------===//