Fixing branches via the indirection block.

Also disabling the local indirection optimization until it's implemented.
This commit is contained in:
Ben Vanik 2013-05-26 03:59:32 -07:00
parent 22f186d713
commit 5d83465ce4
1 changed files with 10 additions and 2 deletions

View File

@ -914,19 +914,24 @@ int X64Emitter::GenerateIndirectionBranch(uint32_t cia, GpVar& target,
if ((internal_indirection_block_.getId() != kInvalidValue || if ((internal_indirection_block_.getId() != kInvalidValue ||
external_indirection_block_.getId() != kInvalidValue) && external_indirection_block_.getId() != kInvalidValue) &&
(locals_.indirection_cia.getId() == kInvalidValue)) { (locals_.indirection_cia.getId() == kInvalidValue)) {
locals_.indirection_target = c.newGpVar(); locals_.indirection_target =
locals_.indirection_cia = c.newGpVar(); c.newGpVar(kX86VarTypeGpq, "indirection_target");
locals_.indirection_cia =
c.newGpVar(kX86VarTypeGpq, "indirection_cia");
} }
// Check to see if the target address is within the function. // Check to see if the target address is within the function.
// If it is jump to that basic block. If the basic block is not found it means // If it is jump to that basic block. If the basic block is not found it means
// we have a jump inside the function that wasn't identified via static // we have a jump inside the function that wasn't identified via static
// analysis. These are bad as they require function regeneration. // analysis. These are bad as they require function regeneration.
#if 0
if (likely_local) { if (likely_local) {
// Note that we only support LK=0, as we are using shared tables. // Note that we only support LK=0, as we are using shared tables.
XEASSERT(!lk); XEASSERT(!lk);
c.mov(locals_.indirection_target, target); c.mov(locals_.indirection_target, target);
c.save(locals_.indirection_target);
c.mov(locals_.indirection_cia, imm(cia)); c.mov(locals_.indirection_cia, imm(cia));
c.save(locals_.indirection_cia);
// if (target >= start && target < end) jmp internal_indirection_block; // if (target >= start && target < end) jmp internal_indirection_block;
// else jmp external_indirection_block; // else jmp external_indirection_block;
GpVar in_range(c.newGpVar()); GpVar in_range(c.newGpVar());
@ -938,13 +943,16 @@ int X64Emitter::GenerateIndirectionBranch(uint32_t cia, GpVar& target,
c.jmp(internal_indirection_block_); c.jmp(internal_indirection_block_);
return 0; return 0;
} }
#endif
// If we are LK=0 jump to the shared indirection block. This prevents us // If we are LK=0 jump to the shared indirection block. This prevents us
// from needing to fill the registers again after the call and shares more // from needing to fill the registers again after the call and shares more
// code. // code.
if (!lk) { if (!lk) {
c.mov(locals_.indirection_target, target); c.mov(locals_.indirection_target, target);
c.save(locals_.indirection_target);
c.mov(locals_.indirection_cia, imm(cia)); c.mov(locals_.indirection_cia, imm(cia));
c.save(locals_.indirection_cia);
c.jmp(external_indirection_block_); c.jmp(external_indirection_block_);
} else { } else {
// Slowest path - spill, call the external function, and fill. // Slowest path - spill, call the external function, and fill.