mirror of https://github.com/PCSX2/pcsx2.git
306 lines
5.3 KiB
C++
306 lines
5.3 KiB
C++
|
/*
|
||
|
* Copyright (C) 2007-2009 Gabest
|
||
|
* http://www.gabest.org
|
||
|
*
|
||
|
* This Program is free software; you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License as published by
|
||
|
* the Free Software Foundation; either version 2, or (at your option)
|
||
|
* any later version.
|
||
|
*
|
||
|
* This Program 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 GNU Make; see the file COPYING. If not, write to
|
||
|
* the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
|
||
|
* http://www.gnu.org/copyleft/gpl.html
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#include "stdafx.h"
|
||
|
#include "GSUtil.h"
|
||
|
#include "GPURendererSW.h"
|
||
|
#include "GSDevice7.h"
|
||
|
#include "GSDevice9.h"
|
||
|
#include "GSDevice10.h"
|
||
|
#include "GPUSettingsDlg.h"
|
||
|
|
||
|
#define PSE_LT_GPU 2
|
||
|
|
||
|
static HRESULT s_hr = E_FAIL;
|
||
|
static GPURendererBase* s_gpu = NULL;
|
||
|
|
||
|
EXPORT_C_(UINT32) PSEgetLibType()
|
||
|
{
|
||
|
return PSE_LT_GPU;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(char*) PSEgetLibName()
|
||
|
{
|
||
|
return GSUtil::GetLibName();
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(UINT32) PSEgetLibVersion()
|
||
|
{
|
||
|
static const UINT32 version = 1;
|
||
|
static const UINT32 revision = 1;
|
||
|
|
||
|
return version << 16 | revision << 8 | PLUGIN_VERSION;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(INT32) GPUinit()
|
||
|
{
|
||
|
AFX_MANAGE_STATE(AfxGetStaticModuleState());
|
||
|
|
||
|
// TODO
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(INT32) GPUshutdown()
|
||
|
{
|
||
|
AFX_MANAGE_STATE(AfxGetStaticModuleState());
|
||
|
|
||
|
// TODO
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(INT32) GPUclose()
|
||
|
{
|
||
|
AFX_MANAGE_STATE(AfxGetStaticModuleState());
|
||
|
|
||
|
delete s_gpu;
|
||
|
|
||
|
s_gpu = NULL;
|
||
|
|
||
|
if(SUCCEEDED(s_hr))
|
||
|
{
|
||
|
::CoUninitialize();
|
||
|
|
||
|
s_hr = E_FAIL;
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(INT32) GPUopen(HWND hWnd)
|
||
|
{
|
||
|
AFX_MANAGE_STATE(AfxGetStaticModuleState());
|
||
|
|
||
|
if(!GSUtil::CheckDirectX() || !GSUtil::CheckSSE())
|
||
|
{
|
||
|
return -1;
|
||
|
}
|
||
|
|
||
|
GPUclose();
|
||
|
|
||
|
GPURendererSettings rs;
|
||
|
|
||
|
rs.m_filter = AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("filter"), 0);
|
||
|
rs.m_dither = AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("dithering"), 1);
|
||
|
rs.m_aspectratio = AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("AspectRatio"), 1);
|
||
|
rs.m_vsync = !!AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("vsync"), FALSE);
|
||
|
rs.m_scale.cx = AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("scale_x"), 0);
|
||
|
rs.m_scale.cy = AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("scale_y"), 0);
|
||
|
|
||
|
int threads = AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("swthreads"), 1);
|
||
|
|
||
|
int renderer = AfxGetApp()->GetProfileInt(_T("GPUSettings"), _T("Renderer"), 1);
|
||
|
|
||
|
switch(renderer)
|
||
|
{
|
||
|
default:
|
||
|
case 0: s_gpu = new GPURendererSW<GSDevice7>(rs, threads); break;
|
||
|
case 1: s_gpu = new GPURendererSW<GSDevice9>(rs, threads); break;
|
||
|
case 2: s_gpu = new GPURendererSW<GSDevice10>(rs, threads); break;
|
||
|
// TODO: case 3: s_gpu = new GPURendererNull<GSDeviceNull>(rs, threads); break;
|
||
|
}
|
||
|
|
||
|
s_hr = ::CoInitializeEx(NULL, COINIT_MULTITHREADED);
|
||
|
|
||
|
if(!s_gpu->Create(hWnd))
|
||
|
{
|
||
|
GPUclose();
|
||
|
|
||
|
return -1;
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(INT32) GPUconfigure()
|
||
|
{
|
||
|
AFX_MANAGE_STATE(AfxGetStaticModuleState());
|
||
|
|
||
|
GPUSettingsDlg dlg;
|
||
|
|
||
|
if(IDOK == dlg.DoModal())
|
||
|
{
|
||
|
GPUshutdown();
|
||
|
GPUinit();
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(INT32) GPUtest()
|
||
|
{
|
||
|
// TODO
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUabout()
|
||
|
{
|
||
|
// TODO
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUwriteDataMem(const BYTE* mem, UINT32 size)
|
||
|
{
|
||
|
s_gpu->WriteData(mem, size);
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUwriteData(UINT32 data)
|
||
|
{
|
||
|
s_gpu->WriteData((BYTE*)&data, 1);
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUreadDataMem(BYTE* mem, UINT32 size)
|
||
|
{
|
||
|
s_gpu->ReadData(mem, size);
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(UINT32) GPUreadData()
|
||
|
{
|
||
|
UINT32 data = 0;
|
||
|
|
||
|
s_gpu->ReadData((BYTE*)&data, 1);
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUwriteStatus(UINT32 status)
|
||
|
{
|
||
|
s_gpu->WriteStatus(status);
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(UINT32) GPUreadStatus()
|
||
|
{
|
||
|
return s_gpu->ReadStatus();
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(UINT32) GPUdmaChain(const BYTE* mem, UINT32 addr)
|
||
|
{
|
||
|
// TODO
|
||
|
|
||
|
UINT32 last[3];
|
||
|
|
||
|
memset(last, 0xff, sizeof(last));
|
||
|
|
||
|
do
|
||
|
{
|
||
|
if(addr == last[1] || addr == last[2]) break;
|
||
|
(addr < last[0] ? last[1] : last[2]) = addr;
|
||
|
last[0] = addr;
|
||
|
|
||
|
BYTE size = mem[addr + 3];
|
||
|
|
||
|
if(size > 0)
|
||
|
{
|
||
|
s_gpu->WriteData(&mem[addr + 4], size);
|
||
|
}
|
||
|
|
||
|
addr = *(UINT32*)&mem[addr] & 0xffffff;
|
||
|
}
|
||
|
while(addr != 0xffffff);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(UINT32) GPUgetMode()
|
||
|
{
|
||
|
// TODO
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUsetMode(UINT32)
|
||
|
{
|
||
|
// TODO
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUupdateLace()
|
||
|
{
|
||
|
s_gpu->VSync();
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUmakeSnapshot()
|
||
|
{
|
||
|
LPCTSTR path = _T("C:\\"); // TODO
|
||
|
|
||
|
s_gpu->MakeSnapshot(path);
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUdisplayText(char* text)
|
||
|
{
|
||
|
// TODO
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUdisplayFlags(UINT32 flags)
|
||
|
{
|
||
|
// TODO
|
||
|
}
|
||
|
|
||
|
EXPORT_C_(INT32) GPUfreeze(UINT32 type, GPUFreezeData* data)
|
||
|
{
|
||
|
if(!data || data->version != 1)
|
||
|
{
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
if(type == 0)
|
||
|
{
|
||
|
s_gpu->Defrost(data);
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
else if(type == 1)
|
||
|
{
|
||
|
s_gpu->Freeze(data);
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
else if(type == 2)
|
||
|
{
|
||
|
int slot = *(int*)data + 1;
|
||
|
|
||
|
if(slot < 1 || slot > 9)
|
||
|
{
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
// TODO
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUgetScreenPic(BYTE* mem)
|
||
|
{
|
||
|
// TODO
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUshowScreenPic(BYTE* mem)
|
||
|
{
|
||
|
// TODO
|
||
|
}
|
||
|
|
||
|
EXPORT_C GPUcursor(int player, int x, int y)
|
||
|
{
|
||
|
// TODO
|
||
|
}
|