mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-25 20:21:12 +01:00
Fix C++ entry and tiny cleanup
This commit is contained in:
parent
113bfd059e
commit
342fee841f
@ -35,8 +35,8 @@ void thread_main(std::string rom_path, std::string pref_path, std::string log_pa
|
|||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT void JNICALL
|
JNIEXPORT void JNICALL
|
||||||
Java_emu_lightswitch_lightswitch_MainActivity_loadFile(JNIEnv *env, jobject instance, jstring rom_path_,
|
Java_emu_lightswitch_MainActivity_loadFile(JNIEnv *env, jobject instance, jstring rom_path_,
|
||||||
jstring pref_path_, jstring log_path_) {
|
jstring pref_path_, jstring log_path_) {
|
||||||
const char *rom_path = env->GetStringUTFChars(rom_path_, 0);
|
const char *rom_path = env->GetStringUTFChars(rom_path_, 0);
|
||||||
const char *pref_path = env->GetStringUTFChars(pref_path_, 0);
|
const char *pref_path = env->GetStringUTFChars(pref_path_, 0);
|
||||||
const char *log_path = env->GetStringUTFChars(log_path_, 0);
|
const char *log_path = env->GetStringUTFChars(log_path_, 0);
|
||||||
|
@ -34,28 +34,19 @@ namespace lightSwitch::hw {
|
|||||||
if (status == -1) throw std::runtime_error("Cannot resume process");
|
if (status == -1) throw std::runtime_error("Cannot resume process");
|
||||||
}
|
}
|
||||||
|
|
||||||
void bin(unsigned n) {
|
void Cpu::WriteBreakpoint(uint64_t address_, uint64_t size) {
|
||||||
unsigned i;
|
|
||||||
std::string s;
|
|
||||||
for (i = 1 << 31; i > 0; i = i / 2)
|
|
||||||
(n & i) ? s += "1" : s += "0";
|
|
||||||
s = s.substr(16);
|
|
||||||
syslog(LOG_WARNING, "%s", s.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
void Cpu::WriteBreakpoint(uint64_t &address_, uint64_t &size) {
|
|
||||||
auto address = (uint32_t *) address_;
|
auto address = (uint32_t *) address_;
|
||||||
for (uint64_t iter = 0; iter < size; iter++) {
|
for (uint64_t iter = 0; iter < size; iter++) {
|
||||||
auto instr_svc = reinterpret_cast<instr::svc *>(address + iter);
|
auto instr_svc = reinterpret_cast<instr::svc *>(address + iter);
|
||||||
auto instr_mrs = reinterpret_cast<instr::mrs *>(address + iter);
|
auto instr_mrs = reinterpret_cast<instr::mrs *>(address + iter);
|
||||||
if (instr_svc->verify()) {
|
if (instr_svc->verify()) {
|
||||||
// syslog(LOG_WARNING, "Found SVC call: 0x%X, At location 0x%X", instr_svc->value, ((uint64_t)address)+iter);
|
// syslog(LOG_WARNING, "Found SVC call: 0x%X, At location 0x%X", instr_svc->value, ((uint64_t)address)+iter);
|
||||||
instr::brk brk((uint16_t) instr_svc->value);
|
instr::brk brk(reinterpret_cast<uint16_t>(instr_svc->value));
|
||||||
address[iter] = *(uint32_t *) (&brk);
|
address[iter] = *reinterpret_cast<uint32_t *>(&brk);
|
||||||
} else if (instr_mrs->verify() && instr_mrs->Sreg == constant::tpidrro_el0) {
|
} else if (instr_mrs->verify() && instr_mrs->Sreg == constant::tpidrro_el0) {
|
||||||
// syslog(LOG_WARNING, "Found MRS call: 0x%X, At location 0x%X", instr_mrs->Xt, ((uint64_t)address)+iter);
|
// syslog(LOG_WARNING, "Found MRS call: 0x%X, At location 0x%X", instr_mrs->Xt, ((uint64_t)address)+iter);
|
||||||
instr::brk brk((uint16_t) (constant::svc_last + 1 + instr_mrs->Xt));
|
instr::brk brk(reinterpret_cast<uint16_t>(constant::svc_last + 1 + instr_mrs->Xt));
|
||||||
address[iter] = *(uint32_t *) (&brk);
|
address[iter] = *reinterpret_cast<uint32_t *>(&brk);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -75,7 +66,7 @@ namespace lightSwitch::hw {
|
|||||||
auto instr = reinterpret_cast<instr::brk *>(ReadMemory(regs.pc));
|
auto instr = reinterpret_cast<instr::brk *>(ReadMemory(regs.pc));
|
||||||
if (instr->verify()) {
|
if (instr->verify()) {
|
||||||
if (instr->value <= constant::svc_last) {
|
if (instr->value <= constant::svc_last) {
|
||||||
svc_handler((uint16_t) instr->value, device);
|
svc_handler(reinterpret_cast<uint16_t>(instr->value), device);
|
||||||
syslog(LOG_ERR, "SVC has been called 0x%X", instr->value);
|
syslog(LOG_ERR, "SVC has been called 0x%X", instr->value);
|
||||||
if (stop) break;
|
if (stop) break;
|
||||||
} else if (instr->value > constant::svc_last && instr->value <= constant::svc_last + constant::num_regs) {
|
} else if (instr->value > constant::svc_last && instr->value <= constant::svc_last + constant::num_regs) {
|
||||||
@ -116,10 +107,10 @@ namespace lightSwitch::hw {
|
|||||||
}
|
}
|
||||||
|
|
||||||
uint64_t Cpu::GetRegister(wreg reg_id) {
|
uint64_t Cpu::GetRegister(wreg reg_id) {
|
||||||
return ((uint32_t *) regs.regs)[wreg_lut[reg_id]];
|
return (reinterpret_cast<uint32_t *>(regs.regs))[wreg_lut[reg_id]];
|
||||||
}
|
}
|
||||||
|
|
||||||
void Cpu::SetRegister(wreg reg_id, uint32_t value) {
|
void Cpu::SetRegister(wreg reg_id, uint32_t value) {
|
||||||
((uint32_t *) regs.regs)[wreg_lut[reg_id]] = value;
|
(reinterpret_cast<uint32_t *>(regs.regs))[wreg_lut[reg_id]] = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -32,7 +32,7 @@ namespace lightSwitch::hw {
|
|||||||
|
|
||||||
void ResumeProcess();
|
void ResumeProcess();
|
||||||
|
|
||||||
void WriteBreakpoint(uint64_t &address, uint64_t &size);
|
void WriteBreakpoint(uint64_t address, uint64_t size);
|
||||||
|
|
||||||
uint8_t wreg_lut[31] = {1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, 33, 35, 37, 39, 41, 43, 45, 47, 49, 51, 53, 55, 57, 59, 61};
|
uint8_t wreg_lut[31] = {1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, 33, 35, 37, 39, 41, 43, 45, 47, 49, 51, 53, 55, 57, 59, 61};
|
||||||
|
|
||||||
|
@ -12,27 +12,27 @@ namespace lightSwitch::hw {
|
|||||||
void Memory::Map(uint64_t address, size_t size, Region region) {
|
void Memory::Map(uint64_t address, size_t size, Region region) {
|
||||||
void *ptr = mmap((void *) address, size, PROT_EXEC | PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANON | MAP_FIXED, 0, 0);
|
void *ptr = mmap((void *) address, size, PROT_EXEC | PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANON | MAP_FIXED, 0, 0);
|
||||||
if (ptr == MAP_FAILED)
|
if (ptr == MAP_FAILED)
|
||||||
throw exception("An occurred while mapping region at " + std::to_string(address));
|
throw exception("An occurred while mapping region: " + std::string(strerror(errno)));
|
||||||
region_map.insert(std::pair<Region, RegionData>(region, {address, size}));
|
region_map.insert(std::pair<Region, RegionData>(region, {address, size}));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Memory::Remap(Region region, size_t size) {
|
void Memory::Remap(Region region, size_t size) {
|
||||||
RegionData region_data = region_map.at(region);
|
RegionData region_data = region_map.at(region);
|
||||||
void *ptr = mremap((void *) region_data.address, region_data.size, size, 0);
|
void *ptr = mremap(reinterpret_cast<void *>(region_data.address), region_data.size, size, 0);
|
||||||
if (ptr == MAP_FAILED)
|
if (ptr == MAP_FAILED)
|
||||||
throw exception("An occurred while unmapping region: " + std::string(strerror(errno)));
|
throw exception("An occurred while remapping region: " + std::string(strerror(errno)));
|
||||||
region_map[region].size = size;
|
region_map[region].size = size;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Memory::Unmap(Region region) {
|
void Memory::Unmap(Region region) {
|
||||||
RegionData region_data = region_map.at(region);
|
RegionData region_data = region_map.at(region);
|
||||||
int err = munmap((void *) region_data.address, region_data.size);
|
int err = munmap(reinterpret_cast<void *>(region_data.address), region_data.size);
|
||||||
if (err == -1)
|
if (err == -1)
|
||||||
throw exception("An occurred while unmapping region: " + std::string(strerror(errno)));
|
throw exception("An occurred while unmapping region: " + std::string(strerror(errno)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Memory::Write(void *data, uint64_t offset, size_t size) {
|
void Memory::Write(void *data, uint64_t offset, size_t size) {
|
||||||
std::memcpy((void *) offset, data, size);
|
std::memcpy(reinterpret_cast<void *>(offset), data, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
@ -41,7 +41,7 @@ namespace lightSwitch::hw {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Memory::Read(void *destination, uint64_t offset, size_t size) {
|
void Memory::Read(void *destination, uint64_t offset, size_t size) {
|
||||||
std::memcpy(destination, (void *) (offset), size);
|
std::memcpy(destination, reinterpret_cast<void *>(offset), size);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user