Finishing unique_ptr'ing and fixing file memory management (for now).

This commit is contained in:
Ben Vanik 2014-08-21 07:54:19 -07:00
parent c59d053404
commit 08b0226a16
26 changed files with 152 additions and 175 deletions

View File

@ -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;

View File

@ -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);

View File

@ -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

View File

@ -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);
} }

View File

@ -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) {

View File

@ -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;
} }

View File

@ -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;

View File

@ -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;

View File

@ -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;
} }

View File

@ -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;

View File

@ -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 {

View File

@ -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);

View File

@ -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] = {
{ {

View File

@ -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;
} }

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;
} }

View File

@ -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

View File

@ -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(); }

View File

@ -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(); }

View File

@ -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(); }

View File

@ -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

View File

@ -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_;

View File

@ -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.

View File

@ -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;