[X86] Optimize stackmap shadows on X86.
authorLang Hames <lhames@gmail.com>
Thu, 24 Jul 2014 20:40:55 +0000 (20:40 +0000)
committerLang Hames <lhames@gmail.com>
Thu, 24 Jul 2014 20:40:55 +0000 (20:40 +0000)
commitf49bc3f1b19c24e4957bd3bc2dc08218f4707c55
tree29cb46995b0d6d1ccbbd9f3f39b492f5b982fcce
parent9a412d13c14ec27bb99354bebf9a71f74bde2330
[X86] Optimize stackmap shadows on X86.

This patch minimizes the number of nops that must be emitted on X86 to satisfy
stackmap shadow constraints.

To minimize the number of nops inserted, the X86AsmPrinter now records the
size of the most recent stackmap's shadow in the StackMapShadowTracker class,
and tracks the number of instruction bytes emitted since the that stackmap
instruction was encountered. Padding is emitted (if it is required at all)
immediately before the next stackmap/patchpoint instruction, or at the end of
the basic block.

This optimization should reduce code-size and improve performance for people
using the llvm stackmap intrinsic on X86.

<rdar://problem/14959522>

llvm-svn: 213892
llvm/include/llvm/CodeGen/AsmPrinter.h
llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
llvm/lib/Target/X86/X86AsmPrinter.cpp
llvm/lib/Target/X86/X86AsmPrinter.h
llvm/lib/Target/X86/X86MCInstLower.cpp
llvm/test/CodeGen/X86/stackmap-nops.ll
llvm/test/CodeGen/X86/stackmap-shadow-optimization.ll [new file with mode: 0644]
llvm/test/MC/X86/stackmap-nops.ll