diff options
| -rw-r--r-- | src/core/hle/service/ac_u.cpp | 20 | ||||
| -rw-r--r-- | src/core/hle/service/dsp_dsp.cpp | 69 | ||||
| -rw-r--r-- | src/core/hle/service/ptm_u.cpp | 94 | ||||
| -rw-r--r-- | src/core/mem_map.h | 4 | ||||
| -rw-r--r-- | src/video_core/command_processor.cpp | 2 | ||||
| -rw-r--r-- | src/video_core/debug_utils/debug_utils.cpp | 8 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/renderer_opengl.cpp | 2 | 
7 files changed, 162 insertions, 37 deletions
| diff --git a/src/core/hle/service/ac_u.cpp b/src/core/hle/service/ac_u.cpp index 9af96f6b8..46aee40d6 100644 --- a/src/core/hle/service/ac_u.cpp +++ b/src/core/hle/service/ac_u.cpp @@ -11,6 +11,24 @@  namespace AC_U { +/** + * AC_U::GetWifiStatus service function + *  Outputs: + *      1 : Result of function, 0 on success, otherwise error code + *      2 : Output connection type, 0 = none, 1 = Old3DS Internet, 2 = New3DS Internet. + */ +void GetWifiStatus(Service::Interface* self) { +    u32* cmd_buff = Service::GetCommandBuffer(); + +    // TODO(purpasmart96): This function is only a stub, +    // it returns a valid result without implementing full functionality. + +    cmd_buff[1] = 0; // No error +    cmd_buff[2] = 0; // Connection type set to none + +    WARN_LOG(KERNEL, "(STUBBED) called"); +} +  const Interface::FunctionInfo FunctionTable[] = {      {0x00010000, nullptr,               "CreateDefaultConfig"},      {0x00040006, nullptr,               "ConnectAsync"}, @@ -18,7 +36,7 @@ const Interface::FunctionInfo FunctionTable[] = {      {0x00080004, nullptr,               "CloseAsync"},      {0x00090002, nullptr,               "GetCloseResult"},      {0x000A0000, nullptr,               "GetLastErrorCode"}, -    {0x000D0000, nullptr,               "GetWifiStatus"}, +    {0x000D0000, GetWifiStatus,         "GetWifiStatus"},      {0x000E0042, nullptr,               "GetCurrentAPInfo"},      {0x00100042, nullptr,               "GetCurrentNZoneInfo"},      {0x00110042, nullptr,               "GetNZoneApNumService"}, diff --git a/src/core/hle/service/dsp_dsp.cpp b/src/core/hle/service/dsp_dsp.cpp index a2b68cac8..72be4c817 100644 --- a/src/core/hle/service/dsp_dsp.cpp +++ b/src/core/hle/service/dsp_dsp.cpp @@ -16,6 +16,25 @@ static Handle semaphore_event;  static Handle interrupt_event;  /** + * DSP_DSP::ConvertProcessAddressFromDspDram service function + *  Inputs: + *      1 : Address + *  Outputs: + *      1 : Result of function, 0 on success, otherwise error code + *      2 : (inaddr << 1) + 0x1FF40000 (where 0x1FF00000 is the DSP RAM address) + */ +void ConvertProcessAddressFromDspDram(Service::Interface* self) { +    u32* cmd_buff = Service::GetCommandBuffer(); + +    u32 addr = cmd_buff[1]; + +    cmd_buff[1] = 0; // No error +    cmd_buff[2] = (addr << 1) + (Memory::DSP_MEMORY_VADDR + 0x40000); + +    DEBUG_LOG(KERNEL, "(STUBBED) called with address %u", addr); +} + +/**   * DSP_DSP::LoadComponent service function   *  Inputs:   *      1 : Size @@ -90,31 +109,31 @@ void WriteReg0x10(Service::Interface* self) {  }  const Interface::FunctionInfo FunctionTable[] = { -    {0x00010040, nullptr,                 "RecvData"}, -    {0x00020040, nullptr,                 "RecvDataIsReady"}, -    {0x00030080, nullptr,                 "SendData"}, -    {0x00040040, nullptr,                 "SendDataIsEmpty"}, -    {0x00070040, WriteReg0x10,            "WriteReg0x10"}, -    {0x00080000, nullptr,                 "GetSemaphore"}, -    {0x00090040, nullptr,                 "ClearSemaphore"}, -    {0x000B0000, nullptr,                 "CheckSemaphoreRequest"}, -    {0x000C0040, nullptr,                 "ConvertProcessAddressFromDspDram"}, -    {0x000D0082, nullptr,                 "WriteProcessPipe"}, -    {0x001000C0, nullptr,                 "ReadPipeIfPossible"}, -    {0x001100C2, LoadComponent,           "LoadComponent"}, -    {0x00120000, nullptr,                 "UnloadComponent"}, -    {0x00130082, nullptr,                 "FlushDataCache"}, -    {0x00140082, nullptr,                 "InvalidateDCache"}, -    {0x00150082, RegisterInterruptEvents, "RegisterInterruptEvents"}, -    {0x00160000, GetSemaphoreEventHandle, "GetSemaphoreEventHandle"}, -    {0x00170040, nullptr,                 "SetSemaphoreMask"}, -    {0x00180040, nullptr,                 "GetPhysicalAddress"}, -    {0x00190040, nullptr,                 "GetVirtualAddress"}, -    {0x001A0042, nullptr,                 "SetIirFilterI2S1_cmd1"}, -    {0x001B0042, nullptr,                 "SetIirFilterI2S1_cmd2"}, -    {0x001C0082, nullptr,                 "SetIirFilterEQ"}, -    {0x001F0000, nullptr,                 "GetHeadphoneStatus"}, -    {0x00210000, nullptr,                 "GetIsDspOccupied"}, +    {0x00010040, nullptr,                          "RecvData"}, +    {0x00020040, nullptr,                          "RecvDataIsReady"}, +    {0x00030080, nullptr,                          "SendData"}, +    {0x00040040, nullptr,                          "SendDataIsEmpty"}, +    {0x00070040, WriteReg0x10,                     "WriteReg0x10"}, +    {0x00080000, nullptr,                          "GetSemaphore"}, +    {0x00090040, nullptr,                          "ClearSemaphore"}, +    {0x000B0000, nullptr,                          "CheckSemaphoreRequest"}, +    {0x000C0040, ConvertProcessAddressFromDspDram, "ConvertProcessAddressFromDspDram"}, +    {0x000D0082, nullptr,                          "WriteProcessPipe"}, +    {0x001000C0, nullptr,                          "ReadPipeIfPossible"}, +    {0x001100C2, LoadComponent,                    "LoadComponent"}, +    {0x00120000, nullptr,                          "UnloadComponent"}, +    {0x00130082, nullptr,                          "FlushDataCache"}, +    {0x00140082, nullptr,                          "InvalidateDCache"}, +    {0x00150082, RegisterInterruptEvents,          "RegisterInterruptEvents"}, +    {0x00160000, GetSemaphoreEventHandle,          "GetSemaphoreEventHandle"}, +    {0x00170040, nullptr,                          "SetSemaphoreMask"}, +    {0x00180040, nullptr,                          "GetPhysicalAddress"}, +    {0x00190040, nullptr,                          "GetVirtualAddress"}, +    {0x001A0042, nullptr,                          "SetIirFilterI2S1_cmd1"}, +    {0x001B0042, nullptr,                          "SetIirFilterI2S1_cmd2"}, +    {0x001C0082, nullptr,                          "SetIirFilterEQ"}, +    {0x001F0000, nullptr,                          "GetHeadphoneStatus"}, +    {0x00210000, nullptr,                          "GetIsDspOccupied"},  };  //////////////////////////////////////////////////////////////////////////////////////////////////// diff --git a/src/core/hle/service/ptm_u.cpp b/src/core/hle/service/ptm_u.cpp index d9122dbbc..941df467b 100644 --- a/src/core/hle/service/ptm_u.cpp +++ b/src/core/hle/service/ptm_u.cpp @@ -11,15 +11,101 @@  namespace PTM_U { +/// Charge levels used by PTM functions +enum class ChargeLevels : u32 { +    CriticalBattery    = 1, +    LowBattery         = 2, +    HalfFull           = 3, +    MostlyFull         = 4, +    CompletelyFull     = 5, +}; + +static bool shell_open = true; + +static bool battery_is_charging = true; + +/** + * It is unknown if GetAdapterState is the same as GetBatteryChargeState, + * it is likely to just be a duplicate function of GetBatteryChargeState + * that controls another part of the HW. + * PTM_U::GetAdapterState service function + *  Outputs: + *      1 : Result of function, 0 on success, otherwise error code + *      2 : Output of function, 0 = not charging, 1 = charging. + */ +static void GetAdapterState(Service::Interface* self) { +    u32* cmd_buff = Service::GetCommandBuffer(); + +    // TODO(purpasmart96): This function is only a stub, +    // it returns a valid result without implementing full functionality. + +    cmd_buff[1] = 0; // No error +    cmd_buff[2] = battery_is_charging ? 1 : 0; + +    WARN_LOG(KERNEL, "(STUBBED) called"); +} + +/* + * PTM_User::GetShellState service function. + *  Outputs: + *      1 : Result of function, 0 on success, otherwise error code + *      2 : Whether the 3DS's physical shell casing is open (1) or closed (0) + */ +static void GetShellState(Service::Interface* self) { +    u32* cmd_buff = Service::GetCommandBuffer(); + +    cmd_buff[1] = 0; +    cmd_buff[2] = shell_open ? 1 : 0; + +    DEBUG_LOG(KERNEL, "PTM_U::GetShellState called"); +} + +/** + * PTM_U::GetBatteryLevel service function + *  Outputs: + *      1 : Result of function, 0 on success, otherwise error code + *      2 : Battery level, 5 = completely full battery, 4 = mostly full battery, + *          3 = half full battery, 2 =  low battery, 1 = critical battery. + */ +static void GetBatteryLevel(Service::Interface* self) { +    u32* cmd_buff = Service::GetCommandBuffer(); + +    // TODO(purpasmart96): This function is only a stub, +    // it returns a valid result without implementing full functionality. + +    cmd_buff[1] = 0; // No error +    cmd_buff[2] = static_cast<u32>(ChargeLevels::CompletelyFull); // Set to a completely full battery + +    WARN_LOG(KERNEL, "(STUBBED) called"); +} + +/** + * PTM_U::GetBatteryChargeState service function + *  Outputs: + *      1 : Result of function, 0 on success, otherwise error code + *      2 : Output of function, 0 = not charging, 1 = charging. + */ +static void GetBatteryChargeState(Service::Interface* self) { +    u32* cmd_buff = Service::GetCommandBuffer(); + +    // TODO(purpasmart96): This function is only a stub, +    // it returns a valid result without implementing full functionality. + +    cmd_buff[1] = 0; // No error +    cmd_buff[2] = battery_is_charging ? 1 : 0; + +    WARN_LOG(KERNEL, "(STUBBED) called"); +} +  const Interface::FunctionInfo FunctionTable[] = {      {0x00010002, nullptr,               "RegisterAlarmClient"},      {0x00020080, nullptr,               "SetRtcAlarm"},      {0x00030000, nullptr,               "GetRtcAlarm"},      {0x00040000, nullptr,               "CancelRtcAlarm"}, -    {0x00050000, nullptr,               "GetAdapterState"}, -    {0x00060000, nullptr,               "GetShellState"}, -    {0x00070000, nullptr,               "GetBatteryLevel"}, -    {0x00080000, nullptr,               "GetBatteryChargeState"}, +    {0x00050000, GetAdapterState,       "GetAdapterState"}, +    {0x00060000, GetShellState,         "GetShellState"}, +    {0x00070000, GetBatteryLevel,       "GetBatteryLevel"}, +    {0x00080000, GetBatteryChargeState, "GetBatteryChargeState"},      {0x00090000, nullptr,               "GetPedometerState"},      {0x000A0042, nullptr,               "GetStepHistoryEntry"},      {0x000B00C2, nullptr,               "GetStepHistory"}, diff --git a/src/core/mem_map.h b/src/core/mem_map.h index a58c59244..da440325f 100644 --- a/src/core/mem_map.h +++ b/src/core/mem_map.h @@ -19,7 +19,6 @@ typedef u32 PAddr; ///< Represents a pointer in the physical address space.  enum {      BOOTROM_SIZE            = 0x00010000,   ///< Bootrom (super secret code/data @ 0x8000) size      MPCORE_PRIV_SIZE        = 0x00002000,   ///< MPCore private memory region size -    DSP_SIZE                = 0x00080000,   ///< DSP memory size      AXI_WRAM_SIZE           = 0x00080000,   ///< AXI WRAM size      FCRAM_SIZE              = 0x08000000,   ///< FCRAM size @@ -34,6 +33,9 @@ enum {      SHARED_MEMORY_VADDR_END = (SHARED_MEMORY_VADDR + SHARED_MEMORY_SIZE),      SHARED_MEMORY_MASK      = (SHARED_MEMORY_SIZE - 1), +    DSP_MEMORY_SIZE         = 0x00080000,   ///< DSP memory size +    DSP_MEMORY_VADDR        = 0x1FF00000,   ///< DSP memory virtual address +      CONFIG_MEMORY_SIZE      = 0x00001000,   ///< Configuration memory size      CONFIG_MEMORY_VADDR     = 0x1FF80000,   ///< Configuration memory virtual address      CONFIG_MEMORY_VADDR_END = (CONFIG_MEMORY_VADDR + CONFIG_MEMORY_SIZE), diff --git a/src/video_core/command_processor.cpp b/src/video_core/command_processor.cpp index 1ec727698..8a6ba2560 100644 --- a/src/video_core/command_processor.cpp +++ b/src/video_core/command_processor.cpp @@ -60,7 +60,7 @@ static inline void WritePicaReg(u32 id, u32 value, u32 mask) {                  const u8* load_address = base_address + loader_config.data_offset;                  // TODO: What happens if a loader overwrites a previous one's data? -                for (int component = 0; component < loader_config.component_count; ++component) { +                for (unsigned component = 0; component < loader_config.component_count; ++component) {                      u32 attribute_index = loader_config.GetComponent(component);                      vertex_attribute_sources[attribute_index] = load_address;                      vertex_attribute_strides[attribute_index] = static_cast<u32>(loader_config.byte_count); diff --git a/src/video_core/debug_utils/debug_utils.cpp b/src/video_core/debug_utils/debug_utils.cpp index 275b06b7c..8a5f11424 100644 --- a/src/video_core/debug_utils/debug_utils.cpp +++ b/src/video_core/debug_utils/debug_utils.cpp @@ -155,7 +155,7 @@ void DumpShader(const u32* binary_data, u32 binary_size, const u32* swizzle_data      // This is put into a try-catch block to make sure we notice unknown configurations.      std::vector<OutputRegisterInfo> output_info_table; -        for (int i = 0; i < 7; ++i) { +        for (unsigned i = 0; i < 7; ++i) {              using OutputAttributes = Pica::Regs::VSOutputAttributes;              // TODO: It's still unclear how the attribute components map to the register! @@ -375,8 +375,8 @@ void DumpTexture(const Pica::Regs::TextureConfig& texture_config, u8* data) {      png_write_info(png_ptr, info_ptr);      buf = new u8[row_stride * texture_config.height]; -    for (int y = 0; y < texture_config.height; ++y) { -        for (int x = 0; x < texture_config.width; ++x) { +    for (unsigned y = 0; y < texture_config.height; ++y) { +        for (unsigned x = 0; x < texture_config.width; ++x) {              // Cf. rasterizer code for an explanation of this algorithm.              int texel_index_within_tile = 0;              for (int block_size_index = 0; block_size_index < 3; ++block_size_index) { @@ -402,7 +402,7 @@ void DumpTexture(const Pica::Regs::TextureConfig& texture_config, u8* data) {      }      // Write image data -    for (auto y = 0; y < texture_config.height; ++y) +    for (unsigned y = 0; y < texture_config.height; ++y)      {          u8* row_ptr = (u8*)buf + y * row_stride;          u8* ptr = row_ptr; diff --git a/src/video_core/renderer_opengl/renderer_opengl.cpp b/src/video_core/renderer_opengl/renderer_opengl.cpp index fd44c3f68..06de6afbd 100644 --- a/src/video_core/renderer_opengl/renderer_opengl.cpp +++ b/src/video_core/renderer_opengl/renderer_opengl.cpp @@ -61,7 +61,7 @@ void RendererOpenGL::SwapBuffers() {      for(int i : {0, 1}) {          const auto& framebuffer = GPU::g_regs.framebuffer_config[i]; -        if (textures[i].width != framebuffer.width || textures[i].height != framebuffer.height) { +        if (textures[i].width != (GLsizei)framebuffer.width || textures[i].height != (GLsizei)framebuffer.height) {              // Reallocate texture if the framebuffer size has changed.              // This is expected to not happen very often and hence should not be a              // performance problem. | 
