|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This removes the RegionCounter class, which is only used as a helper
in teh ComputeRegionCounts stmt visitor. This class is just an extra
layer of abstraction that makes the code harder to follow at this
point, and removing it makes the logic quite a bit more direct.
llvm-svn: 236364 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | We were assigning the counter for the body of the loop to the loop
variable initialization for some reason here, but our tests completely
lacked coverage for range-for loops. This fixes that and makes the
logic generally more similar to the logic for a regular for.
llvm-svn: 236277 | 
| | 
| 
| 
| 
| 
| 
| | We weren't setting regions as being unreachable after C++ throw
expressions, leading to incorrect count propagations.
llvm-svn: 235967 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The RegionCounter type does a lot of legwork, but most of it is only
meaningful within the implementation of CodeGenPGO. The uses elsewhere
in CodeGen generally just want to increment or read counters, so do
that directly.
llvm-svn: 235664 | 
| | 
| 
| 
| 
| 
| 
| 
| | We try to use the member variable "FuncName" here, but we've also used
that name as a parameter. This ends with us getting the length of the
function name wrong when we generate the coverage data.
llvm-svn: 235565 | 
| | 
| 
| 
| | llvm-svn: 234750 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | When we instrument a program for profiling, we copy the linkage of an
instrumented function so that our datastructures merge in the same way
as the function. This avoids redundant copies for things like
linkonce, but ends up emitting names we never need to reference for
normal and internal symbols. Promoting internal and external linkage
to private for these variables reduces the size overhead of profiling
drastically.
llvm-svn: 232799 | 
| | 
| 
| 
| 
| 
| 
| 
| | Somehow this file ended up with a strange hybrid of the old "indent
inside a namespace" style and the new "don't", giving us a wonderful
two-space indent starting halfway through a namespace. Fix it.
llvm-svn: 230244 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | We don't emit any coverage mapping for uncovered functions that come
from system headers, but we were creating a GlobalVariable with each
of their names. This is wasteful since the linker will need to dead
strip the unused symbols, and it can lead to issues when merging
coverage with others TUs that do have coverage for those functions.
llvm-svn: 226764 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | We were previously emitting counter increments even if we didn't have
an insertion point, which would result in a CallInst with no
parent. This leads to a crash, as in pr22166, if we try to do
GlobalDCE.
llvm-svn: 225495 | 
| | 
| 
| 
| 
| 
| 
| 
| | The logic for lowering profiling counters has been moved to an LLVM
pass. Emit the intrinsics rather than duplicating the whole pass in
clang.
llvm-svn: 223683 | 
| | 
| 
| 
| 
| 
| 
| 
| | There's no need to use different names for the local variables than we
use in the profile itself, and it's a bit simpler and easier to debug
if we're consistent.
llvm-svn: 223173 | 
| | 
| 
| 
| 
| 
| 
| 
| | It doesn't make much sense to have std::unique_ptrs of std::string and
std::vector. Avoid some useless indirection by using these types
directly.
llvm-svn: 223166 | 
| | 
| 
| 
| 
| 
| 
| 
| | Reapplying now that r218887 is in.
This reverts commit r218882, reapplying r218880.
llvm-svn: 218888 | 
| | 
| 
| 
| 
| 
| 
| 
| | r218879 has been reverted for now, this needs to go to match.
This reverts commit r218880.
llvm-svn: 218882 | 
| | 
| 
| 
| | llvm-svn: 218880 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The profile data format was recently updated and the new indexing api
requires the code coverage tool to know the function's hash as well
as the function's name to get the execution counts for a function.
Differential Revision: http://reviews.llvm.org/D4995
llvm-svn: 216208 | 
| | 
| 
| 
| 
| 
| | use microsoft's ABI
llvm-svn: 215371 | 
| | 
| 
| 
| | llvm-svn: 215365 | 
| | 
| 
| 
| 
| 
| | Differential Revision: http://reviews.llvm.org/D4799
llvm-svn: 215258 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch adds the '-fcoverage-mapping' option which
allows clang to generate the coverage mapping information
that can be used to provide code coverage analysis using
the execution counts obtained from the instrumentation 
based profiling (-fprofile-instr-generate).
llvm-svn: 214752 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We've added support for a multiple functions with the same name in
LLVM's profile data, so the lookup returning the function hash it
found doesn't make sense anymore. Update to pass in the hash we
expect.
This also adds a test that the version 1 format is still readable,
since the new API is expected to handle that.
llvm-svn: 214586 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Improve the warning when building with -fprofile-instr-use and a file
appears not to have been profiled at all. This keys on whether a
function is defined in the main file or not to avoid false negatives
when one includes a header with functions that have been profiled.
llvm-svn: 211760 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Shared objects are fairly broken for InstrProf right now -- a follow-up
commit in compiler-rt will fix the rest of this.
The main problem here is that at link time, profile data symbols in the
shared object might get used instead of symbols from the main
executable, creating invalid profile data sections.
<rdar://problem/16918688>
llvm-svn: 208939 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | We don't assign counters for implicit Decls, but we were emitting code
to increment the (non-existent) counters and adding empty counter
lists in the output. This fixes the checks in assignRegionCounters and
emitInstrumentationData to do the right thing, and adds an assert for
the pathological case of emitting zero counters.
llvm-svn: 207203 | 
| | 
| 
| 
| | llvm-svn: 206667 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Update clang to use the InstrProfReader from LLVM to read
instrumentation based profile data. This also switches us from the
naive text format to the binary format, since that's what's
implemented in the reader.
llvm-svn: 206658 | 
| | 
| 
| 
| | llvm-svn: 206657 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The function hash should change when control flow changes.  This patch
hashes the type of each AST node that affects counters, rather than just
counting how many there are.  These types are combined into a small
enumerator that currently has 16 values.
The new hash algorithm packs the enums for consecutively visited types
into a `uint64_t`.  In order to save space for new types, the types are
assumed to be 6-bit values (instead of 4-bit).  In order to minimize
overhead for functions with little control flow, the `uint64_t` is used
directly as a hash if it never fills up; if it does, it's passed through
an MD5 context.
<rdar://problem/16435801>
llvm-svn: 206397 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This adds a warning that triggers when profile data doesn't match for
the source that's being compiled with -fprofile-instr-use=. This fires
only once per translation unit, as warning on every mismatched
function would be quite noisy.
llvm-svn: 206322 | 
| | 
| 
| 
| 
| 
| 
| | This comment also appears elsewhere where it actually makes sense, and
it's just confusing here.
llvm-svn: 206321 | 
| | 
| 
| 
| 
| 
| 
| 
| | CapturedStmt was being ignored by instrumentation based profiling, and
its counters attributed to the containing function. Instead, we need
to treat this as a top level entity, like we do with blocks.
llvm-svn: 206231 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Until now we were generating duplicate counters for lambdas: one set
in the function where the lambda was declared and another for the
lambda itself. Instead, we should skip over the bodies of lambdas in
their containing contexts.
llvm-svn: 206081 | 
| | 
| 
| 
| 
| 
| 
| | This avoids the overhead of specifying all the traversal code when using
ConstStmtVisitor and makes it a lot easier to maintain this.
llvm-svn: 206039 | 
| | 
| 
| 
| 
| 
| 
| | This treats binary conditional operators in the same way as ternary
conditional operators for instrumentation based profiling.
llvm-svn: 206021 | 
| | 
| 
| 
| 
| 
| | Responding to Richard Smith's review of r205037.
llvm-svn: 206008 | 
| | 
| 
| 
| 
| 
| 
| 
| | No functionality change.
<rdar://problem/16435801>
llvm-svn: 206002 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Fixes a bug where unsigned numbers are read using strtol and strtoll.
I don't have a testcase because this bug is effectively unobservable
right now.  To expose the problem in the hash, we would need a function
with greater than INT64_MAX counters, which we don't handle anyway.  To
expose the problem in the function count, we'd need a function with
greater than INT32_MAX counters; this is theoretically observable, but
it isn't a practical testcase to check in.
An upcoming commit changes the hash to be non-trivial, so we'll get some
coverage eventually.
<rdar://problem/16435801>
llvm-svn: 206001 | 
| | 
| 
| 
| 
| 
| 
| 
| | Emitting the PGO initialization in EmitGlobalFunctionDefinition is
inefficient, since this only has an effect once per module.  We move
this to Release() with the rest of the once-per-module logic.
llvm-svn: 205977 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | If all of our weights are zero when calculating branch weights, it
means we haven't profiled the code in question. Avoid creating a
metadata node that says all branches are equally likely in this case.
The test also checks constructs that hit the other createBranchWeights
overload. These were already working.
llvm-svn: 205606 | 
| | 
| 
| 
| 
| 
| | Responding to Justin's review of r205025.
llvm-svn: 205037 | 
| | 
| 
| 
| | llvm-svn: 205025 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | -u behaviour is apparently not portable between linkers (see cfe-commits
discussions for r204379 and r205012).  I've moved the logic to IRGen,
where it should have been in the first place.
I don't have a Linux system to test this on, so it's possible this logic
*still* doesn't pull in the instrumented profiling runtime on Linux.
I'm in the process of getting tests going on the compiler-rt side
(llvm-commits "[PATCH] InstrProf: Add initial compiler-rt test").  Once
we have tests for the full flow there, the runtime logic should get a
whole lot less brittle.
<rdar://problem/16458307>
llvm-svn: 205023 | 
| | 
| 
| 
| | llvm-svn: 204846 | 
| | 
| 
| 
| | llvm-svn: 204845 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Variables with available_externally linkage can be dropped at will.
This causes link errors, since there are still references to the
instrumentation!  linkonce_odr is almost equivalent, so use that
instead.
As a drive-by fix (I don't have an Elf system, so I'm not sure how to
write a testcase), use linkonce linkage for the instrumentation of
extern_weak functions.
<rdar://problem/15943240>
llvm-svn: 204408 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The variable is used to set the linkage for variables, and will become
different from function linkage in a follow-up commit.
<rdar://problem/15943240>
llvm-svn: 204407 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | These functions are in the profile runtime.  PGO comes later.
Unfortunately, there's only room for 16 characters in a Darwin section,
so use __llvm_prf_ instead of __llvm_profile_ for section names.
<rdar://problem/15943240>
llvm-svn: 204390 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Remove the remaining explicit static initialization from translation
units, at least on Darwin.  Instead, create a use of __llvm_pgo_runtime,
which will pull in required code from compiler-rt.
After this commit (and its pair in compiler-rt), a user can define their
own __llvm_pgo_runtime to satisfy this undefined symbol and call the
functions in compiler-rt directly.
<rdar://problem/15943240>
llvm-svn: 204379 | 
| | 
| 
| 
| | llvm-svn: 204372 |