mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-24 04:09:45 +00:00
Add a new 'hotpatch' attribute. This attribute will insert a two-byte no-op
instruction at the beginning of each function that has the attribute, allowing the function to be easily hooked and/or patched. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117264 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d8c5ec6aec
commit
970bfcc7d8
@ -1131,6 +1131,11 @@ define void @f() optsize { ... }
|
||||
function into callers whenever possible, ignoring any active inlining size
|
||||
threshold for this caller.</dd>
|
||||
|
||||
<dt><tt><b>hotpatch</b></tt></dt>
|
||||
<dd>This attribute indicates that the prologue should contain a 'hotpatch'
|
||||
sequence at the beginning. This is the same sequence used in the
|
||||
system DLLs in Microsoft Windows XP Service Pack 2 and higher.</dd>
|
||||
|
||||
<dt><tt><b>inlinehint</b></tt></dt>
|
||||
<dd>This attribute indicates that the source code contained a hint that inlining
|
||||
this function is desirable (such as the "inline" keyword in C/C++). It
|
||||
|
@ -65,6 +65,8 @@ const Attributes StackAlignment = 7<<26; ///< Alignment of stack for
|
||||
///of alignment with +1 bias
|
||||
///0 means unaligned (different from
|
||||
///alignstack(1))
|
||||
const Attributes Hotpatch = 1<<29; ///< Function should have special
|
||||
///'hotpatch' sequence in prologue
|
||||
|
||||
/// @brief Attributes that only apply to function parameters.
|
||||
const Attributes ParameterOnly = ByVal | Nest | StructRet | NoCapture;
|
||||
@ -73,7 +75,8 @@ const Attributes ParameterOnly = ByVal | Nest | StructRet | NoCapture;
|
||||
/// be used on return values or function parameters.
|
||||
const Attributes FunctionOnly = NoReturn | NoUnwind | ReadNone | ReadOnly |
|
||||
NoInline | AlwaysInline | OptimizeForSize | StackProtect | StackProtectReq |
|
||||
NoRedZone | NoImplicitFloat | Naked | InlineHint | StackAlignment;
|
||||
NoRedZone | NoImplicitFloat | Naked | InlineHint | StackAlignment |
|
||||
Hotpatch;
|
||||
|
||||
/// @brief Parameter attributes that do not apply to vararg call arguments.
|
||||
const Attributes VarArgsIncompatible = StructRet;
|
||||
|
@ -573,6 +573,7 @@ lltok::Kind LLLexer::LexIdentifier() {
|
||||
KEYWORD(noredzone);
|
||||
KEYWORD(noimplicitfloat);
|
||||
KEYWORD(naked);
|
||||
KEYWORD(hotpatch);
|
||||
|
||||
KEYWORD(type);
|
||||
KEYWORD(opaque);
|
||||
|
@ -982,6 +982,7 @@ bool LLParser::ParseOptionalAttrs(unsigned &Attrs, unsigned AttrKind) {
|
||||
case lltok::kw_noredzone: Attrs |= Attribute::NoRedZone; break;
|
||||
case lltok::kw_noimplicitfloat: Attrs |= Attribute::NoImplicitFloat; break;
|
||||
case lltok::kw_naked: Attrs |= Attribute::Naked; break;
|
||||
case lltok::kw_hotpatch: Attrs |= Attribute::Hotpatch; break;
|
||||
|
||||
case lltok::kw_alignstack: {
|
||||
unsigned Alignment;
|
||||
|
@ -96,6 +96,7 @@ namespace lltok {
|
||||
kw_noredzone,
|
||||
kw_noimplicitfloat,
|
||||
kw_naked,
|
||||
kw_hotpatch,
|
||||
|
||||
kw_type,
|
||||
kw_opaque,
|
||||
|
@ -70,6 +70,8 @@ std::string Attribute::getAsString(Attributes Attrs) {
|
||||
Result += "noimplicitfloat ";
|
||||
if (Attrs & Attribute::Naked)
|
||||
Result += "naked ";
|
||||
if (Attrs & Attribute::Hotpatch)
|
||||
Result += "hotpatch ";
|
||||
if (Attrs & Attribute::StackAlignment) {
|
||||
Result += "alignstack(";
|
||||
Result += utostr(Attribute::getStackAlignmentFromAttrs(Attrs));
|
||||
|
Loading…
Reference in New Issue
Block a user