mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-22 10:33:23 +00:00
70b0751080
Introduce the ``llvm.instrprof_increment`` intrinsic and the ``-instrprof`` pass. These provide the infrastructure for writing counters for profiling, as in clang's ``-fprofile-instr-generate``. The implementation of the instrprof pass is ported directly out of the CodeGenPGO classes in clang, and with the followup in clang that rips that code out to use these new intrinsics this ends up being NFC. Doing the instrumentation this way opens some doors in terms of improving the counter performance. For example, this will make it simple to experiment with alternate lowering strategies, and allows us to try handling profiling specially in some optimizations if we want to. Finally, this drastically simplifies the frontend and puts all of the lowering logic in one place. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@223672 91177308-0d34-0410-b5e6-96231b3b80d8
17 lines
566 B
LLVM
17 lines
566 B
LLVM
;; Check that we don't emit the runtime hooks if the user provided them.
|
|
|
|
; RUN: opt < %s -instrprof -S | FileCheck %s
|
|
; CHECK-NOT: define {{.*}} @__llvm_profile_runtime_user()
|
|
; CHECK-NOT: load i32* @__llvm_profile_runtime
|
|
|
|
@__llvm_profile_runtime = global i32 0, align 4
|
|
|
|
@__llvm_profile_name_foo = hidden constant [3 x i8] c"foo"
|
|
|
|
define void @foo() {
|
|
call void @llvm.instrprof.increment(i8* getelementptr inbounds ([3 x i8]* @__llvm_profile_name_foo, i32 0, i32 0), i64 0, i32 1, i32 0)
|
|
ret void
|
|
}
|
|
|
|
declare void @llvm.instrprof.increment(i8*, i64, i32, i32)
|