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
|
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
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
|
@ -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,
|
||||||
|
@ -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));
|
||||||
|
Loading…
Reference in New Issue
Block a user