Finishing unique_ptr'ing and fixing file memory management (for now).
This commit is contained in:
parent
c59d053404
commit
08b0226a16
|
@ -94,7 +94,7 @@ void* X64CodeCache::PlaceCode(void* machine_code, size_t code_size,
|
||||||
lock_.unlock();
|
lock_.unlock();
|
||||||
|
|
||||||
// Copy code.
|
// Copy code.
|
||||||
xe_copy_struct(final_address, machine_code, code_size);
|
memcpy(final_address, machine_code, code_size);
|
||||||
|
|
||||||
// This isn't needed on x64 (probably), but is convention.
|
// This isn't needed on x64 (probably), but is convention.
|
||||||
FlushInstructionCache(GetCurrentProcess(), final_address, alloc_size);
|
FlushInstructionCache(GetCurrentProcess(), final_address, alloc_size);
|
||||||
|
@ -109,7 +109,7 @@ X64CodeChunk::X64CodeChunk(size_t chunk_size)
|
||||||
fn_table_capacity =
|
fn_table_capacity =
|
||||||
static_cast<uint32_t>(poly::round_up(capacity / ESTIMATED_FN_SIZE, 16));
|
static_cast<uint32_t>(poly::round_up(capacity / ESTIMATED_FN_SIZE, 16));
|
||||||
size_t table_size = fn_table_capacity * sizeof(RUNTIME_FUNCTION);
|
size_t table_size = fn_table_capacity * sizeof(RUNTIME_FUNCTION);
|
||||||
fn_table = (RUNTIME_FUNCTION*)xe_malloc(table_size);
|
fn_table = (RUNTIME_FUNCTION*)malloc(table_size);
|
||||||
fn_table_count = 0;
|
fn_table_count = 0;
|
||||||
fn_table_handle = 0;
|
fn_table_handle = 0;
|
||||||
RtlAddGrowableFunctionTable(&fn_table_handle, fn_table, fn_table_count,
|
RtlAddGrowableFunctionTable(&fn_table_handle, fn_table, fn_table_count,
|
||||||
|
@ -198,8 +198,7 @@ void X64CodeChunk::AddTableEntry(uint8_t* code, size_t code_size,
|
||||||
RtlDeleteGrowableFunctionTable(fn_table_handle);
|
RtlDeleteGrowableFunctionTable(fn_table_handle);
|
||||||
size_t old_size = fn_table_capacity * sizeof(RUNTIME_FUNCTION);
|
size_t old_size = fn_table_capacity * sizeof(RUNTIME_FUNCTION);
|
||||||
size_t new_size = old_size * 2;
|
size_t new_size = old_size * 2;
|
||||||
auto new_table =
|
auto new_table = (RUNTIME_FUNCTION*)realloc(fn_table, new_size);
|
||||||
(RUNTIME_FUNCTION*)xe_realloc(fn_table, old_size, new_size);
|
|
||||||
assert_not_null(new_table);
|
assert_not_null(new_table);
|
||||||
if (!new_table) {
|
if (!new_table) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -95,6 +95,9 @@ class Debugger {
|
||||||
void FindBreakpoints(uint64_t address,
|
void FindBreakpoints(uint64_t address,
|
||||||
std::vector<Breakpoint*>& out_breakpoints);
|
std::vector<Breakpoint*>& out_breakpoints);
|
||||||
|
|
||||||
|
// TODO(benvanik): utility functions for modification (make function ignored,
|
||||||
|
// etc).
|
||||||
|
|
||||||
void OnThreadCreated(ThreadState* thread_state);
|
void OnThreadCreated(ThreadState* thread_state);
|
||||||
void OnThreadDestroyed(ThreadState* thread_state);
|
void OnThreadDestroyed(ThreadState* thread_state);
|
||||||
void OnFunctionDefined(FunctionInfo* symbol_info, Function* function);
|
void OnFunctionDefined(FunctionInfo* symbol_info, Function* function);
|
||||||
|
|
|
@ -22,7 +22,7 @@ std::unique_ptr<AudioSystem> xe::apu::CreateNop(Emulator* emulator) {
|
||||||
|
|
||||||
#if XE_PLATFORM_WIN32
|
#if XE_PLATFORM_WIN32
|
||||||
#include <xenia/apu/xaudio2/xaudio2_apu.h>
|
#include <xenia/apu/xaudio2/xaudio2_apu.h>
|
||||||
AudioSystem* xe::apu::CreateXAudio2(Emulator* emulator) {
|
std::unique_ptr<AudioSystem> xe::apu::CreateXAudio2(Emulator* emulator) {
|
||||||
return xe::apu::xaudio2::Create(emulator);
|
return xe::apu::xaudio2::Create(emulator);
|
||||||
}
|
}
|
||||||
#endif // WIN32
|
#endif // WIN32
|
||||||
|
|
|
@ -9,29 +9,23 @@
|
||||||
|
|
||||||
#include <xenia/core/run_loop.h>
|
#include <xenia/core/run_loop.h>
|
||||||
|
|
||||||
|
typedef struct xe_run_loop { xe_ref_t ref; } xe_run_loop_t;
|
||||||
|
|
||||||
typedef struct xe_run_loop {
|
#define WM_XE_RUN_LOOP_QUIT (WM_APP + 0x100)
|
||||||
xe_ref_t ref;
|
#define WM_XE_RUN_LOOP_CALL (WM_APP + 0x101)
|
||||||
} xe_run_loop_t;
|
|
||||||
|
|
||||||
|
|
||||||
#define WM_XE_RUN_LOOP_QUIT (WM_APP + 0x100)
|
|
||||||
#define WM_XE_RUN_LOOP_CALL (WM_APP + 0x101)
|
|
||||||
|
|
||||||
typedef struct xe_run_loop_call {
|
typedef struct xe_run_loop_call {
|
||||||
xe_run_loop_callback callback;
|
xe_run_loop_callback callback;
|
||||||
void* data;
|
void* data;
|
||||||
} xe_run_loop_call_t;
|
} xe_run_loop_call_t;
|
||||||
|
|
||||||
|
|
||||||
xe_run_loop_ref xe_run_loop_create() {
|
xe_run_loop_ref xe_run_loop_create() {
|
||||||
xe_run_loop_ref run_loop = (xe_run_loop_ref)xe_calloc(sizeof(xe_run_loop_t));
|
xe_run_loop_ref run_loop = (xe_run_loop_ref)calloc(1, sizeof(xe_run_loop_t));
|
||||||
xe_ref_init((xe_ref)run_loop);
|
xe_ref_init((xe_ref)run_loop);
|
||||||
return run_loop;
|
return run_loop;
|
||||||
}
|
}
|
||||||
|
|
||||||
void xe_run_loop_dealloc(xe_run_loop_ref run_loop) {
|
void xe_run_loop_dealloc(xe_run_loop_ref run_loop) {}
|
||||||
}
|
|
||||||
|
|
||||||
xe_run_loop_ref xe_run_loop_retain(xe_run_loop_ref run_loop) {
|
xe_run_loop_ref xe_run_loop_retain(xe_run_loop_ref run_loop) {
|
||||||
xe_ref_retain((xe_ref)run_loop);
|
xe_ref_retain((xe_ref)run_loop);
|
||||||
|
@ -48,19 +42,19 @@ int xe_run_loop_pump(xe_run_loop_ref run_loop) {
|
||||||
TranslateMessage(&msg);
|
TranslateMessage(&msg);
|
||||||
DispatchMessage(&msg);
|
DispatchMessage(&msg);
|
||||||
switch (msg.message) {
|
switch (msg.message) {
|
||||||
case WM_XE_RUN_LOOP_CALL:
|
case WM_XE_RUN_LOOP_CALL:
|
||||||
if (msg.wParam == (WPARAM)run_loop) {
|
if (msg.wParam == (WPARAM)run_loop) {
|
||||||
xe_run_loop_call_t* call = (xe_run_loop_call_t*)msg.lParam;
|
xe_run_loop_call_t* call = (xe_run_loop_call_t*)msg.lParam;
|
||||||
call->callback(call->data);
|
call->callback(call->data);
|
||||||
xe_free(call);
|
free(call);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WM_XE_RUN_LOOP_QUIT:
|
case WM_XE_RUN_LOOP_QUIT:
|
||||||
if (msg.wParam == (WPARAM)run_loop) {
|
if (msg.wParam == (WPARAM)run_loop) {
|
||||||
// Done!
|
// Done!
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -70,11 +64,11 @@ void xe_run_loop_quit(xe_run_loop_ref run_loop) {
|
||||||
PostMessage(NULL, WM_XE_RUN_LOOP_QUIT, (WPARAM)run_loop, 0);
|
PostMessage(NULL, WM_XE_RUN_LOOP_QUIT, (WPARAM)run_loop, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void xe_run_loop_call(xe_run_loop_ref run_loop,
|
void xe_run_loop_call(xe_run_loop_ref run_loop, xe_run_loop_callback callback,
|
||||||
xe_run_loop_callback callback, void* data) {
|
void* data) {
|
||||||
xe_run_loop_call_t* call =
|
xe_run_loop_call_t* call =
|
||||||
(xe_run_loop_call_t*)xe_calloc(sizeof(xe_run_loop_call_t));
|
(xe_run_loop_call_t*)calloc(1, sizeof(xe_run_loop_call_t));
|
||||||
call->callback = callback;
|
call->callback = callback;
|
||||||
call->data = data;
|
call->data = data;
|
||||||
PostMessage(NULL, WM_XE_RUN_LOOP_CALL, (WPARAM)run_loop, (LPARAM)call);
|
PostMessage(NULL, WM_XE_RUN_LOOP_CALL, (WPARAM)run_loop, (LPARAM)call);
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,10 +16,8 @@
|
||||||
#include <winsock2.h>
|
#include <winsock2.h>
|
||||||
#include <ws2tcpip.h>
|
#include <ws2tcpip.h>
|
||||||
|
|
||||||
|
|
||||||
// TODO(benvanik): win32 calls
|
// TODO(benvanik): win32 calls
|
||||||
|
|
||||||
|
|
||||||
void xe_socket_init() {
|
void xe_socket_init() {
|
||||||
WSADATA wsa_data;
|
WSADATA wsa_data;
|
||||||
int result = WSAStartup(MAKEWORD(2, 2), &wsa_data);
|
int result = WSAStartup(MAKEWORD(2, 2), &wsa_data);
|
||||||
|
@ -41,12 +39,8 @@ void xe_socket_close(socket_t socket) {
|
||||||
struct linger so_linger;
|
struct linger so_linger;
|
||||||
so_linger.l_onoff = TRUE;
|
so_linger.l_onoff = TRUE;
|
||||||
so_linger.l_linger = 30;
|
so_linger.l_linger = 30;
|
||||||
setsockopt(
|
setsockopt(socket, SOL_SOCKET, SO_LINGER, (const char*)&so_linger,
|
||||||
socket,
|
sizeof so_linger);
|
||||||
SOL_SOCKET,
|
|
||||||
SO_LINGER,
|
|
||||||
(const char*)&so_linger,
|
|
||||||
sizeof so_linger);
|
|
||||||
shutdown(socket, SD_SEND);
|
shutdown(socket, SD_SEND);
|
||||||
closesocket(socket);
|
closesocket(socket);
|
||||||
}
|
}
|
||||||
|
@ -57,32 +51,32 @@ void xe_socket_set_keepalive(socket_t socket, bool value) {
|
||||||
alive.keepalivetime = 7200000;
|
alive.keepalivetime = 7200000;
|
||||||
alive.keepaliveinterval = 6000;
|
alive.keepaliveinterval = 6000;
|
||||||
DWORD bytes_returned;
|
DWORD bytes_returned;
|
||||||
WSAIoctl(socket, SIO_KEEPALIVE_VALS, &alive, sizeof(alive),
|
WSAIoctl(socket, SIO_KEEPALIVE_VALS, &alive, sizeof(alive), NULL, 0,
|
||||||
NULL, 0, &bytes_returned, NULL, NULL);
|
&bytes_returned, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void xe_socket_set_reuseaddr(socket_t socket, bool value) {
|
void xe_socket_set_reuseaddr(socket_t socket, bool value) {
|
||||||
int opt_value = value ? 1 : 0;
|
int opt_value = value ? 1 : 0;
|
||||||
setsockopt(socket, SOL_SOCKET, SO_REUSEADDR,
|
setsockopt(socket, SOL_SOCKET, SO_REUSEADDR, (const char*)&opt_value,
|
||||||
(const char*)&opt_value, sizeof(opt_value));
|
sizeof(opt_value));
|
||||||
}
|
}
|
||||||
|
|
||||||
void xe_socket_set_nodelay(socket_t socket, bool value) {
|
void xe_socket_set_nodelay(socket_t socket, bool value) {
|
||||||
int opt_value = value ? 1 : 0;
|
int opt_value = value ? 1 : 0;
|
||||||
setsockopt(socket, IPPROTO_TCP, TCP_NODELAY,
|
setsockopt(socket, IPPROTO_TCP, TCP_NODELAY, (const char*)&opt_value,
|
||||||
(const char*)&opt_value, sizeof(opt_value));
|
sizeof(opt_value));
|
||||||
}
|
}
|
||||||
|
|
||||||
void xe_socket_set_nonblock(socket_t socket, bool value) {
|
void xe_socket_set_nonblock(socket_t socket, bool value) {
|
||||||
u_long mode = value ? 1 : 0;
|
u_long mode = value ? 1 : 0;
|
||||||
ioctlsocket(socket, FIONBIO, &mode);
|
ioctlsocket(socket, FIONBIO, &mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
int xe_socket_bind(socket_t socket, uint32_t port) {
|
int xe_socket_bind(socket_t socket, uint32_t port) {
|
||||||
struct sockaddr_in socket_addr;
|
struct sockaddr_in socket_addr;
|
||||||
socket_addr.sin_family = AF_INET;
|
socket_addr.sin_family = AF_INET;
|
||||||
socket_addr.sin_addr.s_addr = htonl(INADDR_ANY);
|
socket_addr.sin_addr.s_addr = htonl(INADDR_ANY);
|
||||||
socket_addr.sin_port = htons(port);
|
socket_addr.sin_port = htons(port);
|
||||||
int r = bind(socket, (struct sockaddr*)&socket_addr, sizeof(socket_addr));
|
int r = bind(socket, (struct sockaddr*)&socket_addr, sizeof(socket_addr));
|
||||||
if (r == SOCKET_ERROR) {
|
if (r == SOCKET_ERROR) {
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -92,9 +86,9 @@ int xe_socket_bind(socket_t socket, uint32_t port) {
|
||||||
|
|
||||||
int xe_socket_bind_loopback(socket_t socket) {
|
int xe_socket_bind_loopback(socket_t socket) {
|
||||||
struct sockaddr_in socket_addr;
|
struct sockaddr_in socket_addr;
|
||||||
socket_addr.sin_family = AF_INET;
|
socket_addr.sin_family = AF_INET;
|
||||||
socket_addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
|
socket_addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
|
||||||
socket_addr.sin_port = htons(0);
|
socket_addr.sin_port = htons(0);
|
||||||
int r = bind(socket, (struct sockaddr*)&socket_addr, sizeof(socket_addr));
|
int r = bind(socket, (struct sockaddr*)&socket_addr, sizeof(socket_addr));
|
||||||
if (r == SOCKET_ERROR) {
|
if (r == SOCKET_ERROR) {
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -113,8 +107,8 @@ int xe_socket_listen(socket_t socket) {
|
||||||
int xe_socket_accept(socket_t socket, xe_socket_connection_t* out_client_info) {
|
int xe_socket_accept(socket_t socket, xe_socket_connection_t* out_client_info) {
|
||||||
struct sockaddr_in client_addr;
|
struct sockaddr_in client_addr;
|
||||||
int client_count = sizeof(client_addr);
|
int client_count = sizeof(client_addr);
|
||||||
socket_t client_socket_id = accept(
|
socket_t client_socket_id =
|
||||||
socket, (struct sockaddr*)&client_addr, &client_count);
|
accept(socket, (struct sockaddr*)&client_addr, &client_count);
|
||||||
if (client_socket_id == INVALID_SOCKET) {
|
if (client_socket_id == INVALID_SOCKET) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -122,8 +116,8 @@ int xe_socket_accept(socket_t socket, xe_socket_connection_t* out_client_info) {
|
||||||
out_client_info->socket = client_socket_id;
|
out_client_info->socket = client_socket_id;
|
||||||
|
|
||||||
int client_ip = client_addr.sin_addr.s_addr;
|
int client_ip = client_addr.sin_addr.s_addr;
|
||||||
inet_ntop(AF_INET, &client_ip,
|
inet_ntop(AF_INET, &client_ip, out_client_info->addr,
|
||||||
out_client_info->addr, poly::countof(out_client_info->addr));
|
poly::countof(out_client_info->addr));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -153,16 +147,16 @@ int64_t xe_socket_recv(socket_t socket, uint8_t* data, size_t length, int flags,
|
||||||
}
|
}
|
||||||
|
|
||||||
struct xe_socket_loop {
|
struct xe_socket_loop {
|
||||||
socket_t socket;
|
socket_t socket;
|
||||||
|
|
||||||
socket_t notify_rd_id;
|
socket_t notify_rd_id;
|
||||||
socket_t notify_wr_id;
|
socket_t notify_wr_id;
|
||||||
|
|
||||||
WSAPOLLFD events[2];
|
WSAPOLLFD events[2];
|
||||||
|
|
||||||
bool pending_queued_write;
|
bool pending_queued_write;
|
||||||
bool pending_recv;
|
bool pending_recv;
|
||||||
bool pending_send;
|
bool pending_send;
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -188,8 +182,8 @@ int Win32SocketPair(socket_t sockets[2]) {
|
||||||
sockaddr client_name;
|
sockaddr client_name;
|
||||||
int client_name_len = sizeof(client_name);
|
int client_name_len = sizeof(client_name);
|
||||||
r = getsockname(client, &client_name, &client_name_len);
|
r = getsockname(client, &client_name, &client_name_len);
|
||||||
const char *pc = (const char*)&client_name;
|
const char* pc = (const char*)&client_name;
|
||||||
const char *pn = (const char*)&listener_name;
|
const char* pn = (const char*)&listener_name;
|
||||||
for (size_t n = 0; n < sizeof(client_name); n++) {
|
for (size_t n = 0; n < sizeof(client_name); n++) {
|
||||||
if (pc[n] != pn[n]) {
|
if (pc[n] != pn[n]) {
|
||||||
closesocket(listener);
|
closesocket(listener);
|
||||||
|
@ -208,28 +202,28 @@ int Win32SocketPair(socket_t sockets[2]) {
|
||||||
}
|
}
|
||||||
|
|
||||||
xe_socket_loop_t* xe_socket_loop_create(socket_t socket) {
|
xe_socket_loop_t* xe_socket_loop_create(socket_t socket) {
|
||||||
xe_socket_loop_t* loop = (xe_socket_loop_t*)xe_calloc(
|
xe_socket_loop_t* loop =
|
||||||
sizeof(xe_socket_loop_t));
|
(xe_socket_loop_t*)calloc(1, sizeof(xe_socket_loop_t));
|
||||||
|
|
||||||
loop->socket = socket;
|
loop->socket = socket;
|
||||||
|
|
||||||
socket_t notify_ids[2] = { 0, 0 };
|
socket_t notify_ids[2] = {0, 0};
|
||||||
for (int retry = 0; retry < 5; retry++) {
|
for (int retry = 0; retry < 5; retry++) {
|
||||||
if (!Win32SocketPair(notify_ids)) {
|
if (!Win32SocketPair(notify_ids)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!notify_ids[0]) {
|
if (!notify_ids[0]) {
|
||||||
xe_free(loop);
|
free(loop);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
loop->notify_rd_id = notify_ids[0];
|
loop->notify_rd_id = notify_ids[0];
|
||||||
loop->notify_wr_id = notify_ids[1];
|
loop->notify_wr_id = notify_ids[1];
|
||||||
|
|
||||||
loop->events[0].fd = socket;
|
loop->events[0].fd = socket;
|
||||||
loop->events[0].events = POLLIN;
|
loop->events[0].events = POLLIN;
|
||||||
loop->events[1].fd = loop->notify_rd_id;
|
loop->events[1].fd = loop->notify_rd_id;
|
||||||
loop->events[1].events = POLLIN;
|
loop->events[1].events = POLLIN;
|
||||||
|
|
||||||
return loop;
|
return loop;
|
||||||
}
|
}
|
||||||
|
@ -237,11 +231,11 @@ xe_socket_loop_t* xe_socket_loop_create(socket_t socket) {
|
||||||
void xe_socket_loop_destroy(xe_socket_loop_t* loop) {
|
void xe_socket_loop_destroy(xe_socket_loop_t* loop) {
|
||||||
closesocket(loop->notify_rd_id);
|
closesocket(loop->notify_rd_id);
|
||||||
closesocket(loop->notify_wr_id);
|
closesocket(loop->notify_wr_id);
|
||||||
xe_free(loop);
|
free(loop);
|
||||||
}
|
}
|
||||||
|
|
||||||
int xe_socket_loop_poll(xe_socket_loop_t* loop,
|
int xe_socket_loop_poll(xe_socket_loop_t* loop, bool check_read,
|
||||||
bool check_read, bool check_write) {
|
bool check_write) {
|
||||||
// Prep events object.
|
// Prep events object.
|
||||||
loop->events[0].events = 0;
|
loop->events[0].events = 0;
|
||||||
if (check_read) {
|
if (check_read) {
|
||||||
|
|
|
@ -33,7 +33,7 @@ using namespace xe::kernel::fs;
|
||||||
using namespace xe::ui;
|
using namespace xe::ui;
|
||||||
|
|
||||||
Emulator::Emulator(const std::wstring& command_line)
|
Emulator::Emulator(const std::wstring& command_line)
|
||||||
: command_line_(command_line) {}
|
: command_line_(command_line), main_window_(nullptr) {}
|
||||||
|
|
||||||
Emulator::~Emulator() {
|
Emulator::~Emulator() {
|
||||||
// Note that we delete things in the reverse order they were initialized.
|
// Note that we delete things in the reverse order they were initialized.
|
||||||
|
@ -134,8 +134,8 @@ X_STATUS Emulator::Setup() {
|
||||||
kernel_state_ = std::make_unique<KernelState>(this);
|
kernel_state_ = std::make_unique<KernelState>(this);
|
||||||
|
|
||||||
// HLE kernel modules.
|
// HLE kernel modules.
|
||||||
xboxkrnl_ = std::make_unique<XboxkrnlModule>(this, kernel_state_);
|
xboxkrnl_ = std::make_unique<XboxkrnlModule>(this, kernel_state_.get());
|
||||||
xam_ = std::make_unique<XamModule>(this, kernel_state_);
|
xam_ = std::make_unique<XamModule>(this, kernel_state_.get());
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,7 @@ class AudioSystem;
|
||||||
} // namespace apu
|
} // namespace apu
|
||||||
namespace cpu {
|
namespace cpu {
|
||||||
class Processor;
|
class Processor;
|
||||||
|
class XenonThreadState;
|
||||||
} // namespace cpu
|
} // namespace cpu
|
||||||
namespace gpu {
|
namespace gpu {
|
||||||
class GraphicsSystem;
|
class GraphicsSystem;
|
||||||
|
|
|
@ -34,7 +34,7 @@ D3D11IndexBufferResource::~D3D11IndexBufferResource() {
|
||||||
|
|
||||||
int D3D11IndexBufferResource::CreateHandle() {
|
int D3D11IndexBufferResource::CreateHandle() {
|
||||||
D3D11_BUFFER_DESC buffer_desc;
|
D3D11_BUFFER_DESC buffer_desc;
|
||||||
xe_zero_struct(&buffer_desc, sizeof(buffer_desc));
|
memset(&buffer_desc, 0, sizeof(buffer_desc));
|
||||||
buffer_desc.ByteWidth = static_cast<UINT>(memory_range_.length);
|
buffer_desc.ByteWidth = static_cast<UINT>(memory_range_.length);
|
||||||
buffer_desc.Usage = D3D11_USAGE_DYNAMIC;
|
buffer_desc.Usage = D3D11_USAGE_DYNAMIC;
|
||||||
buffer_desc.BindFlags = D3D11_BIND_INDEX_BUFFER;
|
buffer_desc.BindFlags = D3D11_BIND_INDEX_BUFFER;
|
||||||
|
@ -100,7 +100,7 @@ D3D11VertexBufferResource::~D3D11VertexBufferResource() {
|
||||||
|
|
||||||
int D3D11VertexBufferResource::CreateHandle() {
|
int D3D11VertexBufferResource::CreateHandle() {
|
||||||
D3D11_BUFFER_DESC buffer_desc;
|
D3D11_BUFFER_DESC buffer_desc;
|
||||||
xe_zero_struct(&buffer_desc, sizeof(buffer_desc));
|
memset(&buffer_desc, 0, sizeof(buffer_desc));
|
||||||
buffer_desc.ByteWidth = static_cast<UINT>(memory_range_.length);
|
buffer_desc.ByteWidth = static_cast<UINT>(memory_range_.length);
|
||||||
buffer_desc.Usage = D3D11_USAGE_DYNAMIC;
|
buffer_desc.Usage = D3D11_USAGE_DYNAMIC;
|
||||||
buffer_desc.BindFlags = D3D11_BIND_VERTEX_BUFFER;
|
buffer_desc.BindFlags = D3D11_BIND_VERTEX_BUFFER;
|
||||||
|
|
|
@ -59,9 +59,8 @@ int D3D11GeometryShader::Prepare(D3D11VertexShaderResource* vertex_shader) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
byte_code_length = shader_blob->GetBufferSize();
|
byte_code_length = shader_blob->GetBufferSize();
|
||||||
byte_code = xe_malloc(byte_code_length);
|
byte_code = malloc(byte_code_length);
|
||||||
xe_copy_struct(
|
memcpy(byte_code, shader_blob->GetBufferPointer(), byte_code_length);
|
||||||
byte_code, shader_blob->GetBufferPointer(), byte_code_length);
|
|
||||||
SafeRelease(shader_blob);
|
SafeRelease(shader_blob);
|
||||||
|
|
||||||
// Create shader.
|
// Create shader.
|
||||||
|
@ -71,7 +70,7 @@ int D3D11GeometryShader::Prepare(D3D11VertexShaderResource* vertex_shader) {
|
||||||
&handle_);
|
&handle_);
|
||||||
if (FAILED(hr)) {
|
if (FAILED(hr)) {
|
||||||
XELOGE("D3D11: failed to create geometry shader");
|
XELOGE("D3D11: failed to create geometry shader");
|
||||||
xe_free(byte_code);
|
free(byte_code);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -39,13 +39,12 @@ D3D11GraphicsDriver::D3D11GraphicsDriver(
|
||||||
|
|
||||||
resource_cache_ = new D3D11ResourceCache(memory, device_, context_);
|
resource_cache_ = new D3D11ResourceCache(memory, device_, context_);
|
||||||
|
|
||||||
xe_zero_struct(&state_, sizeof(state_));
|
memset(&state_, 0, sizeof(state_));
|
||||||
|
|
||||||
xe_zero_struct(&render_targets_, sizeof(render_targets_));
|
memset(&render_targets_, 0, sizeof(render_targets_));
|
||||||
|
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
D3D11_BUFFER_DESC buffer_desc;
|
D3D11_BUFFER_DESC buffer_desc = {0};
|
||||||
xe_zero_struct(&buffer_desc, sizeof(buffer_desc));
|
|
||||||
buffer_desc.Usage = D3D11_USAGE_DYNAMIC;
|
buffer_desc.Usage = D3D11_USAGE_DYNAMIC;
|
||||||
buffer_desc.BindFlags = D3D11_BIND_CONSTANT_BUFFER;
|
buffer_desc.BindFlags = D3D11_BIND_CONSTANT_BUFFER;
|
||||||
buffer_desc.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
|
buffer_desc.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
|
||||||
|
@ -100,8 +99,7 @@ int D3D11GraphicsDriver::Initialize() {
|
||||||
|
|
||||||
void D3D11GraphicsDriver::InitializeInvalidTexture() {
|
void D3D11GraphicsDriver::InitializeInvalidTexture() {
|
||||||
// TODO(benvanik): pattern?
|
// TODO(benvanik): pattern?
|
||||||
D3D11_TEXTURE2D_DESC texture_desc;
|
D3D11_TEXTURE2D_DESC texture_desc = {0};
|
||||||
xe_zero_struct(&texture_desc, sizeof(texture_desc));
|
|
||||||
texture_desc.Width = 4;
|
texture_desc.Width = 4;
|
||||||
texture_desc.Height = 4;
|
texture_desc.Height = 4;
|
||||||
texture_desc.MipLevels = 1;
|
texture_desc.MipLevels = 1;
|
||||||
|
@ -131,8 +129,7 @@ void D3D11GraphicsDriver::InitializeInvalidTexture() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
D3D11_SHADER_RESOURCE_VIEW_DESC texture_view_desc;
|
D3D11_SHADER_RESOURCE_VIEW_DESC texture_view_desc = {};
|
||||||
xe_zero_struct(&texture_view_desc, sizeof(texture_view_desc));
|
|
||||||
texture_view_desc.Format = texture_desc.Format;
|
texture_view_desc.Format = texture_desc.Format;
|
||||||
texture_view_desc.ViewDimension = D3D10_SRV_DIMENSION_TEXTURE2D;
|
texture_view_desc.ViewDimension = D3D10_SRV_DIMENSION_TEXTURE2D;
|
||||||
texture_view_desc.Texture2D.MipLevels = 1;
|
texture_view_desc.Texture2D.MipLevels = 1;
|
||||||
|
@ -141,8 +138,7 @@ void D3D11GraphicsDriver::InitializeInvalidTexture() {
|
||||||
texture, &texture_view_desc, &invalid_texture_view_);
|
texture, &texture_view_desc, &invalid_texture_view_);
|
||||||
SafeRelease(texture);
|
SafeRelease(texture);
|
||||||
|
|
||||||
D3D11_SAMPLER_DESC sampler_desc;
|
D3D11_SAMPLER_DESC sampler_desc = {};
|
||||||
xe_zero_struct(&sampler_desc, sizeof(sampler_desc));
|
|
||||||
sampler_desc.Filter;
|
sampler_desc.Filter;
|
||||||
sampler_desc.AddressU = D3D11_TEXTURE_ADDRESS_CLAMP;
|
sampler_desc.AddressU = D3D11_TEXTURE_ADDRESS_CLAMP;
|
||||||
sampler_desc.AddressV = D3D11_TEXTURE_ADDRESS_CLAMP;
|
sampler_desc.AddressV = D3D11_TEXTURE_ADDRESS_CLAMP;
|
||||||
|
@ -396,8 +392,7 @@ int D3D11GraphicsDriver::SetupRasterizerState(const DrawCommand& command) {
|
||||||
ID3D11RasterizerState* rasterizer_state = nullptr;
|
ID3D11RasterizerState* rasterizer_state = nullptr;
|
||||||
auto it = rasterizer_state_cache_.find(key);
|
auto it = rasterizer_state_cache_.find(key);
|
||||||
if (it == rasterizer_state_cache_.end()) {
|
if (it == rasterizer_state_cache_.end()) {
|
||||||
D3D11_RASTERIZER_DESC rasterizer_desc;
|
D3D11_RASTERIZER_DESC rasterizer_desc = {};
|
||||||
xe_zero_struct(&rasterizer_desc, sizeof(rasterizer_desc));
|
|
||||||
rasterizer_desc.FillMode = D3D11_FILL_SOLID; // D3D11_FILL_WIREFRAME;
|
rasterizer_desc.FillMode = D3D11_FILL_SOLID; // D3D11_FILL_WIREFRAME;
|
||||||
switch (mode_control & 0x3) {
|
switch (mode_control & 0x3) {
|
||||||
case 0:
|
case 0:
|
||||||
|
@ -480,8 +475,7 @@ int D3D11GraphicsDriver::SetupBlendState(const DrawCommand& command) {
|
||||||
ID3D11BlendState* blend_state = nullptr;
|
ID3D11BlendState* blend_state = nullptr;
|
||||||
auto it = blend_state_cache_.find(key);
|
auto it = blend_state_cache_.find(key);
|
||||||
if (it == blend_state_cache_.end()) {
|
if (it == blend_state_cache_.end()) {
|
||||||
D3D11_BLEND_DESC blend_desc;
|
D3D11_BLEND_DESC blend_desc = {0};
|
||||||
xe_zero_struct(&blend_desc, sizeof(blend_desc));
|
|
||||||
//blend_desc.AlphaToCoverageEnable = false;
|
//blend_desc.AlphaToCoverageEnable = false;
|
||||||
// ?
|
// ?
|
||||||
blend_desc.IndependentBlendEnable = true;
|
blend_desc.IndependentBlendEnable = true;
|
||||||
|
@ -557,8 +551,7 @@ int D3D11GraphicsDriver::SetupDepthStencilState(const DrawCommand& command) {
|
||||||
ID3D11DepthStencilState* depth_stencil_state = nullptr;
|
ID3D11DepthStencilState* depth_stencil_state = nullptr;
|
||||||
auto it = depth_stencil_state_cache_.find(key);
|
auto it = depth_stencil_state_cache_.find(key);
|
||||||
if (it == depth_stencil_state_cache_.end()) {
|
if (it == depth_stencil_state_cache_.end()) {
|
||||||
D3D11_DEPTH_STENCIL_DESC depth_stencil_desc;
|
D3D11_DEPTH_STENCIL_DESC depth_stencil_desc = {0};
|
||||||
xe_zero_struct(&depth_stencil_desc, sizeof(depth_stencil_desc));
|
|
||||||
// A2XX_RB_DEPTHCONTROL_BACKFACE_ENABLE
|
// A2XX_RB_DEPTHCONTROL_BACKFACE_ENABLE
|
||||||
// ?
|
// ?
|
||||||
// A2XX_RB_DEPTHCONTROL_Z_ENABLE
|
// A2XX_RB_DEPTHCONTROL_Z_ENABLE
|
||||||
|
@ -846,8 +839,7 @@ int D3D11GraphicsDriver::RebuildRenderTargets(uint32_t width,
|
||||||
|
|
||||||
for (int n = 0; n < poly::countof(render_targets_.color_buffers); n++) {
|
for (int n = 0; n < poly::countof(render_targets_.color_buffers); n++) {
|
||||||
auto& cb = render_targets_.color_buffers[n];
|
auto& cb = render_targets_.color_buffers[n];
|
||||||
D3D11_TEXTURE2D_DESC color_buffer_desc;
|
D3D11_TEXTURE2D_DESC color_buffer_desc = {};
|
||||||
xe_zero_struct(&color_buffer_desc, sizeof(color_buffer_desc));
|
|
||||||
color_buffer_desc.Width = width;
|
color_buffer_desc.Width = width;
|
||||||
color_buffer_desc.Height = height;
|
color_buffer_desc.Height = height;
|
||||||
color_buffer_desc.MipLevels = 1;
|
color_buffer_desc.MipLevels = 1;
|
||||||
|
@ -865,7 +857,7 @@ int D3D11GraphicsDriver::RebuildRenderTargets(uint32_t width,
|
||||||
&color_buffer_desc, NULL, &cb.buffer);
|
&color_buffer_desc, NULL, &cb.buffer);
|
||||||
|
|
||||||
D3D11_RENDER_TARGET_VIEW_DESC render_target_view_desc;
|
D3D11_RENDER_TARGET_VIEW_DESC render_target_view_desc;
|
||||||
xe_zero_struct(&render_target_view_desc, sizeof(render_target_view_desc));
|
memset(&render_target_view_desc, 0, sizeof(render_target_view_desc));
|
||||||
render_target_view_desc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
|
render_target_view_desc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
|
||||||
render_target_view_desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE2D;
|
render_target_view_desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE2D;
|
||||||
// render_target_view_desc.Buffer ?
|
// render_target_view_desc.Buffer ?
|
||||||
|
@ -875,8 +867,7 @@ int D3D11GraphicsDriver::RebuildRenderTargets(uint32_t width,
|
||||||
&cb.color_view_8888);
|
&cb.color_view_8888);
|
||||||
}
|
}
|
||||||
|
|
||||||
D3D11_TEXTURE2D_DESC depth_stencil_desc;
|
D3D11_TEXTURE2D_DESC depth_stencil_desc = {};
|
||||||
xe_zero_struct(&depth_stencil_desc, sizeof(depth_stencil_desc));
|
|
||||||
depth_stencil_desc.Width = width;
|
depth_stencil_desc.Width = width;
|
||||||
depth_stencil_desc.Height = height;
|
depth_stencil_desc.Height = height;
|
||||||
depth_stencil_desc.MipLevels = 1;
|
depth_stencil_desc.MipLevels = 1;
|
||||||
|
@ -891,8 +882,7 @@ int D3D11GraphicsDriver::RebuildRenderTargets(uint32_t width,
|
||||||
device_->CreateTexture2D(
|
device_->CreateTexture2D(
|
||||||
&depth_stencil_desc, NULL, &render_targets_.depth_buffer);
|
&depth_stencil_desc, NULL, &render_targets_.depth_buffer);
|
||||||
|
|
||||||
D3D11_DEPTH_STENCIL_VIEW_DESC depth_stencil_view_desc;
|
D3D11_DEPTH_STENCIL_VIEW_DESC depth_stencil_view_desc = {};
|
||||||
xe_zero_struct(&depth_stencil_view_desc, sizeof(depth_stencil_view_desc));
|
|
||||||
depth_stencil_view_desc.Format = DXGI_FORMAT_D24_UNORM_S8_UINT;
|
depth_stencil_view_desc.Format = DXGI_FORMAT_D24_UNORM_S8_UINT;
|
||||||
depth_stencil_view_desc.ViewDimension = D3D11_DSV_DIMENSION_TEXTURE2D;
|
depth_stencil_view_desc.ViewDimension = D3D11_DSV_DIMENSION_TEXTURE2D;
|
||||||
depth_stencil_view_desc.Flags = 0;
|
depth_stencil_view_desc.Flags = 0;
|
||||||
|
|
|
@ -23,7 +23,7 @@ namespace d3d11 {
|
||||||
class D3D11Window;
|
class D3D11Window;
|
||||||
|
|
||||||
|
|
||||||
GraphicsSystem* Create(Emulator* emulator);
|
std::unique_ptr<GraphicsSystem> Create(Emulator* emulator);
|
||||||
|
|
||||||
|
|
||||||
class D3D11GraphicsSystem : public GraphicsSystem {
|
class D3D11GraphicsSystem : public GraphicsSystem {
|
||||||
|
|
|
@ -175,8 +175,7 @@ bool D3D11ProfilerDisplay::SetupState() {
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
auto device = window_->device();
|
auto device = window_->device();
|
||||||
|
|
||||||
D3D11_BLEND_DESC blend_desc;
|
D3D11_BLEND_DESC blend_desc = {0};
|
||||||
xe_zero_struct(&blend_desc, sizeof(blend_desc));
|
|
||||||
blend_desc.RenderTarget[0].BlendEnable = true;
|
blend_desc.RenderTarget[0].BlendEnable = true;
|
||||||
blend_desc.RenderTarget[0].BlendOp = D3D11_BLEND_OP_ADD;
|
blend_desc.RenderTarget[0].BlendOp = D3D11_BLEND_OP_ADD;
|
||||||
blend_desc.RenderTarget[0].BlendOpAlpha = D3D11_BLEND_OP_ADD;
|
blend_desc.RenderTarget[0].BlendOpAlpha = D3D11_BLEND_OP_ADD;
|
||||||
|
@ -188,8 +187,7 @@ bool D3D11ProfilerDisplay::SetupState() {
|
||||||
hr = device->CreateBlendState(&blend_desc, &blend_state_);
|
hr = device->CreateBlendState(&blend_desc, &blend_state_);
|
||||||
assert_true(SUCCEEDED(hr));
|
assert_true(SUCCEEDED(hr));
|
||||||
|
|
||||||
D3D11_DEPTH_STENCIL_DESC depth_stencil_desc;
|
D3D11_DEPTH_STENCIL_DESC depth_stencil_desc = {0};
|
||||||
xe_zero_struct(&depth_stencil_desc, sizeof(depth_stencil_desc));
|
|
||||||
depth_stencil_desc.DepthEnable = false;
|
depth_stencil_desc.DepthEnable = false;
|
||||||
depth_stencil_desc.StencilEnable = false;
|
depth_stencil_desc.StencilEnable = false;
|
||||||
depth_stencil_desc.DepthWriteMask = D3D11_DEPTH_WRITE_MASK_ZERO;
|
depth_stencil_desc.DepthWriteMask = D3D11_DEPTH_WRITE_MASK_ZERO;
|
||||||
|
@ -371,8 +369,7 @@ bool D3D11ProfilerDisplay::SetupFont() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
D3D11_SHADER_RESOURCE_VIEW_DESC texture_view_desc;
|
D3D11_SHADER_RESOURCE_VIEW_DESC texture_view_desc = {};
|
||||||
xe_zero_struct(&texture_view_desc, sizeof(texture_view_desc));
|
|
||||||
texture_view_desc.Format = texture_desc.Format;
|
texture_view_desc.Format = texture_desc.Format;
|
||||||
texture_view_desc.ViewDimension = D3D10_SRV_DIMENSION_TEXTURE2D;
|
texture_view_desc.ViewDimension = D3D10_SRV_DIMENSION_TEXTURE2D;
|
||||||
texture_view_desc.Texture2D.MipLevels = 1;
|
texture_view_desc.Texture2D.MipLevels = 1;
|
||||||
|
@ -385,8 +382,7 @@ bool D3D11ProfilerDisplay::SetupFont() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
D3D11_SAMPLER_DESC sampler_desc;
|
D3D11_SAMPLER_DESC sampler_desc = {};
|
||||||
xe_zero_struct(&sampler_desc, sizeof(sampler_desc));
|
|
||||||
sampler_desc.Filter = D3D11_ENCODE_BASIC_FILTER(
|
sampler_desc.Filter = D3D11_ENCODE_BASIC_FILTER(
|
||||||
D3D11_FILTER_TYPE_POINT, D3D11_FILTER_TYPE_POINT,
|
D3D11_FILTER_TYPE_POINT, D3D11_FILTER_TYPE_POINT,
|
||||||
D3D11_FILTER_TYPE_POINT, false);
|
D3D11_FILTER_TYPE_POINT, false);
|
||||||
|
|
|
@ -35,8 +35,7 @@ int D3D11SamplerStateResource::Prepare() {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
D3D11_SAMPLER_DESC sampler_desc;
|
D3D11_SAMPLER_DESC sampler_desc = {};
|
||||||
xe_zero_struct(&sampler_desc, sizeof(sampler_desc));
|
|
||||||
// MIN, MAG, MIP
|
// MIN, MAG, MIP
|
||||||
static const D3D11_FILTER filter_matrix[2][2][3] = {
|
static const D3D11_FILTER filter_matrix[2][2][3] = {
|
||||||
{
|
{
|
||||||
|
|
|
@ -97,7 +97,7 @@ D3D11VertexShaderResource::D3D11VertexShaderResource(
|
||||||
handle_(nullptr),
|
handle_(nullptr),
|
||||||
input_layout_(nullptr),
|
input_layout_(nullptr),
|
||||||
translated_src_(nullptr) {
|
translated_src_(nullptr) {
|
||||||
xe_zero_struct(geometry_shaders_, sizeof(geometry_shaders_));
|
memset(geometry_shaders_, 0, sizeof(geometry_shaders_));
|
||||||
}
|
}
|
||||||
|
|
||||||
D3D11VertexShaderResource::~D3D11VertexShaderResource() {
|
D3D11VertexShaderResource::~D3D11VertexShaderResource() {
|
||||||
|
@ -106,7 +106,7 @@ D3D11VertexShaderResource::~D3D11VertexShaderResource() {
|
||||||
for (int i = 0; i < poly::countof(geometry_shaders_); ++i) {
|
for (int i = 0; i < poly::countof(geometry_shaders_); ++i) {
|
||||||
delete geometry_shaders_[i];
|
delete geometry_shaders_[i];
|
||||||
}
|
}
|
||||||
xe_free(translated_src_);
|
free(translated_src_);
|
||||||
}
|
}
|
||||||
|
|
||||||
int D3D11VertexShaderResource::Prepare(
|
int D3D11VertexShaderResource::Prepare(
|
||||||
|
@ -135,25 +135,22 @@ int D3D11VertexShaderResource::Prepare(
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
byte_code_length = shader_blob->GetBufferSize();
|
byte_code_length = shader_blob->GetBufferSize();
|
||||||
byte_code = xe_malloc(byte_code_length);
|
byte_code = malloc(byte_code_length);
|
||||||
xe_copy_struct(
|
memcpy(byte_code, shader_blob->GetBufferPointer(), byte_code_length);
|
||||||
byte_code, shader_blob->GetBufferPointer(), byte_code_length);
|
|
||||||
SafeRelease(shader_blob);
|
SafeRelease(shader_blob);
|
||||||
|
|
||||||
// Create shader.
|
// Create shader.
|
||||||
HRESULT hr = resource_cache_->device()->CreateVertexShader(
|
HRESULT hr = resource_cache_->device()->CreateVertexShader(
|
||||||
byte_code, byte_code_length,
|
byte_code, byte_code_length, nullptr, &handle_);
|
||||||
nullptr,
|
|
||||||
&handle_);
|
|
||||||
if (FAILED(hr)) {
|
if (FAILED(hr)) {
|
||||||
XELOGE("D3D11: failed to create vertex shader");
|
XELOGE("D3D11: failed to create vertex shader");
|
||||||
xe_free(byte_code);
|
free(byte_code);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create input layout.
|
// Create input layout.
|
||||||
ret = CreateInputLayout(byte_code, byte_code_length);
|
ret = CreateInputLayout(byte_code, byte_code_length);
|
||||||
xe_free(byte_code);
|
free(byte_code);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -174,9 +171,8 @@ int D3D11VertexShaderResource::CreateInputLayout(const void* byte_code,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
D3D11_INPUT_ELEMENT_DESC* element_descs =
|
D3D11_INPUT_ELEMENT_DESC* element_descs = (D3D11_INPUT_ELEMENT_DESC*)alloca(
|
||||||
(D3D11_INPUT_ELEMENT_DESC*)xe_alloca(
|
sizeof(D3D11_INPUT_ELEMENT_DESC) * element_count);
|
||||||
sizeof(D3D11_INPUT_ELEMENT_DESC) * element_count);
|
|
||||||
uint32_t el_index = 0;
|
uint32_t el_index = 0;
|
||||||
for (uint32_t n = 0; n < inputs.count; n++) {
|
for (uint32_t n = 0; n < inputs.count; n++) {
|
||||||
const auto& input = inputs.descs[n];
|
const auto& input = inputs.descs[n];
|
||||||
|
@ -327,7 +323,7 @@ D3D11PixelShaderResource::D3D11PixelShaderResource(
|
||||||
|
|
||||||
D3D11PixelShaderResource::~D3D11PixelShaderResource() {
|
D3D11PixelShaderResource::~D3D11PixelShaderResource() {
|
||||||
SafeRelease(handle_);
|
SafeRelease(handle_);
|
||||||
xe_free(translated_src_);
|
free(translated_src_);
|
||||||
}
|
}
|
||||||
|
|
||||||
int D3D11PixelShaderResource::Prepare(const xe_gpu_program_cntl_t& program_cntl,
|
int D3D11PixelShaderResource::Prepare(const xe_gpu_program_cntl_t& program_cntl,
|
||||||
|
@ -358,9 +354,8 @@ int D3D11PixelShaderResource::Prepare(const xe_gpu_program_cntl_t& program_cntl,
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
byte_code_length = shader_blob->GetBufferSize();
|
byte_code_length = shader_blob->GetBufferSize();
|
||||||
byte_code = xe_malloc(byte_code_length);
|
byte_code = malloc(byte_code_length);
|
||||||
xe_copy_struct(
|
memcpy(byte_code, shader_blob->GetBufferPointer(), byte_code_length);
|
||||||
byte_code, shader_blob->GetBufferPointer(), byte_code_length);
|
|
||||||
SafeRelease(shader_blob);
|
SafeRelease(shader_blob);
|
||||||
|
|
||||||
// Create shader.
|
// Create shader.
|
||||||
|
@ -370,11 +365,11 @@ int D3D11PixelShaderResource::Prepare(const xe_gpu_program_cntl_t& program_cntl,
|
||||||
&handle_);
|
&handle_);
|
||||||
if (FAILED(hr)) {
|
if (FAILED(hr)) {
|
||||||
XELOGE("D3D11: failed to create pixel shader");
|
XELOGE("D3D11: failed to create pixel shader");
|
||||||
xe_free(byte_code);
|
free(byte_code);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
xe_free(byte_code);
|
free(byte_code);
|
||||||
is_prepared_ = true;
|
is_prepared_ = true;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,8 +37,7 @@ D3D11TextureResource::~D3D11TextureResource() {
|
||||||
int D3D11TextureResource::CreateHandle() {
|
int D3D11TextureResource::CreateHandle() {
|
||||||
SCOPE_profile_cpu_f("gpu");
|
SCOPE_profile_cpu_f("gpu");
|
||||||
|
|
||||||
D3D11_SHADER_RESOURCE_VIEW_DESC srv_desc;
|
D3D11_SHADER_RESOURCE_VIEW_DESC srv_desc = {};
|
||||||
xe_zero_struct(&srv_desc, sizeof(srv_desc));
|
|
||||||
// TODO(benvanik): this may need to be typed on the fetch instruction (float/int/etc?)
|
// TODO(benvanik): this may need to be typed on the fetch instruction (float/int/etc?)
|
||||||
srv_desc.Format = info_.format;
|
srv_desc.Format = info_.format;
|
||||||
|
|
||||||
|
@ -94,8 +93,7 @@ int D3D11TextureResource::CreateHandle() {
|
||||||
int D3D11TextureResource::CreateHandle1D() {
|
int D3D11TextureResource::CreateHandle1D() {
|
||||||
uint32_t width = 1 + info_.size_1d.width;
|
uint32_t width = 1 + info_.size_1d.width;
|
||||||
|
|
||||||
D3D11_TEXTURE1D_DESC texture_desc;
|
D3D11_TEXTURE1D_DESC texture_desc = {};
|
||||||
xe_zero_struct(&texture_desc, sizeof(texture_desc));
|
|
||||||
texture_desc.Width = width;
|
texture_desc.Width = width;
|
||||||
texture_desc.MipLevels = 1;
|
texture_desc.MipLevels = 1;
|
||||||
texture_desc.ArraySize = 1;
|
texture_desc.ArraySize = 1;
|
||||||
|
@ -113,8 +111,7 @@ int D3D11TextureResource::CreateHandle1D() {
|
||||||
}
|
}
|
||||||
|
|
||||||
int D3D11TextureResource::CreateHandle2D() {
|
int D3D11TextureResource::CreateHandle2D() {
|
||||||
D3D11_TEXTURE2D_DESC texture_desc;
|
D3D11_TEXTURE2D_DESC texture_desc = {};
|
||||||
xe_zero_struct(&texture_desc, sizeof(texture_desc));
|
|
||||||
texture_desc.Width = info_.size_2d.output_width;
|
texture_desc.Width = info_.size_2d.output_width;
|
||||||
texture_desc.Height = info_.size_2d.output_height;
|
texture_desc.Height = info_.size_2d.output_height;
|
||||||
texture_desc.MipLevels = 1;
|
texture_desc.MipLevels = 1;
|
||||||
|
|
|
@ -57,8 +57,7 @@ int D3D11Window::Initialize(const std::wstring& title, uint32_t width,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Setup swap chain.
|
// Setup swap chain.
|
||||||
DXGI_SWAP_CHAIN_DESC desc;
|
DXGI_SWAP_CHAIN_DESC desc = {};
|
||||||
xe_zero_struct(&desc, sizeof(desc));
|
|
||||||
desc.OutputWindow = handle();
|
desc.OutputWindow = handle();
|
||||||
desc.Windowed = TRUE;
|
desc.Windowed = TRUE;
|
||||||
desc.SwapEffect = DXGI_SWAP_EFFECT_FLIP_SEQUENTIAL;
|
desc.SwapEffect = DXGI_SWAP_EFFECT_FLIP_SEQUENTIAL;
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include <xenia/hid/hid.h>
|
#include <xenia/hid/hid.h>
|
||||||
#include <xenia/hid/hid-private.h>
|
#include <xenia/hid/hid-private.h>
|
||||||
|
#include <xenia/hid/input_driver.h>
|
||||||
|
|
||||||
using namespace xe;
|
using namespace xe;
|
||||||
using namespace xe::hid;
|
using namespace xe::hid;
|
||||||
|
|
|
@ -19,12 +19,7 @@ namespace hid {
|
||||||
InputSystem::InputSystem(Emulator* emulator)
|
InputSystem::InputSystem(Emulator* emulator)
|
||||||
: emulator_(emulator), memory_(emulator->memory()) {}
|
: emulator_(emulator), memory_(emulator->memory()) {}
|
||||||
|
|
||||||
InputSystem::~InputSystem() {
|
InputSystem::~InputSystem() = default;
|
||||||
for (auto it = drivers_.begin(); it != drivers_.end(); ++it) {
|
|
||||||
InputDriver* driver = *it;
|
|
||||||
delete driver;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
X_STATUS InputSystem::Setup() {
|
X_STATUS InputSystem::Setup() {
|
||||||
processor_ = emulator_->processor();
|
processor_ = emulator_->processor();
|
||||||
|
@ -32,14 +27,15 @@ X_STATUS InputSystem::Setup() {
|
||||||
return X_STATUS_SUCCESS;
|
return X_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputSystem::AddDriver(InputDriver* driver) { drivers_.push_back(driver); }
|
void InputSystem::AddDriver(std::unique_ptr<InputDriver> driver) {
|
||||||
|
drivers_.push_back(std::move(driver));
|
||||||
|
}
|
||||||
|
|
||||||
X_RESULT InputSystem::GetCapabilities(uint32_t user_index, uint32_t flags,
|
X_RESULT InputSystem::GetCapabilities(uint32_t user_index, uint32_t flags,
|
||||||
X_INPUT_CAPABILITIES* out_caps) {
|
X_INPUT_CAPABILITIES* out_caps) {
|
||||||
SCOPE_profile_cpu_f("hid");
|
SCOPE_profile_cpu_f("hid");
|
||||||
|
|
||||||
for (auto it = drivers_.begin(); it != drivers_.end(); ++it) {
|
for (auto& driver : drivers_) {
|
||||||
InputDriver* driver = *it;
|
|
||||||
if (XSUCCEEDED(driver->GetCapabilities(user_index, flags, out_caps))) {
|
if (XSUCCEEDED(driver->GetCapabilities(user_index, flags, out_caps))) {
|
||||||
return X_ERROR_SUCCESS;
|
return X_ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -50,8 +46,7 @@ X_RESULT InputSystem::GetCapabilities(uint32_t user_index, uint32_t flags,
|
||||||
X_RESULT InputSystem::GetState(uint32_t user_index, X_INPUT_STATE* out_state) {
|
X_RESULT InputSystem::GetState(uint32_t user_index, X_INPUT_STATE* out_state) {
|
||||||
SCOPE_profile_cpu_f("hid");
|
SCOPE_profile_cpu_f("hid");
|
||||||
|
|
||||||
for (auto it = drivers_.begin(); it != drivers_.end(); ++it) {
|
for (auto& driver : drivers_) {
|
||||||
InputDriver* driver = *it;
|
|
||||||
if (driver->GetState(user_index, out_state) == X_ERROR_SUCCESS) {
|
if (driver->GetState(user_index, out_state) == X_ERROR_SUCCESS) {
|
||||||
return X_ERROR_SUCCESS;
|
return X_ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -63,8 +58,7 @@ X_RESULT InputSystem::SetState(uint32_t user_index,
|
||||||
X_INPUT_VIBRATION* vibration) {
|
X_INPUT_VIBRATION* vibration) {
|
||||||
SCOPE_profile_cpu_f("hid");
|
SCOPE_profile_cpu_f("hid");
|
||||||
|
|
||||||
for (auto it = drivers_.begin(); it != drivers_.end(); ++it) {
|
for (auto& driver : drivers_) {
|
||||||
InputDriver* driver = *it;
|
|
||||||
if (XSUCCEEDED(driver->SetState(user_index, vibration))) {
|
if (XSUCCEEDED(driver->SetState(user_index, vibration))) {
|
||||||
return X_ERROR_SUCCESS;
|
return X_ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -76,8 +70,7 @@ X_RESULT InputSystem::GetKeystroke(uint32_t user_index, uint32_t flags,
|
||||||
X_INPUT_KEYSTROKE* out_keystroke) {
|
X_INPUT_KEYSTROKE* out_keystroke) {
|
||||||
SCOPE_profile_cpu_f("hid");
|
SCOPE_profile_cpu_f("hid");
|
||||||
|
|
||||||
for (auto it = drivers_.begin(); it != drivers_.end(); ++it) {
|
for (auto& driver : drivers_) {
|
||||||
InputDriver* driver = *it;
|
|
||||||
if (XSUCCEEDED(driver->GetKeystroke(user_index, flags, out_keystroke))) {
|
if (XSUCCEEDED(driver->GetKeystroke(user_index, flags, out_keystroke))) {
|
||||||
return X_ERROR_SUCCESS;
|
return X_ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
#ifndef XENIA_HID_INPUT_SYSTEM_H_
|
#ifndef XENIA_HID_INPUT_SYSTEM_H_
|
||||||
#define XENIA_HID_INPUT_SYSTEM_H_
|
#define XENIA_HID_INPUT_SYSTEM_H_
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <xenia/core.h>
|
#include <xenia/core.h>
|
||||||
|
@ -32,7 +33,7 @@ class InputSystem {
|
||||||
|
|
||||||
X_STATUS Setup();
|
X_STATUS Setup();
|
||||||
|
|
||||||
void AddDriver(InputDriver* driver);
|
void AddDriver(std::unique_ptr<InputDriver> driver);
|
||||||
|
|
||||||
X_RESULT GetCapabilities(uint32_t user_index, uint32_t flags,
|
X_RESULT GetCapabilities(uint32_t user_index, uint32_t flags,
|
||||||
X_INPUT_CAPABILITIES* out_caps);
|
X_INPUT_CAPABILITIES* out_caps);
|
||||||
|
@ -46,7 +47,7 @@ class InputSystem {
|
||||||
Memory* memory_;
|
Memory* memory_;
|
||||||
cpu::Processor* processor_;
|
cpu::Processor* processor_;
|
||||||
|
|
||||||
std::vector<InputDriver*> drivers_;
|
std::vector<std::unique_ptr<InputDriver>> drivers_;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace hid
|
} // namespace hid
|
||||||
|
|
|
@ -23,7 +23,7 @@ DiscImageFile::DiscImageFile(KernelState* kernel_state, Mode mode,
|
||||||
DiscImageEntry* entry)
|
DiscImageEntry* entry)
|
||||||
: XFile(kernel_state, mode), entry_(entry) {}
|
: XFile(kernel_state, mode), entry_(entry) {}
|
||||||
|
|
||||||
DiscImageFile::~DiscImageFile() {}
|
DiscImageFile::~DiscImageFile() { delete entry_; }
|
||||||
|
|
||||||
const std::string& DiscImageFile::path() const { return entry_->path(); }
|
const std::string& DiscImageFile::path() const { return entry_->path(); }
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,10 @@ HostPathFile::HostPathFile(KernelState* kernel_state, Mode mode,
|
||||||
file_handle_(file_handle),
|
file_handle_(file_handle),
|
||||||
XFile(kernel_state, mode) {}
|
XFile(kernel_state, mode) {}
|
||||||
|
|
||||||
HostPathFile::~HostPathFile() { CloseHandle(file_handle_); }
|
HostPathFile::~HostPathFile() {
|
||||||
|
CloseHandle(file_handle_);
|
||||||
|
delete entry_;
|
||||||
|
}
|
||||||
|
|
||||||
const std::string& HostPathFile::path() const { return entry_->path(); }
|
const std::string& HostPathFile::path() const { return entry_->path(); }
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ STFSContainerFile::STFSContainerFile(KernelState* kernel_state, Mode mode,
|
||||||
STFSContainerEntry* entry)
|
STFSContainerEntry* entry)
|
||||||
: entry_(entry), XFile(kernel_state, mode) {}
|
: entry_(entry), XFile(kernel_state, mode) {}
|
||||||
|
|
||||||
STFSContainerFile::~STFSContainerFile() {}
|
STFSContainerFile::~STFSContainerFile() { delete entry_; }
|
||||||
|
|
||||||
const std::string& STFSContainerFile::path() const { return entry_->path(); }
|
const std::string& STFSContainerFile::path() const { return entry_->path(); }
|
||||||
|
|
||||||
|
|
|
@ -176,6 +176,16 @@ std::unique_ptr<Entry> FileSystem::ResolvePath(const std::string& path) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
X_STATUS FileSystem::Open(std::unique_ptr<Entry> entry,
|
||||||
|
KernelState* kernel_state, Mode mode, bool async,
|
||||||
|
XFile** out_file) {
|
||||||
|
auto result = entry->Open(kernel_state, mode, async, out_file);
|
||||||
|
if (XSUCCEEDED(result)) {
|
||||||
|
entry.release();
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace fs
|
} // namespace fs
|
||||||
} // namespace kernel
|
} // namespace kernel
|
||||||
} // namespace xe
|
} // namespace xe
|
||||||
|
|
|
@ -52,6 +52,8 @@ class FileSystem {
|
||||||
int DeleteSymbolicLink(const std::string& path);
|
int DeleteSymbolicLink(const std::string& path);
|
||||||
|
|
||||||
std::unique_ptr<Entry> ResolvePath(const std::string& path);
|
std::unique_ptr<Entry> ResolvePath(const std::string& path);
|
||||||
|
X_STATUS Open(std::unique_ptr<Entry> entry, KernelState* kernel_state,
|
||||||
|
Mode mode, bool async, XFile** out_file);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::vector<Device*> devices_;
|
std::vector<Device*> devices_;
|
||||||
|
|
|
@ -62,7 +62,8 @@ X_STATUS XUserModule::LoadFromFile(const char* path) {
|
||||||
std::vector<uint8_t> buffer(file_info.file_length);
|
std::vector<uint8_t> buffer(file_info.file_length);
|
||||||
|
|
||||||
// Open file for reading.
|
// Open file for reading.
|
||||||
result = fs_entry->Open(kernel_state(), fs::Mode::READ, false, &file);
|
result = kernel_state()->file_system()->Open(
|
||||||
|
std::move(fs_entry), kernel_state(), fs::Mode::READ, false, &file);
|
||||||
XEEXPECTZERO(result);
|
XEEXPECTZERO(result);
|
||||||
|
|
||||||
// Read entire file into memory.
|
// Read entire file into memory.
|
||||||
|
|
|
@ -105,9 +105,9 @@ SHIM_CALL NtCreateFile_shim(PPCContext* ppc_state, KernelState* state) {
|
||||||
XFile* file = NULL;
|
XFile* file = NULL;
|
||||||
if (entry && entry->type() == Entry::Type::FILE) {
|
if (entry && entry->type() == Entry::Type::FILE) {
|
||||||
// Open the file.
|
// Open the file.
|
||||||
result = entry->Open(state, mode,
|
result = fs->Open(std::move(entry), state, mode,
|
||||||
false, // TODO(benvanik): pick async mode, if needed.
|
false, // TODO(benvanik): pick async mode, if needed.
|
||||||
&file);
|
&file);
|
||||||
} else {
|
} else {
|
||||||
result = X_STATUS_NO_SUCH_FILE;
|
result = X_STATUS_NO_SUCH_FILE;
|
||||||
info = X_FILE_DOES_NOT_EXIST;
|
info = X_FILE_DOES_NOT_EXIST;
|
||||||
|
@ -173,9 +173,9 @@ SHIM_CALL NtOpenFile_shim(PPCContext* ppc_state, KernelState* state) {
|
||||||
XFile* file = NULL;
|
XFile* file = NULL;
|
||||||
if (entry && entry->type() == Entry::Type::FILE) {
|
if (entry && entry->type() == Entry::Type::FILE) {
|
||||||
// Open the file.
|
// Open the file.
|
||||||
result = entry->Open(state, mode,
|
result = fs->Open(std::move(entry), state, mode,
|
||||||
false, // TODO(benvanik): pick async mode, if needed.
|
false, // TODO(benvanik): pick async mode, if needed.
|
||||||
&file);
|
&file);
|
||||||
} else {
|
} else {
|
||||||
result = X_STATUS_NO_SUCH_FILE;
|
result = X_STATUS_NO_SUCH_FILE;
|
||||||
info = X_FILE_DOES_NOT_EXIST;
|
info = X_FILE_DOES_NOT_EXIST;
|
||||||
|
|
Loading…
Reference in New Issue