mirror of https://github.com/PCSX2/pcsx2.git
Renamed memzero_obj to memzero. Been meaning to do that for a while. Also, Savestates *almost* work, but it's just not going to happen. See everyone in 5 days or so. -_-
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@1913 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
32550ef6a0
commit
6b9ffd8132
|
@ -16,11 +16,11 @@
|
|||
#ifndef _LNX_MEMZERO_H_
|
||||
#define _LNX_MEMZERO_H_
|
||||
|
||||
// This header contains non-optimized implementation of memzero_ptr and memset8_obj,
|
||||
// memset16_obj, etc.
|
||||
// This header contains non-optimized implementation of memzero_ptr and memset8,
|
||||
// memset16, etc.
|
||||
|
||||
template< u32 data, typename T >
|
||||
static __forceinline void memset32_obj( T& obj )
|
||||
static __forceinline void memset32( T& obj )
|
||||
{
|
||||
// this function works on 32-bit aligned lengths of data only.
|
||||
// If the data length is not a factor of 32 bits, the C++ optimizing compiler will
|
||||
|
@ -40,28 +40,28 @@ static __forceinline void memzero_ptr( void* dest )
|
|||
}
|
||||
|
||||
template< typename T >
|
||||
static __forceinline void memzero_obj( T& obj )
|
||||
static __forceinline void memzero( T& obj )
|
||||
{
|
||||
memset( &obj, 0, sizeof( T ) );
|
||||
}
|
||||
|
||||
template< u8 data, typename T >
|
||||
static __forceinline void memset8_obj( T& obj )
|
||||
static __forceinline void memset8( T& obj )
|
||||
{
|
||||
// Aligned sizes use the optimized 32 bit inline memset. Unaligned sizes use memset.
|
||||
if( (sizeof(T) & 0x3) != 0 )
|
||||
memset( &obj, data, sizeof( T ) );
|
||||
else
|
||||
memset32_obj<data + (data<<8) + (data<<16) + (data<<24)>( obj );
|
||||
memset32<data + (data<<8) + (data<<16) + (data<<24)>( obj );
|
||||
}
|
||||
|
||||
template< u16 data, typename T >
|
||||
static __forceinline void memset16_obj( T& obj )
|
||||
static __forceinline void memset16( T& obj )
|
||||
{
|
||||
if( (sizeof(T) & 0x3) != 0 )
|
||||
_memset16_unaligned( &obj, data, sizeof( T ) );
|
||||
else
|
||||
memset32_obj<data + (data<<16)>( obj );
|
||||
memset32<data + (data<<16)>( obj );
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -562,28 +562,28 @@ static __forceinline void memset_32( void *dest )
|
|||
// Structures, static arrays, etc. No need to include sizeof() crap, this does it automatically
|
||||
// for you!
|
||||
template< typename T >
|
||||
static __forceinline void memzero_obj( T& object )
|
||||
static __forceinline void memzero( T& object )
|
||||
{
|
||||
memzero_ptr<sizeof(T)>( &object );
|
||||
}
|
||||
|
||||
// This method clears an object with the given 8 bit value.
|
||||
template< u8 data, typename T >
|
||||
static __forceinline void memset8_obj( T& object )
|
||||
static __forceinline void memset8( T& object )
|
||||
{
|
||||
memset_8<data, sizeof(T)>( &object );
|
||||
}
|
||||
|
||||
// This method clears an object with the given 16 bit value.
|
||||
template< u16 data, typename T >
|
||||
static __forceinline void memset16_obj( T& object )
|
||||
static __forceinline void memset16( T& object )
|
||||
{
|
||||
memset_16<data, sizeof(T)>( &object );
|
||||
}
|
||||
|
||||
// This method clears an object with the given 32 bit value.
|
||||
template< u32 data, typename T >
|
||||
static __forceinline void memset32_obj( T& object )
|
||||
static __forceinline void memset32( T& object )
|
||||
{
|
||||
memset_32<data, sizeof(T)>( &object );
|
||||
}
|
||||
|
|
|
@ -166,7 +166,7 @@ void cpudetectInit()
|
|||
int num;
|
||||
char str[50];
|
||||
|
||||
memzero_obj( x86caps.VendorName );
|
||||
memzero( x86caps.VendorName );
|
||||
x86caps.FamilyID = 0;
|
||||
x86caps.Model = 0;
|
||||
x86caps.TypeID = 0;
|
||||
|
@ -254,7 +254,7 @@ void cpudetectInit()
|
|||
if ( x86caps.VendorName[ 0 ] == 'G' ){ cputype=0;}//trick lines but if you know a way better ;p
|
||||
if ( x86caps.VendorName[ 0 ] == 'A' ){ cputype=1;}
|
||||
|
||||
memzero_obj( x86caps.FamilyName );
|
||||
memzero( x86caps.FamilyName );
|
||||
iCpuId( 0x80000002, (u32*)x86caps.FamilyName);
|
||||
iCpuId( 0x80000003, (u32*)(x86caps.FamilyName+16));
|
||||
iCpuId( 0x80000004, (u32*)(x86caps.FamilyName+32));
|
||||
|
|
|
@ -453,7 +453,7 @@ static uint cdvdBlockReadTime( CDVD_MODE_TYPE mode )
|
|||
|
||||
void cdvdReset()
|
||||
{
|
||||
memzero_obj(cdvd);
|
||||
memzero(cdvd);
|
||||
|
||||
cdvd.Type = CDVD_TYPE_NODISC;
|
||||
cdvd.Spinning = false;
|
||||
|
|
|
@ -508,7 +508,7 @@ void cdrReadInterrupt() {
|
|||
if (cdr.RErr == -1)
|
||||
{
|
||||
CDR_LOG(" err\n");
|
||||
memzero_obj(cdr.Transfer);
|
||||
memzero(cdr.Transfer);
|
||||
cdr.Stat = DiskError;
|
||||
cdr.Result[0] |= 0x01;
|
||||
ReadTrack();
|
||||
|
@ -955,7 +955,7 @@ void cdvdDmaInterrupt(s32 channel)
|
|||
#endif
|
||||
|
||||
void cdrReset() {
|
||||
memzero_obj(cdr);
|
||||
memzero(cdr);
|
||||
cdr.CurTrack=1;
|
||||
cdr.File=1; cdr.Channel=1;
|
||||
cdReadTime = (PSXCLK / 1757) * BIAS;
|
||||
|
|
|
@ -50,8 +50,8 @@ void IsoFS_init()
|
|||
|
||||
ISOFS_LOG("[IsoFSdrv:init] Initializing '%s' file driver.", "IsoFS");
|
||||
|
||||
memzero_obj( fd_table );
|
||||
memzero_obj( fd_used );
|
||||
memzero( fd_table );
|
||||
memzero( fd_used );
|
||||
|
||||
inited = TRUE;
|
||||
|
||||
|
|
|
@ -124,7 +124,7 @@ static __forceinline void cpuRcntSet()
|
|||
void rcntInit() {
|
||||
int i;
|
||||
|
||||
memzero_obj(counters);
|
||||
memzero(counters);
|
||||
|
||||
for (i=0; i<4; i++) {
|
||||
counters[i].rate = 2;
|
||||
|
|
|
@ -234,7 +234,7 @@ void iDumpBlock( int startpc, u8 * ptr )
|
|||
EEINST_LIVE0, EEINST_LIVE1, EEINST_LIVE2, EEINST_LASTUSE, EEINST_MMX, EEINST_XMM, EEINST_USED
|
||||
);
|
||||
|
||||
memzero_obj(used);
|
||||
memzero(used);
|
||||
numused = 0;
|
||||
for(uint i = 0; i < ArraySize(s_pInstCache->regs); ++i) {
|
||||
if( s_pInstCache->regs[i] & EEINST_USED ) {
|
||||
|
@ -243,7 +243,7 @@ void iDumpBlock( int startpc, u8 * ptr )
|
|||
}
|
||||
}
|
||||
|
||||
memzero_obj(fpuused);
|
||||
memzero(fpuused);
|
||||
fpunumused = 0;
|
||||
for(uint i = 0; i < ArraySize(s_pInstCache->fpuregs); ++i) {
|
||||
if( s_pInstCache->fpuregs[i] & EEINST_USED ) {
|
||||
|
|
|
@ -87,7 +87,7 @@ void gsSetRegionMode( GS_RegionMode region )
|
|||
// Make sure framelimiter options are in sync with the plugin's capabilities.
|
||||
void gsInit()
|
||||
{
|
||||
memzero_obj(g_RealGSMem);
|
||||
memzero(g_RealGSMem);
|
||||
}
|
||||
|
||||
void gsReset()
|
||||
|
@ -99,7 +99,7 @@ void gsReset()
|
|||
UpdateVSyncRate()
|
||||
);
|
||||
|
||||
memzero_obj(g_RealGSMem);
|
||||
memzero(g_RealGSMem);
|
||||
|
||||
GSCSRr = 0x551B4000; // Set the FINISH bit to 1 for now
|
||||
GSIMR = 0x7f00;
|
||||
|
|
|
@ -49,7 +49,7 @@ public:
|
|||
const char* gsdll, *cdvddll, *spudll;
|
||||
const char* pad1dll, *pad2dll, *dev9dll;
|
||||
|
||||
StartupParams() { memzero_obj(*this); }
|
||||
StartupParams() { memzero(*this); }
|
||||
};
|
||||
|
||||
extern StartupParams g_Startup;
|
||||
|
|
|
@ -132,12 +132,12 @@ __forceinline void mpeg2_init()
|
|||
{
|
||||
mpeg2_idct_init();
|
||||
yuv2rgb_init();
|
||||
memzero_obj(mb8.Y);
|
||||
memzero_obj(mb8.Cb);
|
||||
memzero_obj(mb8.Cr);
|
||||
memzero_obj(mb16.Y);
|
||||
memzero_obj(mb16.Cb);
|
||||
memzero_obj(mb16.Cr);
|
||||
memzero(mb8.Y);
|
||||
memzero(mb8.Cb);
|
||||
memzero(mb8.Cr);
|
||||
memzero(mb16.Y);
|
||||
memzero(mb16.Cb);
|
||||
memzero(mb16.Cr);
|
||||
mpeg2_inited = TRUE;
|
||||
}
|
||||
}
|
||||
|
@ -146,8 +146,8 @@ __forceinline void mpeg2_init()
|
|||
// Register accesses (run on EE thread)
|
||||
int ipuInit()
|
||||
{
|
||||
memzero_obj(*ipuRegs);
|
||||
memzero_obj(g_BP);
|
||||
memzero(*ipuRegs);
|
||||
memzero(g_BP);
|
||||
init_g_decoder();
|
||||
g_nDMATransfer._u32 = 0;
|
||||
|
||||
|
@ -156,7 +156,7 @@ int ipuInit()
|
|||
|
||||
void ipuReset()
|
||||
{
|
||||
memzero_obj(*ipuRegs);
|
||||
memzero(*ipuRegs);
|
||||
g_nDMATransfer._u32 = 0;
|
||||
}
|
||||
|
||||
|
@ -499,8 +499,8 @@ static __forceinline BOOL ipuBDEC(u32 val)
|
|||
g_decoder.dcr = bdec.DCR;
|
||||
g_decoder.macroblock_modes |= bdec.MBI ? MACROBLOCK_INTRA : MACROBLOCK_PATTERN;
|
||||
|
||||
memzero_obj(mb8);
|
||||
memzero_obj(mb16);
|
||||
memzero(mb8);
|
||||
memzero(mb16);
|
||||
|
||||
s_routine = so_create(mpeg2_slice, &s_RoutineDone, s_tempstack, sizeof(s_tempstack));
|
||||
assert(s_routine != NULL);
|
||||
|
@ -1300,7 +1300,7 @@ void __fastcall ipu_copy(const macroblock_8 *mb8, macroblock_16 *mb16)
|
|||
///////////////////// IPU DMA ////////////////////////
|
||||
void FIFOto_clear()
|
||||
{
|
||||
memzero_obj(fifo_input);
|
||||
memzero(fifo_input);
|
||||
g_BP.IFC = 0;
|
||||
ipuRegs->ctrl.IFC = 0;
|
||||
FIreadpos = 0;
|
||||
|
@ -1592,7 +1592,7 @@ int IPU1dma()
|
|||
|
||||
void FIFOfrom_clear()
|
||||
{
|
||||
memzero_obj(fifo_output);
|
||||
memzero(fifo_output);
|
||||
ipuRegs->ctrl.OFC = 0;
|
||||
FOreadpos = 0;
|
||||
FOwritepos = 0;
|
||||
|
|
|
@ -985,7 +985,7 @@ static void __fastcall slice_non_intra_DCT(decoder_t * const decoder,
|
|||
/*u8*/s16 * const dest, const int stride)
|
||||
{
|
||||
int last;
|
||||
memzero_obj(decoder->DCTblock);
|
||||
memzero(decoder->DCTblock);
|
||||
|
||||
if (decoder->mpeg1)
|
||||
last = get_mpeg1_non_intra_block(decoder);
|
||||
|
@ -1035,7 +1035,7 @@ void SaveTGA(const char* filename, int width, int height, void* pdata)
|
|||
|
||||
assert(sizeof(TGA_HEADER) == 18 && sizeof(hdr) == 18);
|
||||
|
||||
memzero_obj(hdr);
|
||||
memzero(hdr);
|
||||
hdr.imagetype = 2;
|
||||
hdr.bits = 32;
|
||||
hdr.width = width;
|
||||
|
@ -1185,8 +1185,8 @@ void mpeg2sliceIDEC(void* pdone)
|
|||
decoder->coded_block_pattern = 0x3F;//all 6 blocks
|
||||
//ipuRegs->ctrl.CBP = 0x3f;
|
||||
|
||||
memzero_obj(*decoder->mb8);
|
||||
memzero_obj(*decoder->rgb32);
|
||||
memzero(*decoder->mb8);
|
||||
memzero(*decoder->rgb32);
|
||||
|
||||
slice_intra_DCT(decoder, 0, (u8*)decoder->mb8->Y, DCT_stride);
|
||||
slice_intra_DCT(decoder, 0, (u8*)decoder->mb8->Y + 8, DCT_stride);
|
||||
|
@ -1312,8 +1312,8 @@ void mpeg2_slice(void* pdone)
|
|||
*(int*)pdone = 0;
|
||||
ipuRegs->ctrl.ECD = 0;
|
||||
|
||||
memzero_obj(*decoder->mb8);
|
||||
memzero_obj(*decoder->mb16);
|
||||
memzero(*decoder->mb8);
|
||||
memzero(*decoder->mb16);
|
||||
|
||||
bitstream_init(decoder);
|
||||
|
||||
|
|
|
@ -113,7 +113,7 @@ static void _rcntSet( int cntidx )
|
|||
void psxRcntInit() {
|
||||
int i;
|
||||
|
||||
memzero_obj( psxCounters );
|
||||
memzero( psxCounters );
|
||||
|
||||
for (i=0; i<3; i++) {
|
||||
psxCounters[i].rate = 1;
|
||||
|
|
|
@ -53,7 +53,7 @@ only recv2 & dataout influences padman
|
|||
|
||||
void sio2Reset() {
|
||||
DevCon::Status( "Sio2 Reset" );
|
||||
memzero_obj(sio2);
|
||||
memzero(sio2);
|
||||
sio2.packet.recvVal1 = 0x1D100; // Nothing is connected at start
|
||||
}
|
||||
|
||||
|
|
|
@ -885,6 +885,6 @@ void mmap_ClearCpuBlock( uint offset )
|
|||
void mmap_ResetBlockTracking()
|
||||
{
|
||||
DevCon::WriteLn( "vtlb/mmap: Block Tracking reset..." );
|
||||
memzero_obj( m_PageProtectInfo );
|
||||
memzero( m_PageProtectInfo );
|
||||
HostSys::MemProtect( psM, Ps2MemSize::Base, Protect_ReadWrite );
|
||||
}
|
||||
|
|
|
@ -521,8 +521,8 @@ void inifile_command( char * cmd )
|
|||
|
||||
if ( ! pEqual ) pEqual = cmd+strlen(cmd); // fastmemory doesn't have =
|
||||
|
||||
memzero_obj( command );
|
||||
memzero_obj( parameter );
|
||||
memzero( command );
|
||||
memzero( parameter );
|
||||
|
||||
strncpy( command, cmd, pEqual - cmd );
|
||||
strncpy( parameter, pEqual + 1, sizeof( parameter ) );
|
||||
|
|
|
@ -51,7 +51,7 @@ PCSX2_ALIGNED16(psxRegisters psxRegs);
|
|||
|
||||
void psxReset()
|
||||
{
|
||||
memzero_obj(psxRegs);
|
||||
memzero(psxRegs);
|
||||
|
||||
psxRegs.pc = 0xbfc00000; // Start in bootstrap
|
||||
psxRegs.CP0.n.Status = 0x10900000; // COP0 enabled | BEV = 1 | TS = 1
|
||||
|
|
|
@ -65,9 +65,9 @@ void cpuReset()
|
|||
psxMemReset();
|
||||
vuMicroMemReset();
|
||||
|
||||
memzero_obj(cpuRegs);
|
||||
memzero_obj(fpuRegs);
|
||||
memzero_obj(tlb);
|
||||
memzero(cpuRegs);
|
||||
memzero(fpuRegs);
|
||||
memzero(tlb);
|
||||
|
||||
cpuRegs.pc = 0xbfc00000; ///set pc reg to stack
|
||||
cpuRegs.CP0.n.Config = 0x440;
|
||||
|
|
|
@ -41,7 +41,7 @@ static void PreLoadPrep()
|
|||
|
||||
static void PostLoadPrep()
|
||||
{
|
||||
memzero_obj(pCache);
|
||||
memzero(pCache);
|
||||
// WriteCP0Status(cpuRegs.CP0.n.Status.val);
|
||||
for(int i=0; i<48; i++) MapTLB(i);
|
||||
}
|
||||
|
@ -78,7 +78,7 @@ void SaveStateBase::FreezeTag( const char* src )
|
|||
{
|
||||
wxASSERT( strlen(src) < (sizeof( m_tagspace )-1) );
|
||||
|
||||
memzero_obj( m_tagspace );
|
||||
memzero( m_tagspace );
|
||||
strcpy( m_tagspace, src );
|
||||
Freeze( m_tagspace );
|
||||
|
||||
|
@ -98,10 +98,14 @@ void SaveStateBase::FreezeBios()
|
|||
// doesn't match the bios currently being used (chances are it'll still
|
||||
// work fine, but some games are very picky).
|
||||
|
||||
char descin[128];
|
||||
char descin[128], desccmp[128];
|
||||
wxString descout;
|
||||
IsBIOS( g_Conf->FullpathToBios(), descout );
|
||||
memcpy_fast( descin, descout.ToAscii().data(), 128 );
|
||||
memzero( descin );
|
||||
memzero( desccmp );
|
||||
|
||||
memcpy_fast( descin, descout.ToAscii().data(), descout.Length() );
|
||||
memcpy_fast( desccmp, descout.ToAscii().data(), descout.Length() );
|
||||
|
||||
// ... and only freeze bios info once per state, since the user msg could
|
||||
// become really annoying on a corrupted state or something. (have to always
|
||||
|
@ -112,7 +116,7 @@ void SaveStateBase::FreezeBios()
|
|||
|
||||
if( !m_DidBios )
|
||||
{
|
||||
if( memcmp( descin, descout.ToAscii().data(), 128 ) != 0 )
|
||||
if( memcmp( descin, desccmp, 128 ) != 0 )
|
||||
{
|
||||
Console::Error(
|
||||
"\n\tWarning: BIOS Version Mismatch, savestate may be unstable!\n"
|
||||
|
@ -246,15 +250,15 @@ bool SaveStateBase::FreezeSection()
|
|||
FreezeTag( "HardwareRegisters" );
|
||||
int seekpos = m_idx+4;
|
||||
int sectsize;
|
||||
Freeze( sectsize );
|
||||
|
||||
Freeze( sectsize );
|
||||
FreezeRegisters();
|
||||
|
||||
int realsectsize = m_idx - seekpos;
|
||||
if( IsSaving() )
|
||||
{
|
||||
// write back the section length...
|
||||
*((u32*)m_memory.GetPtr(seekpos)) = realsectsize - 4;
|
||||
*((u32*)m_memory.GetPtr(seekpos-4)) = realsectsize;
|
||||
}
|
||||
else // IsLoading!!
|
||||
{
|
||||
|
@ -275,8 +279,8 @@ bool SaveStateBase::FreezeSection()
|
|||
FreezeTag( "Plugin" );
|
||||
int seekpos = m_idx+4;
|
||||
int sectsize;
|
||||
Freeze( sectsize );
|
||||
|
||||
Freeze( sectsize );
|
||||
Freeze( m_pid );
|
||||
g_plugins->Freeze( (PluginsEnum_t)m_pid, *this );
|
||||
|
||||
|
@ -284,7 +288,7 @@ bool SaveStateBase::FreezeSection()
|
|||
if( IsSaving() )
|
||||
{
|
||||
// write back the section length...
|
||||
*((u32*)m_memory.GetPtr(seekpos)) = realsectsize - 4;
|
||||
*((u32*)m_memory.GetPtr(seekpos-4)) = realsectsize;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
|
@ -64,10 +64,10 @@ extern bool iopsifbusy[2];
|
|||
|
||||
void sifInit()
|
||||
{
|
||||
memzero_obj(sif0);
|
||||
memzero_obj(sif1);
|
||||
memzero_obj(eesifbusy);
|
||||
memzero_obj(iopsifbusy);
|
||||
memzero(sif0);
|
||||
memzero(sif1);
|
||||
memzero(eesifbusy);
|
||||
memzero(iopsifbusy);
|
||||
}
|
||||
|
||||
static __forceinline void SIF0write(u32 *from, int words)
|
||||
|
|
|
@ -86,8 +86,8 @@ static u8 sio_xor( const u8 *buf, uint length )
|
|||
|
||||
void sioInit()
|
||||
{
|
||||
memzero_obj(sio);
|
||||
memzero_obj(m_PostSavestateCards);
|
||||
memzero(sio);
|
||||
memzero(m_PostSavestateCards);
|
||||
|
||||
// Transfer(?) Ready and the Buffer is Empty
|
||||
sio.StatReg = TX_RDY | TX_EMPTY;
|
||||
|
@ -171,7 +171,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
PAD_LOG("RESET MEMORY CARD");
|
||||
|
||||
sio.bufcount = 8;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[3] = sio.terminator;
|
||||
sio.buf[2] = '+';
|
||||
sio.mcdst = 99;
|
||||
|
@ -179,7 +179,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
break;
|
||||
case 0x12: // RESET
|
||||
sio.bufcount = 8;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[3] = sio.terminator;
|
||||
sio.buf[2] = '+';
|
||||
sio.mcdst = 99;
|
||||
|
@ -189,7 +189,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
break;
|
||||
case 0x81: // COMMIT
|
||||
sio.bufcount = 8;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.mcdst = 99;
|
||||
sio.buf[3] = sio.terminator;
|
||||
sio.buf[2] = '+';
|
||||
|
@ -205,7 +205,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
case 0x22:
|
||||
case 0x23: // SECTOR SET
|
||||
sio.bufcount = 8; sio.mcdst = 99; sio.sector=0; sio.k=0;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio2.packet.recvVal3 = 0x8c;
|
||||
sio.buf[8]=sio.terminator;
|
||||
sio.buf[7]='+';
|
||||
|
@ -219,7 +219,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
break;
|
||||
case 0x26:
|
||||
sio.bufcount = 12; sio.mcdst = 99; sio2.packet.recvVal3 = 0x83;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
memcpy(&sio.buf[2], &mc_command_0x26, sizeof(mc_command_0x26));
|
||||
sio.buf[12]=sio.terminator;
|
||||
MEMCARDS_LOG("MC(%d) command 0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
|
@ -228,7 +228,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
case 0x28:
|
||||
case 0xBF:
|
||||
sio.bufcount = 4; sio.mcdst = 99; sio2.packet.recvVal3 = 0x8b;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[4]=sio.terminator;
|
||||
sio.buf[3]='+';
|
||||
MEMCARDS_LOG("MC(%d) command 0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
|
@ -243,7 +243,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
if(value==0x43) sio.lastsector = sio.sector; // Reading
|
||||
|
||||
sio.bufcount =133; sio.mcdst = 99;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[133]=sio.terminator;
|
||||
sio.buf[132]='+';
|
||||
MEMCARDS_LOG("MC(%d) command 0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
|
@ -257,24 +257,24 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
case 0xf3:
|
||||
case 0xf7:
|
||||
sio.bufcount = 4; sio.mcdst = 99;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[4]=sio.terminator;
|
||||
sio.buf[3]='+';
|
||||
MEMCARDS_LOG("MC(%d) command 0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
break;
|
||||
case 0x52:
|
||||
sio.rdwr = 1; memset8_obj<0xff>(sio.buf);
|
||||
sio.rdwr = 1; memset8<0xff>(sio.buf);
|
||||
sio.buf[sio.bufcount]=sio.terminator; sio.buf[sio.bufcount-1]='+';
|
||||
MEMCARDS_LOG("MC(%d) command 0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
break;
|
||||
case 0x57:
|
||||
sio.rdwr = 2; memset8_obj<0xff>(sio.buf);
|
||||
sio.rdwr = 2; memset8<0xff>(sio.buf);
|
||||
sio.buf[sio.bufcount]=sio.terminator; sio.buf[sio.bufcount-1]='+';
|
||||
MEMCARDS_LOG("MC(%d) command 0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
break;
|
||||
default:
|
||||
sio.mcdst = 0;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[sio.bufcount]=sio.terminator; sio.buf[sio.bufcount-1]='+';
|
||||
MEMCARDS_LOG("Unknown MC(%d) command 0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
}
|
||||
|
@ -332,7 +332,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
case 0x42:
|
||||
if (sio.parp==2) {
|
||||
sio.bufcount=5+value;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[sio.bufcount-1]='+';
|
||||
sio.buf[sio.bufcount]=sio.terminator;
|
||||
MEMCARDS_LOG("MC(%d) WRITE command, size=0x%02X", sio.GetMemcardIndex()+1, value);
|
||||
|
@ -409,7 +409,7 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
case 17:
|
||||
case 19:
|
||||
sio.bufcount=13;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[12] = 0; // Xor value of data from index 4 to 11
|
||||
sio.buf[3]='+';
|
||||
sio.buf[13] = sio.terminator;
|
||||
|
@ -418,13 +418,13 @@ void SIO_CommandWrite(u8 value,int way) {
|
|||
case 7:
|
||||
case 11:
|
||||
sio.bufcount=13;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[12]='+';
|
||||
sio.buf[13] = sio.terminator;
|
||||
break;
|
||||
default:
|
||||
sio.bufcount=4;
|
||||
memset8_obj<0xff>(sio.buf);
|
||||
memset8<0xff>(sio.buf);
|
||||
sio.buf[3]='+';
|
||||
sio.buf[4] = sio.terminator;
|
||||
}
|
||||
|
|
|
@ -285,8 +285,7 @@ void SysLoadState( const wxString& srcfile )
|
|||
|
||||
SysClearExecutionCache();
|
||||
cpuReset();
|
||||
//joe.FreezeAll();
|
||||
StateRecovery::Recover();
|
||||
joe.FreezeAll();
|
||||
}
|
||||
|
||||
// Maps a block of memory for use as a recompiled code buffer, and ensures that the
|
||||
|
|
|
@ -96,9 +96,9 @@ void vuMicroMemReset()
|
|||
memMapVUmicro();
|
||||
|
||||
// === VU0 Initialization ===
|
||||
memzero_obj(VU0.ACC);
|
||||
memzero_obj(VU0.VF);
|
||||
memzero_obj(VU0.VI);
|
||||
memzero(VU0.ACC);
|
||||
memzero(VU0.VF);
|
||||
memzero(VU0.VI);
|
||||
VU0.VF[0].f.x = 0.0f;
|
||||
VU0.VF[0].f.y = 0.0f;
|
||||
VU0.VF[0].f.z = 0.0f;
|
||||
|
@ -119,9 +119,9 @@ void vuMicroMemReset()
|
|||
VU0.vifRegs = vif0Regs;
|
||||
|
||||
// === VU1 Initialization ===
|
||||
memzero_obj(VU1.ACC);
|
||||
memzero_obj(VU1.VF);
|
||||
memzero_obj(VU1.VI);
|
||||
memzero(VU1.ACC);
|
||||
memzero(VU1.VF);
|
||||
memzero(VU1.VI);
|
||||
VU1.VF[0].f.x = 0.0f;
|
||||
VU1.VF[0].f.y = 0.0f;
|
||||
VU1.VF[0].f.z = 0.0f;
|
||||
|
|
|
@ -1553,7 +1553,7 @@ void vif0Write32(u32 mem, u32 value)
|
|||
{
|
||||
/* Reset VIF */
|
||||
//Console::WriteLn("Vif0 Reset %x", vif0Regs->stat);
|
||||
memzero_obj(vif0);
|
||||
memzero(vif0);
|
||||
vif0ch->qwc = 0; //?
|
||||
cpuRegs.interrupt &= ~1; //Stop all vif0 DMA's
|
||||
psHu64(VIF0_FIFO) = 0;
|
||||
|
@ -1648,8 +1648,8 @@ void vif0Write32(u32 mem, u32 value)
|
|||
void vif0Reset()
|
||||
{
|
||||
/* Reset the whole VIF, meaning the internal pcsx2 vars and all the registers */
|
||||
memzero_obj(vif0);
|
||||
memzero_obj(*vif0Regs);
|
||||
memzero(vif0);
|
||||
memzero(*vif0Regs);
|
||||
SetNewMask(g_vif0Masks, g_vif0HasMask3, 0, 0xffffffff);
|
||||
psHu64(VIF0_FIFO) = 0;
|
||||
psHu64(VIF0_FIFO + 8) = 0;
|
||||
|
@ -2648,7 +2648,7 @@ void vif1Write32(u32 mem, u32 value)
|
|||
if (value & 0x1)
|
||||
{
|
||||
/* Reset VIF */
|
||||
memzero_obj(vif1);
|
||||
memzero(vif1);
|
||||
cpuRegs.interrupt &= ~((1 << 1) | (1 << 10)); //Stop all vif1 DMA's
|
||||
vif1ch->qwc = 0; //?
|
||||
psHu64(VIF1_FIFO) = 0;
|
||||
|
@ -2792,8 +2792,8 @@ void vif1Write32(u32 mem, u32 value)
|
|||
void vif1Reset()
|
||||
{
|
||||
/* Reset the whole VIF, meaning the internal pcsx2 vars, and all the registers */
|
||||
memzero_obj(vif1);
|
||||
memzero_obj(*vif1Regs);
|
||||
memzero(vif1);
|
||||
memzero(*vif1Regs);
|
||||
SetNewMask(g_vif1Masks, g_vif1HasMask3, 0, 0xffffffff);
|
||||
psHu64(VIF1_FIFO) = 0;
|
||||
psHu64(VIF1_FIFO + 8) = 0;
|
||||
|
|
|
@ -76,7 +76,7 @@ protected:
|
|||
|
||||
FileMemoryCard::FileMemoryCard()
|
||||
{
|
||||
memset8_obj<0xff>( m_effeffs );
|
||||
memset8<0xff>( m_effeffs );
|
||||
|
||||
for( int port=0; port<2; ++port )
|
||||
{
|
||||
|
|
|
@ -199,7 +199,7 @@ PCSX2_ALIGNED16( static GifPathStruct s_gifPath ) =
|
|||
|
||||
GIFPath::GIFPath() : tag()
|
||||
{
|
||||
memzero_obj( *this );
|
||||
memzero( *this );
|
||||
}
|
||||
|
||||
__forceinline bool GIFPath::StepReg()
|
||||
|
@ -379,14 +379,14 @@ __forceinline int GIFPath_ParseTag(GIF_PATH pathidx, const u8* pMem, u32 size)
|
|||
// Clears all GIFpath data to zero.
|
||||
void GIFPath_Reset()
|
||||
{
|
||||
memzero_obj( s_gifPath.path );
|
||||
memzero( s_gifPath.path );
|
||||
}
|
||||
|
||||
// This is a hackfix tool provided for "canceling" the contents of the GIFpath when
|
||||
// invalid GIFdma states are encountered (tpyically needed for PATH3 only).
|
||||
__forceinline void GIFPath_Clear( GIF_PATH pathidx )
|
||||
{
|
||||
memzero_obj(s_gifPath.path[pathidx]);
|
||||
memzero(s_gifPath.path[pathidx]);
|
||||
if( GSgifSoftReset == NULL ) return;
|
||||
mtgsThread.SendSimplePacket( GS_RINGTYPE_SOFTRESET, (1<<pathidx), 0, 0 );
|
||||
}
|
||||
|
|
|
@ -489,7 +489,7 @@ void vtlb_VMapUnmap(u32 vaddr,u32 sz)
|
|||
void vtlb_Init()
|
||||
{
|
||||
vtlbHandlerCount=0;
|
||||
memzero_obj(vtlbdata.RWFT);
|
||||
memzero(vtlbdata.RWFT);
|
||||
|
||||
//Register default handlers
|
||||
//Unmapped Virt handlers _MUST_ be registered first.
|
||||
|
|
|
@ -49,7 +49,7 @@ using namespace std;
|
|||
static int s_xmmchecknext = 0;
|
||||
|
||||
void _initXMMregs() {
|
||||
memzero_obj( xmmregs );
|
||||
memzero( xmmregs );
|
||||
g_xmmAllocCounter = 0;
|
||||
s_xmmchecknext = 0;
|
||||
}
|
||||
|
@ -1028,9 +1028,9 @@ int _allocCheckGPRtoX86(EEINST* pinst, int gprreg, int mode)
|
|||
|
||||
void _recClearInst(EEINST* pinst)
|
||||
{
|
||||
memzero_obj( *pinst );
|
||||
memset8_obj<EEINST_LIVE0|EEINST_LIVE1|EEINST_LIVE2>( pinst->regs );
|
||||
memset8_obj<EEINST_LIVE0>( pinst->fpuregs );
|
||||
memzero( *pinst );
|
||||
memset8<EEINST_LIVE0|EEINST_LIVE1|EEINST_LIVE2>( pinst->regs );
|
||||
memset8<EEINST_LIVE0>( pinst->fpuregs );
|
||||
}
|
||||
|
||||
// returns nonzero value if reg has been written between [startpc, endpc-4]
|
||||
|
|
|
@ -164,7 +164,7 @@ static void iIopDumpBlock( int startpc, u8 * ptr )
|
|||
// write the instruction info
|
||||
f.Printf("\n\nlive0 - %x, lastuse - %x used - %x\n", EEINST_LIVE0, EEINST_LASTUSE, EEINST_USED);
|
||||
|
||||
memzero_obj(used);
|
||||
memzero(used);
|
||||
numused = 0;
|
||||
for(i = 0; i < ArraySize(s_pInstCache->regs); ++i) {
|
||||
if( s_pInstCache->regs[i] & EEINST_USED ) {
|
||||
|
|
|
@ -39,7 +39,7 @@ static int g_x86checknext;
|
|||
// use special x86 register allocation for ia32
|
||||
|
||||
void _initX86regs() {
|
||||
memzero_obj(x86regs);
|
||||
memzero(x86regs);
|
||||
g_x86AllocCounter = 0;
|
||||
g_x86checknext = 0;
|
||||
}
|
||||
|
@ -467,7 +467,7 @@ static int s_mmxchecknext = 0;
|
|||
|
||||
void _initMMXregs()
|
||||
{
|
||||
memzero_obj(mmxregs);
|
||||
memzero(mmxregs);
|
||||
g_mmxAllocCounter = 0;
|
||||
s_mmxchecknext = 0;
|
||||
}
|
||||
|
|
|
@ -404,8 +404,8 @@ void recResetEE( void )
|
|||
memset_8<0xcc, REC_CACHEMEM>(recMem); // 0xcc is INT3
|
||||
memzero_ptr<m_recBlockAllocSize - Ps2MemSize::Base>( m_recBlockAlloc ); // Excluding the 32mb ram copy
|
||||
memzero_ptr<RECCONSTBUF_SIZE * sizeof(u32)>(recConstBuf);
|
||||
memzero_obj( manual_page );
|
||||
memzero_obj( manual_counter );
|
||||
memzero( manual_page );
|
||||
memzero( manual_counter );
|
||||
ClearRecLUT((BASEBLOCK*)m_recBlockAlloc,
|
||||
(((Ps2MemSize::Base + Ps2MemSize::Rom + Ps2MemSize::Rom1) / 4)));
|
||||
|
||||
|
|
|
@ -541,7 +541,7 @@ void SuperVUAnalyzeOp(VURegs *VU, _vuopinfo *info, _VURegsNum* pCodeRegs)
|
|||
// check upper flags
|
||||
if (ptr[1] & 0x80000000) { // I flag
|
||||
info->cycle = vucycle;
|
||||
memzero_obj(*lregs);
|
||||
memzero(*lregs);
|
||||
}
|
||||
else {
|
||||
|
||||
|
|
|
@ -165,7 +165,7 @@ class VuInstruction
|
|||
public:
|
||||
VuInstruction()
|
||||
{
|
||||
memzero_obj(*this);
|
||||
memzero(*this);
|
||||
nParentPc = -1;
|
||||
vicached = -1;
|
||||
}
|
||||
|
@ -294,9 +294,9 @@ VuBaseBlock::VuBaseBlock()
|
|||
cycles = 0;
|
||||
pcode = NULL;
|
||||
id = 0;
|
||||
memzero_obj(pChildJumps);
|
||||
memzero_obj(startregs);
|
||||
memzero_obj(endregs);
|
||||
memzero(pChildJumps);
|
||||
memzero(startregs);
|
||||
memzero(endregs);
|
||||
allocX86Regs = nStartx86 = nEndx86 = -1;
|
||||
prevFlagsOutOfBlock = 0;
|
||||
}
|
||||
|
@ -863,10 +863,10 @@ static VuFunctionHeader* SuperVURecompileProgram(u32 startpc, int vuindex)
|
|||
// analyze the global graph
|
||||
s_listBlocks.clear();
|
||||
VUPIPELINES pipes;
|
||||
memzero_obj(pipes.fmac);
|
||||
memzero_obj(pipes.fdiv);
|
||||
memzero_obj(pipes.efu);
|
||||
memzero_obj(pipes.ialu);
|
||||
memzero(pipes.fmac);
|
||||
memzero(pipes.fdiv);
|
||||
memzero(pipes.efu);
|
||||
memzero(pipes.ialu);
|
||||
SuperVUBuildBlocks(NULL, startpc, pipes);
|
||||
|
||||
// fill parents
|
||||
|
|
Loading…
Reference in New Issue