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:
Charles Davis 2010-10-25 15:37:09 +00:00
parent d8c5ec6aec
commit 970bfcc7d8
6 changed files with 14 additions and 1 deletions

View File

@ -1131,6 +1131,11 @@ define void @f() optsize { ... }
function into callers whenever possible, ignoring any active inlining size function into callers whenever possible, ignoring any active inlining size
threshold for this caller.</dd> 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> <dt><tt><b>inlinehint</b></tt></dt>
<dd>This attribute indicates that the source code contained a hint that inlining <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 this function is desirable (such as the "inline" keyword in C/C++). It

View File

@ -65,6 +65,8 @@ const Attributes StackAlignment = 7<<26; ///< Alignment of stack for
///of alignment with +1 bias ///of alignment with +1 bias
///0 means unaligned (different from ///0 means unaligned (different from
///alignstack(1)) ///alignstack(1))
const Attributes Hotpatch = 1<<29; ///< Function should have special
///'hotpatch' sequence in prologue
/// @brief Attributes that only apply to function parameters. /// @brief Attributes that only apply to function parameters.
const Attributes ParameterOnly = ByVal | Nest | StructRet | NoCapture; 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. /// be used on return values or function parameters.
const Attributes FunctionOnly = NoReturn | NoUnwind | ReadNone | ReadOnly | const Attributes FunctionOnly = NoReturn | NoUnwind | ReadNone | ReadOnly |
NoInline | AlwaysInline | OptimizeForSize | StackProtect | StackProtectReq | 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. /// @brief Parameter attributes that do not apply to vararg call arguments.
const Attributes VarArgsIncompatible = StructRet; const Attributes VarArgsIncompatible = StructRet;

View File

@ -573,6 +573,7 @@ lltok::Kind LLLexer::LexIdentifier() {
KEYWORD(noredzone); KEYWORD(noredzone);
KEYWORD(noimplicitfloat); KEYWORD(noimplicitfloat);
KEYWORD(naked); KEYWORD(naked);
KEYWORD(hotpatch);
KEYWORD(type); KEYWORD(type);
KEYWORD(opaque); KEYWORD(opaque);

View File

@ -982,6 +982,7 @@ bool LLParser::ParseOptionalAttrs(unsigned &Attrs, unsigned AttrKind) {
case lltok::kw_noredzone: Attrs |= Attribute::NoRedZone; break; case lltok::kw_noredzone: Attrs |= Attribute::NoRedZone; break;
case lltok::kw_noimplicitfloat: Attrs |= Attribute::NoImplicitFloat; break; case lltok::kw_noimplicitfloat: Attrs |= Attribute::NoImplicitFloat; break;
case lltok::kw_naked: Attrs |= Attribute::Naked; break; case lltok::kw_naked: Attrs |= Attribute::Naked; break;
case lltok::kw_hotpatch: Attrs |= Attribute::Hotpatch; break;
case lltok::kw_alignstack: { case lltok::kw_alignstack: {
unsigned Alignment; unsigned Alignment;

View File

@ -96,6 +96,7 @@ namespace lltok {
kw_noredzone, kw_noredzone,
kw_noimplicitfloat, kw_noimplicitfloat,
kw_naked, kw_naked,
kw_hotpatch,
kw_type, kw_type,
kw_opaque, kw_opaque,

View File

@ -70,6 +70,8 @@ std::string Attribute::getAsString(Attributes Attrs) {
Result += "noimplicitfloat "; Result += "noimplicitfloat ";
if (Attrs & Attribute::Naked) if (Attrs & Attribute::Naked)
Result += "naked "; Result += "naked ";
if (Attrs & Attribute::Hotpatch)
Result += "hotpatch ";
if (Attrs & Attribute::StackAlignment) { if (Attrs & Attribute::StackAlignment) {
Result += "alignstack("; Result += "alignstack(";
Result += utostr(Attribute::getStackAlignmentFromAttrs(Attrs)); Result += utostr(Attribute::getStackAlignmentFromAttrs(Attrs));