[all-commits] [llvm/llvm-project] 4275eb: Re-land [Codegen/Statepoint] Allow usage of regist...
serguei-katkov via All-commits
all-commits at lists.llvm.org
Thu Apr 9 20:14:08 PDT 2020
Branch: refs/heads/master
Home: https://github.com/llvm/llvm-project
Commit: 4275eb13315fbc59b8976667b774de2a1510fc36
https://github.com/llvm/llvm-project/commit/4275eb13315fbc59b8976667b774de2a1510fc36
Author: Serguei Katkov <serguei.katkov at azul.com>
Date: 2020-04-10 (Fri, 10 Apr 2020)
Changed paths:
M llvm/include/llvm/CodeGen/Passes.h
M llvm/include/llvm/InitializePasses.h
M llvm/lib/CodeGen/CMakeLists.txt
M llvm/lib/CodeGen/CodeGen.cpp
A llvm/lib/CodeGen/FixupStatepointCallerSaved.cpp
M llvm/lib/CodeGen/SelectionDAG/StatepointLowering.cpp
M llvm/lib/CodeGen/TargetPassConfig.cpp
M llvm/test/CodeGen/AArch64/O0-pipeline.ll
M llvm/test/CodeGen/AArch64/O3-pipeline.ll
M llvm/test/CodeGen/ARM/O3-pipeline.ll
M llvm/test/CodeGen/X86/O0-pipeline.ll
M llvm/test/CodeGen/X86/O3-pipeline.ll
A llvm/test/CodeGen/X86/statepoint-regs.ll
Log Message:
-----------
Re-land [Codegen/Statepoint] Allow usage of registers for non gc deopt values.
The change introduces the usage of physical registers for non-gc deopt values.
This require runtime support to know how to take a value from register.
By default usage is off and can be switched on by option.
The change also introduces additional fix-up patch which forces the spilling
of caller saved registers (clobbered after the call) and re-writes statepoint
to use spill slots instead of caller saved registers.
Reviewers: reames, danstrushin
Reviewed By: dantrushin
Subscribers: mgorny, hiraditya, mgrang, llvm-commits
Differential Revision: https://reviews.llvm.org/D77797
More information about the All-commits
mailing list