Making xenia-test run on Windows.

This commit is contained in:
Ben Vanik 2013-05-25 05:20:28 -07:00
parent edb3aabdd4
commit bd8376e231
3 changed files with 64 additions and 13 deletions

View File

@ -100,7 +100,7 @@ int Processor::Setup() {
int Processor::LoadRawBinary(const xechar_t* path, uint32_t start_address) { int Processor::LoadRawBinary(const xechar_t* path, uint32_t start_address) {
ExecModule* exec_module = NULL; ExecModule* exec_module = NULL;
const xechar_t* name = xestrrchr(path, '/') + 1; const xechar_t* name = xestrrchr(path, XE_PATH_SEPARATOR) + 1;
// TODO(benvanik): map file from filesystem API, not via platform API. // TODO(benvanik): map file from filesystem API, not via platform API.
xe_mmap_ref mmap = xe_mmap_open(kXEFileModeRead, path, 0, 0); xe_mmap_ref mmap = xe_mmap_open(kXEFileModeRead, path, 0, 0);

View File

@ -36,8 +36,6 @@ X64JIT::~X64JIT() {
int X64JIT::Setup() { int X64JIT::Setup() {
int result_code = 1; int result_code = 1;
XELOGCPU("Initializing x64 JIT backend...");
// Check processor for support. // Check processor for support.
result_code = CheckProcessor(); result_code = CheckProcessor();
if (result_code) { if (result_code) {
@ -97,6 +95,8 @@ static const BitDescription x86Features[] = {
int X64JIT::CheckProcessor() { int X64JIT::CheckProcessor() {
const CpuInfo* cpu = CpuInfo::getGlobal(); const CpuInfo* cpu = CpuInfo::getGlobal();
const X86CpuInfo* x86Cpu = static_cast<const X86CpuInfo*>(cpu); const X86CpuInfo* x86Cpu = static_cast<const X86CpuInfo*>(cpu);
#if 0
XELOGCPU("Processor Info:"); XELOGCPU("Processor Info:");
XELOGCPU(" Vendor string : %s", cpu->getVendorString()); XELOGCPU(" Vendor string : %s", cpu->getVendorString());
XELOGCPU(" Brand string : %s", cpu->getBrandString()); XELOGCPU(" Brand string : %s", cpu->getBrandString());
@ -118,6 +118,7 @@ int X64JIT::CheckProcessor() {
XELOGCPU(" %s", d->description); XELOGCPU(" %s", d->description);
} }
} }
#endif
// TODO(benvanik): ensure features we want are supported. // TODO(benvanik): ensure features we want are supported.

View File

@ -9,7 +9,9 @@
#include <xenia/xenia.h> #include <xenia/xenia.h>
#if !XE_LIKE(WIN32)
#include <dirent.h> #include <dirent.h>
#endif // !WIN32
#include <gflags/gflags.h> #include <gflags/gflags.h>
@ -19,8 +21,13 @@ using namespace xe::cpu;
using namespace xe::kernel; using namespace xe::kernel;
#if XE_LIKE(WIN32)
DEFINE_string(test_path, "test\\codegen\\",
"Directory scanned for test files.");
#else
DEFINE_string(test_path, "test/codegen/", DEFINE_string(test_path, "test/codegen/",
"Directory scanned for test files."); "Directory scanned for test files.");
#endif // WIN32
typedef vector<pair<string, string> > annotations_list_t; typedef vector<pair<string, string> > annotations_list_t;
@ -115,12 +122,13 @@ int run_test(string& src_file_path) {
XEEXPECTZERO(read_annotations(src_file_path, annotations)); XEEXPECTZERO(read_annotations(src_file_path, annotations));
xe_memory_options_t memory_options; while (!memory) {
xe_zero_struct(&memory_options, sizeof(memory_options)); xe_memory_options_t memory_options;
memory = xe_memory_create(memory_options); xe_zero_struct(&memory_options, sizeof(memory_options));
XEEXPECTNOTNULL(memory); memory = xe_memory_create(memory_options);
}
backend_ = shared_ptr<Backend>(new xe::cpu::x64::X64Backend()); backend = shared_ptr<Backend>(new xe::cpu::x64::X64Backend());
processor = shared_ptr<Processor>(new Processor(memory, backend)); processor = shared_ptr<Processor>(new Processor(memory, backend));
XEEXPECTZERO(processor->Setup()); XEEXPECTZERO(processor->Setup());
@ -128,7 +136,14 @@ int run_test(string& src_file_path) {
runtime = shared_ptr<Runtime>(new Runtime(processor, XT(""))); runtime = shared_ptr<Runtime>(new Runtime(processor, XT("")));
// Load the binary module. // Load the binary module.
XEEXPECTZERO(processor->LoadRawBinary(bin_file_path.c_str(), 0x82010000)); #if XE_WCHAR
xechar_t bin_file_path_str[XE_MAX_PATH];
XEEXPECTTRUE(xestrwiden(bin_file_path_str, XECOUNT(bin_file_path_str),
bin_file_path.c_str()));
#else
const xechar_t* bin_file_path_str = bin_file_path.c_str();
#endif // XE_CHAR
XEEXPECTZERO(processor->LoadRawBinary(bin_file_path_str, 0x82010000));
// Simulate a thread. // Simulate a thread.
thread_state = processor->AllocThread(256 * 1024, 0); thread_state = processor->AllocThread(256 * 1024, 0);
@ -157,7 +172,29 @@ XECLEANUP:
int discover_tests(string& test_path, int discover_tests(string& test_path,
vector<string>& test_files) { vector<string>& test_files) {
// TODO(benvanik): use PAL instead of this // TODO(benvanik): use PAL instead of this.
#if XE_LIKE(WIN32)
string search_path = test_path;
search_path.append("\\*.s");
WIN32_FIND_DATAA ffd;
HANDLE hFind = FindFirstFileA(search_path.c_str(), &ffd);
if (hFind == INVALID_HANDLE_VALUE) {
XELOGE("Unable to find test path %s", test_path.c_str());
return 1;
}
do {
if (!(ffd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)) {
string file_name = string(ffd.cFileName);
string file_path = test_path;
if (*(test_path.end() - 1) != '\\') {
file_path += "\\";
}
file_path += file_name;
test_files.push_back(file_path);
}
} while (FindNextFileA(hFind, &ffd));
FindClose(hFind);
#else
DIR* d = opendir(test_path.c_str()); DIR* d = opendir(test_path.c_str());
if (!d) { if (!d) {
XELOGE("Unable to find test path %s", test_path.c_str()); XELOGE("Unable to find test path %s", test_path.c_str());
@ -179,10 +216,11 @@ int discover_tests(string& test_path,
} }
} }
closedir(d); closedir(d);
#endif // WIN32
return 0; return 0;
} }
int run_tests(const xechar_t* test_name) { int run_tests(std::string& test_name) {
int result_code = 1; int result_code = 1;
int failed_count = 0; int failed_count = 0;
int passed_count = 0; int passed_count = 0;
@ -203,7 +241,7 @@ int run_tests(const xechar_t* test_name) {
for (vector<string>::iterator it = test_files.begin(); for (vector<string>::iterator it = test_files.begin();
it != test_files.end(); ++it) { it != test_files.end(); ++it) {
if (test_name && *it != test_name) { if (test_name.length() && *it != test_name) {
continue; continue;
} }
@ -235,8 +273,20 @@ int xenia_test(int argc, xechar_t **argv) {
if (argc >= 2) { if (argc >= 2) {
test_name = argv[1]; test_name = argv[1];
} }
string test_name_str;
if (test_name) {
#if XE_WCHAR
char test_name_buffer[XE_MAX_PATH];
XEIGNORE(xestrnarrow(test_name_buffer, XECOUNT(test_name_buffer),
test_name));
test_name_str = test_name_buffer;
#else
test_name_str = test_name;
#endif // XE_WCHAR
}
result_code = run_tests(test_name); result_code = run_tests(test_name_str);
return result_code; return result_code;
} }