Considérons la fonction simple:Clang ajoute attribut non enligne à toutes les fonctions lors de l'émission LLVM IR
int foo() { return 42; }
Compiler ce à LLVM via clang -emit-llvm -S foo.cpp
produit le module suivant:
; ModuleID = 'foo.cpp'
source_filename = "foo.cpp"
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-apple-macosx10.13.0"
; Function Attrs: noinline nounwind ssp uwtable
define i32 @_Z3foov() #0 {
ret i32 42
}
attributes #0 = { noinline nounwind ssp uwtable "correctly-rounded-divide-sqrt-fp-math"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="penryn" "target-features"="+cx16,+fxsr,+mmx,+sse,+sse2,+sse3,+sse4.1,+ssse3,+x87" "unsafe-fp-math"="false" "use-soft-float"="false" }
!llvm.module.flags = !{!0}
!llvm.ident = !{!1}
!0 = !{i32 1, !"PIC Level", i32 2}
!1 = !{!"Apple LLVM version 9.0.0 (clang-900.0.37)"}
Pourquoi la fonction foo
déclaré comme noinline
? L'indicateur n'est pas ajouté si un niveau d'optimisation (autre que -O0
) est spécifié, mais je souhaite éviter cela.
Existe-t-il un autre moyen/drapeau?
me semble logique que, pour une construction unoptimized (qui doit être debugable), les fonctions ne sont pas inline. Pourquoi le voulez-vous autrement? –
Je veux modifier/analyser plus loin avec un outil externe (et donc besoin d'être non optimisé), mais je veux pouvoir passer le module modifié à 'opt' plus tard et l'avoir ensuite optimisé ... – jfrohnhofen