本文整理汇总了C++中X64Assembler::code方法的典型用法代码示例。如果您正苦于以下问题:C++ X64Assembler::code方法的具体用法?C++ X64Assembler::code怎么用?C++ X64Assembler::code使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类X64Assembler
的用法示例。
在下文中一共展示了X64Assembler::code方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: emitFuncGuard
void emitFuncGuard(const Func* func, CodeBlock& cb) {
using namespace reg;
X64Assembler a { cb };
assertx(x64::abi(CodeKind::CrossTrace).gpUnreserved.contains(rax));
TCA start DEBUG_ONLY = a.frontier();
auto const funcImm = Immed64(func);
if (funcImm.fits(sz::dword)) {
emitSmashableCmpq(a.code(), funcImm.l(), rVmFp,
safe_cast<int8_t>(AROFF(m_func)));
} else {
// Although func doesn't fit in a signed 32-bit immediate, it may still fit
// in an unsigned one. Rather than deal with yet another case (which only
// happens when we disable jemalloc), just emit a smashable mov followed by
// a register cmp.
emitSmashableMovq(a.code(), uint64_t(func), rax);
a. cmpq (rax, rVmFp[AROFF(m_func)]);
}
a. jnz (mcg->tx().uniqueStubs.funcPrologueRedispatch);
assertx(funcPrologueToGuard(a.frontier(), func) == start);
assertx(funcPrologueHasGuard(a.frontier(), func));
}
示例2: emitFuncGuard
void emitFuncGuard(const Func* func, CodeBlock& cb, CGMeta& fixups) {
using namespace reg;
X64Assembler a { cb };
assertx(x64::abi(CodeKind::CrossTrace).gpUnreserved.contains(rax));
auto const funcImm = Immed64(func);
if (funcImm.fits(sz::dword)) {
emitSmashableCmpq(a.code(), fixups, funcImm.l(), rvmfp(),
safe_cast<int8_t>(AROFF(m_func)));
} else {
// Although func doesn't fit in a signed 32-bit immediate, it may still fit
// in an unsigned one. Rather than deal with yet another case (which only
// happens when we disable jemalloc), just emit a smashable mov followed by
// a register cmp.
emitSmashableMovq(a.code(), fixups, uint64_t(func), rax);
a. cmpq (rax, rvmfp()[AROFF(m_func)]);
}
a. jnz (tc::ustubs().funcPrologueRedispatch);
DEBUG_ONLY auto guard = funcGuardFromPrologue(a.frontier(), func);
assertx(funcGuardMatches(guard, func));
}
示例3: emitFuncGuard
void emitFuncGuard(const Func* func, CodeBlock& cb) {
using namespace reg;
X64Assembler a { cb };
assertx(cross_trace_abi.gpUnreserved.contains(rax));
auto const funcImm = Immed64(func);
int nbytes, offset;
if (!funcImm.fits(sz::dword)) {
nbytes = kFuncGuardSmash;
offset = kFuncGuardImm;
} else {
nbytes = kFuncGuardShortSmash;
offset = kFuncGuardShortImm;
}
mcg->backEnd().prepareForSmash(a.code(), nbytes, offset);
TCA start DEBUG_ONLY = a.frontier();
if (!funcImm.fits(sz::dword)) {
// Although func doesnt fit in a signed 32-bit immediate, it may still fit
// in an unsigned one. Rather than deal with yet another case (which only
// happens when we disable jemalloc), just force it to be an 8-byte
// immediate, and patch it up afterwards.
a. movq (0xdeadbeeffeedface, rax);
auto immptr = reinterpret_cast<uintptr_t*>(a.frontier()) - 1;
assertx(*immptr == 0xdeadbeeffeedface);
*immptr = uintptr_t(func);
a. cmpq (rax, rVmFp[AROFF(m_func)]);
} else {
a. cmpq (funcImm.l(), rVmFp[AROFF(m_func)]);
}
a. jnz (mcg->tx().uniqueStubs.funcPrologueRedispatch);
assertx(funcPrologueToGuard(a.frontier(), func) == start);
assertx(funcPrologueHasGuard(a.frontier(), func));
}
示例4: emitPops
void PhysRegSaverParity::emitPops(X64Assembler& as, RegSet regs) {
emitPops(Vauto(as.code()).main(), regs);
}
示例5: Vauto
PhysRegSaverParity::PhysRegSaverParity(int parity, X64Assembler& as,
RegSet regs)
: PhysRegSaverParity{parity, Vauto(as.code()).main(), regs} {
m_v = nullptr;
m_as = &as;
}