csgo-2018-source/common/ps3/spu_job_main.cpp
2021-07-24 21:11:47 -07:00

91 lines
2.4 KiB
C++

//========= Copyright © 1996-2004, Valve LLC, All rights reserved. ============
//
// This common file serves as redirection to make minimal SPU-only preparation
// of a job and call into its Main function. The Main function is hidden behind
// the unique namespace, just like all global symbols, so that multiple similar
// jobs can easily compile into and link with the vjobs.prx module that can call
// them on PPU either for debugging, for fallback case, or for main processing
// on Xbox360
//
//#include <cell/spurs/job_chain.h>
#include <cell/spurs/job_queue.h>
#include <cell/spurs/job_context.h>
#include <spu_printf.h>
#ifdef USE_LSGUARD
#include <cell/lsguard.h>
#endif
#ifndef VJOB
#error "Please define VJOB to the project name in SPU job project. This will isolate it from other jobs when they compile into the common elf, prx or dll"
#endif
namespace VJOB
{
extern void Main( CellSpursJobContext2* stInfo, CellSpursJob256 *job );
}
CellSpursJobContext2* g_stInfo = 0;
uint32_t g_InterlockedBuffer[32] __attribute__((aligned(128)));
#ifdef VJOB_JOBCHAIN_JOB
// JobChain job: the symbol is "job"
extern "C"
void cellSpursJobMain2(CellSpursJobContext2* stInfo, CellSpursJob256 *job)
{
extern CellSpursJobContext2* g_stInfo;
g_stInfo = stInfo;
VJOB::Main( stInfo, job );
}
#else
// JobQueue job: the symbol is "jqjob"
void cellSpursJobQueueMain(
CellSpursJobContext2 *pContext,
CellSpursJob256 *pJob
)
{
extern CellSpursJobContext2* g_stInfo;
g_stInfo = pContext;
VJOB::Main( pContext, pJob );
}
#endif
void CheckBufferOverflow_Impl()
{
uint16_t nCause;
int nResult;
nResult = cellSpursJobMemoryCheckTest( &nCause );
if ( nResult != CELL_OK )
{
spu_printf( "cellSpursJobMemoryCheckTest() failed = %08X\n", nResult );
__asm volatile ("stopd $0,$0,$0");
}
#ifdef USE_LSGUARD
nResult = cellLsGuardCheckCorruption();
if ( nResult != CELL_OK )
{
spu_printf( "cellLsGuardCheckCorruption() failed = %08X\n", nResult );
__asm volatile ("stopd $0,$0,$0");
cellLsGuardRehash(); // We rehash to detect the next corruption
}
#endif
}
void CheckDmaGet_Impl( const void * pBuffer, size_t nSize )
{
#ifdef USE_LSGUARD
int nResult;
nResult = cellLsGuardCheckWriteAccess( pBuffer, nSize );
if ( nResult != CELL_OK )
{
spu_printf( "cellLsGuardCheckWriteAccess() failed = %08X\n", nResult );
spu_printf( "Address: %08X - Size: %d\n", (int)pBuffer, (int)nSize );
__asm volatile ("stopd $0,$0,$0");
}
#endif
}