2009-09-08 12:08:10 +00:00
|
|
|
/* PCSX2 - PS2 Emulator for PCs
|
|
|
|
* Copyright (C) 2002-2009 PCSX2 Dev Team
|
2010-04-25 00:31:27 +00:00
|
|
|
*
|
2009-09-08 12:08:10 +00:00
|
|
|
* PCSX2 is free software: you can redistribute it and/or modify it under the terms
|
|
|
|
* of the GNU Lesser General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
2009-04-14 01:26:57 +00:00
|
|
|
*
|
2009-09-08 12:08:10 +00:00
|
|
|
* PCSX2 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with PCSX2.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
2009-04-14 01:26:57 +00:00
|
|
|
*/
|
2009-04-07 21:54:50 +00:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2009-07-03 00:49:40 +00:00
|
|
|
#include "x86types.h"
|
|
|
|
#include "instructions.h"
|
2009-11-06 21:45:30 +00:00
|
|
|
|
|
|
|
#define OpWriteSSE( pre, op ) xOpWrite0F( pre, op, to, from )
|
|
|
|
|
|
|
|
namespace x86Emitter {
|
|
|
|
|
|
|
|
extern void SimdPrefix( u8 prefix, u16 opcode );
|
|
|
|
extern void EmitSibMagic( uint regfield, const void* address );
|
|
|
|
extern void EmitSibMagic( uint regfield, const ModSibBase& info );
|
|
|
|
extern void EmitSibMagic( uint reg1, const xRegisterBase& reg2 );
|
|
|
|
extern void EmitSibMagic( const xRegisterBase& reg1, const xRegisterBase& reg2 );
|
|
|
|
extern void EmitSibMagic( const xRegisterBase& reg1, const void* src );
|
|
|
|
extern void EmitSibMagic( const xRegisterBase& reg1, const ModSibBase& sib );
|
|
|
|
|
|
|
|
extern void _xMovRtoR( const xRegisterInt& to, const xRegisterInt& from );
|
|
|
|
extern void _g1_EmitOp( G1Type InstType, const xRegisterInt& to, const xRegisterInt& from );
|
|
|
|
|
2009-11-07 17:15:37 +00:00
|
|
|
template< typename T > inline
|
|
|
|
void xWrite( T val )
|
|
|
|
{
|
|
|
|
*(T*)x86Ptr = val;
|
|
|
|
x86Ptr += sizeof(T);
|
|
|
|
}
|
|
|
|
|
2009-11-06 21:45:30 +00:00
|
|
|
template< typename T1, typename T2 > __emitinline
|
|
|
|
void xOpWrite( u8 prefix, u8 opcode, const T1& param1, const T2& param2 )
|
|
|
|
{
|
|
|
|
if( prefix != 0 )
|
|
|
|
xWrite16( (opcode<<8) | prefix );
|
|
|
|
else
|
|
|
|
xWrite8( opcode );
|
|
|
|
|
|
|
|
EmitSibMagic( param1, param2 );
|
|
|
|
}
|
|
|
|
|
|
|
|
template< typename T1, typename T2 > __emitinline
|
|
|
|
void xOpWrite0F( u8 prefix, u16 opcode, const T1& param1, const T2& param2 )
|
|
|
|
{
|
|
|
|
SimdPrefix( prefix, opcode );
|
|
|
|
EmitSibMagic( param1, param2 );
|
|
|
|
}
|
|
|
|
|
|
|
|
template< typename T1, typename T2 > __emitinline
|
|
|
|
void xOpWrite0F( u8 prefix, u16 opcode, const T1& param1, const T2& param2, u8 imm8 )
|
|
|
|
{
|
|
|
|
xOpWrite0F( prefix, opcode, param1, param2 );
|
|
|
|
xWrite8( imm8 );
|
|
|
|
}
|
|
|
|
|
|
|
|
template< typename T1, typename T2 > __emitinline
|
|
|
|
void xOpWrite0F( u16 opcode, const T1& param1, const T2& param2 ) { xOpWrite0F( 0, opcode, param1, param2 ); }
|
|
|
|
|
|
|
|
template< typename T1, typename T2 > __emitinline
|
|
|
|
void xOpWrite0F( u16 opcode, const T1& param1, const T2& param2, u8 imm8 ) { xOpWrite0F( 0, opcode, param1, param2, imm8 ); }
|
|
|
|
|
|
|
|
}
|
|
|
|
|