mirror of
https://github.com/wheremyfoodat/Panda3DS.git
synced 2025-04-06 22:25:41 +12:00
Fix discrepancy between ConfigMem::BatteryLevel and PTM
This commit is contained in:
parent
51b2b8eee5
commit
5b24006046
4 changed files with 21 additions and 6 deletions
|
@ -5,9 +5,11 @@
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <optional>
|
#include <optional>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
#include "config.hpp"
|
||||||
#include "crypto/aes_engine.hpp"
|
#include "crypto/aes_engine.hpp"
|
||||||
#include "helpers.hpp"
|
|
||||||
#include "handles.hpp"
|
#include "handles.hpp"
|
||||||
|
#include "helpers.hpp"
|
||||||
#include "loader/ncsd.hpp"
|
#include "loader/ncsd.hpp"
|
||||||
#include "services/region_codes.hpp"
|
#include "services/region_codes.hpp"
|
||||||
#include "services/shared_font.hpp"
|
#include "services/shared_font.hpp"
|
||||||
|
@ -154,13 +156,14 @@ private:
|
||||||
static constexpr FirmwareInfo firm{.unk = 0, .revision = 0, .minor = 0x34, .major = 2, .syscoreVer = 2, .sdkVer = 0x0000F297};
|
static constexpr FirmwareInfo firm{.unk = 0, .revision = 0, .minor = 0x34, .major = 2, .syscoreVer = 2, .sdkVer = 0x0000F297};
|
||||||
// Adjusted upon loading a ROM based on the ROM header. Used by CFG::SecureInfoGetArea to get past region locks
|
// Adjusted upon loading a ROM based on the ROM header. Used by CFG::SecureInfoGetArea to get past region locks
|
||||||
Regions region = Regions::USA;
|
Regions region = Regions::USA;
|
||||||
|
const EmulatorConfig& config;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
u16 kernelVersion = 0;
|
u16 kernelVersion = 0;
|
||||||
u32 usedUserMemory = u32(0_MB); // How much of the APPLICATION FCRAM range is used (allocated to the appcore)
|
u32 usedUserMemory = u32(0_MB); // How much of the APPLICATION FCRAM range is used (allocated to the appcore)
|
||||||
u32 usedSystemMemory = u32(0_MB); // Similar for the SYSTEM range (reserved for the syscore)
|
u32 usedSystemMemory = u32(0_MB); // Similar for the SYSTEM range (reserved for the syscore)
|
||||||
|
|
||||||
Memory(u64& cpuTicks);
|
Memory(u64& cpuTicks, const EmulatorConfig& config);
|
||||||
void reset();
|
void reset();
|
||||||
void* getReadPointer(u32 address);
|
void* getReadPointer(u32 address);
|
||||||
void* getWritePointer(u32 address);
|
void* getWritePointer(u32 address);
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
#include "services/ssl.hpp"
|
#include "services/ssl.hpp"
|
||||||
#include "services/y2r.hpp"
|
#include "services/y2r.hpp"
|
||||||
|
|
||||||
class EmulatorConfig;
|
struct EmulatorConfig;
|
||||||
// More circular dependencies!!
|
// More circular dependencies!!
|
||||||
class Kernel;
|
class Kernel;
|
||||||
|
|
||||||
|
|
|
@ -6,10 +6,11 @@
|
||||||
|
|
||||||
#include "config_mem.hpp"
|
#include "config_mem.hpp"
|
||||||
#include "resource_limits.hpp"
|
#include "resource_limits.hpp"
|
||||||
|
#include "services/ptm.hpp"
|
||||||
|
|
||||||
using namespace KernelMemoryTypes;
|
using namespace KernelMemoryTypes;
|
||||||
|
|
||||||
Memory::Memory(u64& cpuTicks) : cpuTicks(cpuTicks) {
|
Memory::Memory(u64& cpuTicks, const EmulatorConfig& config) : cpuTicks(cpuTicks), config(config) {
|
||||||
fcram = new uint8_t[FCRAM_SIZE]();
|
fcram = new uint8_t[FCRAM_SIZE]();
|
||||||
dspRam = new uint8_t[DSP_RAM_SIZE]();
|
dspRam = new uint8_t[DSP_RAM_SIZE]();
|
||||||
|
|
||||||
|
@ -85,7 +86,18 @@ u8 Memory::read8(u32 vaddr) {
|
||||||
return *(u8*)(pointer + offset);
|
return *(u8*)(pointer + offset);
|
||||||
} else {
|
} else {
|
||||||
switch (vaddr) {
|
switch (vaddr) {
|
||||||
case ConfigMem::BatteryState: return getBatteryState(true, true, BatteryLevel::FourBars);
|
case ConfigMem::BatteryState: {
|
||||||
|
// Set by the PTM module
|
||||||
|
// Charger plugged: Shows whether the charger is plugged
|
||||||
|
// Charging: Shows whether the charger is plugged and the console is actually charging, ie the battery is not full
|
||||||
|
// BatteryLevel: A battery level calculated via PTM::GetBatteryLevel
|
||||||
|
// These are all assembled into a bitfield and returned via config memory
|
||||||
|
const bool chargerPlugged = config.chargerPlugged;
|
||||||
|
const bool charging = config.chargerPlugged && (config.batteryPercentage < 100);
|
||||||
|
const auto batteryLevel = static_cast<BatteryLevel>(PTMService::batteryPercentToLevel(config.batteryPercentage));
|
||||||
|
|
||||||
|
return getBatteryState(chargerPlugged, charging, batteryLevel);
|
||||||
|
}
|
||||||
case ConfigMem::EnvInfo: return envInfo;
|
case ConfigMem::EnvInfo: return envInfo;
|
||||||
case ConfigMem::HardwareType: return ConfigMem::HardwareCodes::Product;
|
case ConfigMem::HardwareType: return ConfigMem::HardwareCodes::Product;
|
||||||
case ConfigMem::KernelVersionMinor: return u8(kernelVersion & 0xff);
|
case ConfigMem::KernelVersionMinor: return u8(kernelVersion & 0xff);
|
||||||
|
|
|
@ -13,7 +13,7 @@ __declspec(dllexport) DWORD AmdPowerXpressRequestHighPerformance = 1;
|
||||||
|
|
||||||
Emulator::Emulator()
|
Emulator::Emulator()
|
||||||
: config(std::filesystem::current_path() / "config.toml"), kernel(cpu, memory, gpu, config), cpu(memory, kernel), gpu(memory, config),
|
: config(std::filesystem::current_path() / "config.toml"), kernel(cpu, memory, gpu, config), cpu(memory, kernel), gpu(memory, config),
|
||||||
memory(cpu.getTicksRef()), cheats(memory, kernel.getServiceManager().getHID()), running(false), programRunning(false)
|
memory(cpu.getTicksRef(), config), cheats(memory, kernel.getServiceManager().getHID()), running(false), programRunning(false)
|
||||||
#ifdef PANDA3DS_ENABLE_HTTP_SERVER
|
#ifdef PANDA3DS_ENABLE_HTTP_SERVER
|
||||||
, httpServer(this)
|
, httpServer(this)
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Add table
Reference in a new issue