x86emitter: Remove unused classes

xAddressInfo was not being used
xSmartJump was not being used and is incompatible with x86-64
This commit is contained in:
Tellow Krinkle 2020-07-16 03:33:42 -05:00 committed by tellowkrinkle
parent 096bb8bf74
commit 1a727febe9
2 changed files with 0 additions and 254 deletions

View File

@ -545,30 +545,6 @@ struct xRegisterEmpty
}
};
// FIXME This one is likely useless and superseeded by the future xRegister16or32or64
class xRegister16or32
{
protected:
const xRegisterInt &m_convtype;
public:
xRegister16or32(const xRegister32 &src)
: m_convtype(src)
{
}
xRegister16or32(const xRegister16 &src)
: m_convtype(src)
{
}
operator const xRegisterBase &() const { return m_convtype; }
const xRegisterInt *operator->() const
{
return &m_convtype;
}
};
class xRegister16or32or64
{
protected:
@ -720,73 +696,6 @@ public:
__fi void operator-=(sptr imm) { Add(-imm); }
};
// --------------------------------------------------------------------------------------
// xAddressInfo
// --------------------------------------------------------------------------------------
template <typename BaseType>
class xAddressInfo : public xAddressVoid
{
typedef xAddressVoid _parent;
public:
xAddressInfo(const xAddressReg &base, const xAddressReg &index, int factor = 1, sptr displacement = 0)
: _parent(base, index, factor, displacement)
{
}
/*xAddressInfo( const xAddressVoid& src )
: _parent( src ) {}*/
explicit xAddressInfo(const xAddressReg &index, sptr displacement = 0)
: _parent(index, displacement)
{
}
explicit xAddressInfo(sptr displacement = 0)
: _parent(displacement)
{
}
static xAddressInfo<BaseType> FromIndexReg(const xAddressReg &index, int scale = 0, sptr displacement = 0);
public:
using _parent::operator+=;
using _parent::operator-=;
bool IsByteSizeDisp() const { return is_s8(Displacement); }
xAddressInfo<BaseType> &Add(sptr imm)
{
Displacement += imm;
return *this;
}
xAddressInfo<BaseType> &Add(const xAddressReg &src)
{
_parent::Add(src);
return *this;
}
xAddressInfo<BaseType> &Add(const xAddressInfo<BaseType> &src)
{
_parent::Add(src);
return *this;
}
__fi xAddressInfo<BaseType> operator+(const xAddressReg &right) const { return xAddressInfo(*this).Add(right); }
__fi xAddressInfo<BaseType> operator+(const xAddressInfo<BaseType> &right) const { return xAddressInfo(*this).Add(right); }
__fi xAddressInfo<BaseType> operator+(sptr imm) const { return xAddressInfo(*this).Add(imm); }
__fi xAddressInfo<BaseType> operator-(sptr imm) const { return xAddressInfo(*this).Add(-imm); }
__fi xAddressInfo<BaseType> operator+(const void *addr) const { return xAddressInfo(*this).Add((uptr)addr); }
__fi void operator+=(const xAddressInfo<BaseType> &right) { Add(right); }
};
typedef xAddressInfo<u128> xAddress128;
typedef xAddressInfo<u64> xAddress64;
typedef xAddressInfo<u32> xAddress32;
typedef xAddressInfo<u16> xAddress16;
typedef xAddressInfo<u8> xAddress8;
static __fi xAddressVoid operator+(const void *addr, const xAddressVoid &right)
{
return right + addr;
@ -797,19 +706,6 @@ static __fi xAddressVoid operator+(sptr addr, const xAddressVoid &right)
return right + addr;
}
template <typename OperandType>
static __fi xAddressInfo<OperandType> operator+(const void *addr, const xAddressInfo<OperandType> &right)
{
//return xAddressInfo<OperandType>( (sptr)addr ).Add( reg );
return right + addr;
}
template <typename OperandType>
static __fi xAddressInfo<OperandType> operator+(sptr addr, const xAddressInfo<OperandType> &right)
{
return right + addr;
}
// --------------------------------------------------------------------------------------
// xImmReg< typename xRegType >
// --------------------------------------------------------------------------------------
@ -902,11 +798,6 @@ public:
{
_operandSize = sizeof(OperandType);
}
explicit xIndirect(const xAddressInfo<OperandType> &src)
: _parent(src)
{
_operandSize = sizeof(OperandType);
}
xIndirect(xAddressReg base, xAddressReg index, int scale = 0, sptr displacement = 0)
: _parent(base, index, scale, displacement)
{
@ -1018,122 +909,6 @@ extern const xAddressIndexer<xIndirect32> ptr32;
extern const xAddressIndexer<xIndirect16> ptr16;
extern const xAddressIndexer<xIndirect8> ptr8;
// --------------------------------------------------------------------------------------
// xDirectOrIndirect
// --------------------------------------------------------------------------------------
// This utility class can represent either a direct (register) or indirect (memory address)
// source or destination operand. When supplied to an emitted instruction, the direct form
// is favored *if* it is not Empty (xEmptyReg). Otherwise the indirect form is used.
//
#if 0
template< typename xRegType, typename xSibType >
class xDirectOrIndirect
{
xRegType m_RegDirect;
xSibType m_MemIndirect;
public:
xDirectOrIndirect() :
m_RegDirect(), m_MemIndirect( 0 ) {}
xDirectOrIndirect( const xRegType& srcreg ) :
m_RegDirect( srcreg ), m_MemIndirect( 0 ) {}
explicit xDirectOrIndirect( const xSibType& srcmem ) :
m_RegDirect(), m_MemIndirect( srcmem ) {}
const xRegType& GetReg() const { return m_RegDirect; }
const xSibType& GetMem() const { return m_MemIndirect; }
bool IsDirect() const { return !m_RegDirect.IsEmpty(); }
bool IsIndirect() const { return m_RegDirect.IsEmpty(); }
bool operator==( const xDirectOrIndirect& src ) const
{
return IsDirect() ?
(m_RegDirect == src.m_RegDirect) :
(m_MemIndirect == src.m_MemIndirect);
}
bool operator!=( const xDirectOrIndirect& src ) const
{
return !operator==( src );
}
bool operator==( const xRegType& src ) const { return (m_RegDirect == src); }
bool operator!=( const xRegType& src ) const { return (m_RegDirect != src); }
};
typedef xDirectOrIndirect<xRegister8,xIndirect8> xDirectOrIndirect8;
typedef xDirectOrIndirect<xRegister16,xIndirect16> xDirectOrIndirect16;
typedef xDirectOrIndirect<xRegister32,xIndirect32> xDirectOrIndirect32;
typedef xDirectOrIndirect<xRegisterSSE,xIndirect128> xDirectOrIndirect128;
#endif
// --------------------------------------------------------------------------------------
// xSmartJump
// --------------------------------------------------------------------------------------
// This class provides an interface for generating forward-based j8's or j32's "smartly"
// as per the measured displacement distance. If the displacement is a valid s8, then
// a j8 is inserted, else a j32.
//
// Note: This class is inherently unsafe, and so it's recommended to use xForwardJump8/32
// whenever it is known that the jump destination is (or is not) short. Only use
// xSmartJump in cases where it's unknown what jump encoding will be ideal.
//
// Important: Use this tool with caution! xSmartJump cannot be used in cases where jump
// targets overlap, since the writeback of the second target will alter the position of
// the first target (which breaks the relative addressing). To assist in avoiding such
// errors, xSmartJump works based on C++ block scope, where the destruction of the
// xSmartJump object (invoked by a '}') signals the target of the jump. Example:
//
// {
// iCMP( EAX, ECX );
// xSmartJump jumpTo( Jcc_Above );
// [... conditional code ...]
// } // smartjump targets this spot.
//
// No code inside the scope can attempt to jump outside the scoped block (unless the jump
// uses an immediate addressing method, such as Register or Mod/RM forms of JMP/CALL).
// Multiple SmartJumps can be safely nested inside scopes, as long as they are properly
// scoped themselves.
//
// Performance Analysis: j8's use 4 less byes per opcode, and thus can provide minor
// speed benefits in the form of L1/L2 cache clutter, on any CPU. They're also notably
// faster on P4's, and mildly faster on AMDs. (Core2's and i7's don't care)
//
class xSmartJump
{
DeclareNoncopyableObject(xSmartJump);
protected:
u8 *m_baseptr; // base address of the instruction (passed to the instruction emitter)
JccComparisonType m_cc; // comparison type of the instruction
public:
int GetMaxInstructionSize() const
{
pxAssert(m_cc != Jcc_Unknown);
return (m_cc == Jcc_Unconditional) ? 5 : 6;
}
JccComparisonType GetCondition() const { return m_cc; }
virtual ~xSmartJump();
// ------------------------------------------------------------------------
// ccType - Comparison type to be written back to the jump instruction position.
//
xSmartJump(JccComparisonType ccType)
{
pxAssert(ccType != Jcc_Unknown);
m_baseptr = xGetPtr();
m_cc = ccType;
xAdvancePtr(GetMaxInstructionSize());
}
protected:
void SetTarget();
};
// --------------------------------------------------------------------------------------
// xForwardJump
// --------------------------------------------------------------------------------------

View File

@ -128,35 +128,6 @@ void xImpl_FastCall::operator()(const xIndirectNative &f, const xRegisterLong &a
const xImpl_FastCall xFastCall = {};
void xSmartJump::SetTarget()
{
u8 *target = xGetPtr();
if (m_baseptr == NULL)
return;
xSetPtr(m_baseptr);
u8 *const saveme = m_baseptr + GetMaxInstructionSize();
xJccKnownTarget(m_cc, target, true);
// Copy recompiled data inward if the jump instruction didn't fill the
// alloted buffer (means that we optimized things to a j8!)
const int spacer = (sptr)saveme - (sptr)xGetPtr();
if (spacer != 0) {
u8 *destpos = xGetPtr();
const int copylen = (sptr)target - (sptr)saveme;
memcpy(destpos, saveme, copylen);
xSetPtr(target - spacer);
}
}
xSmartJump::~xSmartJump()
{
SetTarget();
m_baseptr = NULL; // just in case (sometimes helps in debugging too)
}
// ------------------------------------------------------------------------
// Emits a 32 bit jump, and returns a pointer to the 32 bit displacement.
// (displacements should be assigned relative to the end of the jump instruction,