mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu-mainline.git
				synced 2025-03-21 01:53:15 +00:00 
			
		
		
		
	Merge pull request #1577 from JamePeng/update-apta-func
Append the missing function name"GetAppletInfo", "SetAppCpuTimeLimit" and "GetAppCpuTimeLimit" to APT:A
This commit is contained in:
		
						commit
						f531d4b810
					
				@ -397,6 +397,23 @@ void GetAppletInfo(Service::Interface* self) {
 | 
				
			|||||||
    LOG_WARNING(Service_APT, "(stubbed) called appid=%u", app_id);
 | 
					    LOG_WARNING(Service_APT, "(stubbed) called appid=%u", app_id);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void GetStartupArgument(Service::Interface* self) {
 | 
				
			||||||
 | 
					    u32* cmd_buff = Kernel::GetCommandBuffer();
 | 
				
			||||||
 | 
					    u32 parameter_size = cmd_buff[1];
 | 
				
			||||||
 | 
					    StartupArgumentType startup_argument_type = static_cast<StartupArgumentType>(cmd_buff[2]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (parameter_size >= 0x300) {
 | 
				
			||||||
 | 
					        LOG_ERROR(Service_APT, "Parameter size is outside the valid range (capped to 0x300): parameter_size=0x%08x", parameter_size);
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    LOG_WARNING(Service_APT,"(stubbed) called startup_argument_type=%u , parameter_size=0x%08x , parameter_value=0x%08x",
 | 
				
			||||||
 | 
					                startup_argument_type, parameter_size, Memory::Read32(cmd_buff[41]));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    cmd_buff[1] = RESULT_SUCCESS.raw;
 | 
				
			||||||
 | 
					    cmd_buff[2] = (parameter_size > 0) ? 1 : 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void Init() {
 | 
					void Init() {
 | 
				
			||||||
    AddService(new APT_A_Interface);
 | 
					    AddService(new APT_A_Interface);
 | 
				
			||||||
    AddService(new APT_S_Interface);
 | 
					    AddService(new APT_S_Interface);
 | 
				
			||||||
 | 
				
			|||||||
@ -67,6 +67,12 @@ enum class AppletId : u32 {
 | 
				
			|||||||
    Ed2                = 0x402,
 | 
					    Ed2                = 0x402,
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					enum class StartupArgumentType : u32 {
 | 
				
			||||||
 | 
					    OtherApp   = 0,
 | 
				
			||||||
 | 
					    Restart    = 1,
 | 
				
			||||||
 | 
					    OtherMedia = 2,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/// Send a parameter to the currently-running application, which will read it via ReceiveParameter
 | 
					/// Send a parameter to the currently-running application, which will read it via ReceiveParameter
 | 
				
			||||||
void SendParameter(const MessageParameter& parameter);
 | 
					void SendParameter(const MessageParameter& parameter);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -344,6 +350,17 @@ void PreloadLibraryApplet(Service::Interface* self);
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
void StartLibraryApplet(Service::Interface* self);
 | 
					void StartLibraryApplet(Service::Interface* self);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * APT::GetStartupArgument service function
 | 
				
			||||||
 | 
					 *  Inputs:
 | 
				
			||||||
 | 
					 *      1 : Parameter Size (capped to 0x300)
 | 
				
			||||||
 | 
					 *      2 : StartupArgumentType
 | 
				
			||||||
 | 
					 *  Outputs:
 | 
				
			||||||
 | 
					 *      0 : Return header
 | 
				
			||||||
 | 
					 *      1 : u8, Exists (0 = does not exist, 1 = exists)
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void GetStartupArgument(Service::Interface* self);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/// Initialize the APT service
 | 
					/// Initialize the APT service
 | 
				
			||||||
void Init();
 | 
					void Init();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -13,9 +13,10 @@ const Interface::FunctionInfo FunctionTable[] = {
 | 
				
			|||||||
    {0x00020080, Initialize,                   "Initialize?"},
 | 
					    {0x00020080, Initialize,                   "Initialize?"},
 | 
				
			||||||
    {0x00030040, Enable,                       "Enable?"},
 | 
					    {0x00030040, Enable,                       "Enable?"},
 | 
				
			||||||
    {0x00040040, nullptr,                      "Finalize?"},
 | 
					    {0x00040040, nullptr,                      "Finalize?"},
 | 
				
			||||||
    {0x00050040, nullptr,                      "GetAppletManInfo?"},
 | 
					    {0x00050040, GetAppletManInfo,             "GetAppletManInfo"},
 | 
				
			||||||
    {0x00060040, nullptr,                      "GetAppletInfo?"},
 | 
					    {0x00060040, GetAppletInfo,                "GetAppletInfo"},
 | 
				
			||||||
    {0x00090040, IsRegistered,                 "IsRegistered"},
 | 
					    {0x00090040, IsRegistered,                 "IsRegistered"},
 | 
				
			||||||
 | 
					    {0x000B0040, InquireNotification,          "InquireNotification"},
 | 
				
			||||||
    {0x000C0104, SendParameter,                "SendParameter"},
 | 
					    {0x000C0104, SendParameter,                "SendParameter"},
 | 
				
			||||||
    {0x000D0080, ReceiveParameter,             "ReceiveParameter"},
 | 
					    {0x000D0080, ReceiveParameter,             "ReceiveParameter"},
 | 
				
			||||||
    {0x000E0080, GlanceParameter,              "GlanceParameter"},
 | 
					    {0x000E0080, GlanceParameter,              "GlanceParameter"},
 | 
				
			||||||
@ -24,9 +25,13 @@ const Interface::FunctionInfo FunctionTable[] = {
 | 
				
			|||||||
    {0x00180040, PrepareToStartLibraryApplet,  "PrepareToStartLibraryApplet"},
 | 
					    {0x00180040, PrepareToStartLibraryApplet,  "PrepareToStartLibraryApplet"},
 | 
				
			||||||
    {0x001E0084, StartLibraryApplet,           "StartLibraryApplet"},
 | 
					    {0x001E0084, StartLibraryApplet,           "StartLibraryApplet"},
 | 
				
			||||||
    {0x003B0040, nullptr,                      "CancelLibraryApplet?"},
 | 
					    {0x003B0040, nullptr,                      "CancelLibraryApplet?"},
 | 
				
			||||||
 | 
					    {0x003E0080, nullptr,                      "ReplySleepQuery"},
 | 
				
			||||||
    {0x00430040, NotifyToWait,                 "NotifyToWait?"},
 | 
					    {0x00430040, NotifyToWait,                 "NotifyToWait?"},
 | 
				
			||||||
    {0x00440000, GetSharedFont,                "GetSharedFont?"},
 | 
					    {0x00440000, GetSharedFont,                "GetSharedFont?"},
 | 
				
			||||||
    {0x004B00C2, AppletUtility,                "AppletUtility?"},
 | 
					    {0x004B00C2, AppletUtility,                "AppletUtility?"},
 | 
				
			||||||
 | 
					    {0x004F0080, SetAppCpuTimeLimit,           "SetAppCpuTimeLimit"},
 | 
				
			||||||
 | 
					    {0x00500040, GetAppCpuTimeLimit,           "GetAppCpuTimeLimit"},
 | 
				
			||||||
 | 
					    {0x00510080, GetStartupArgument,           "GetStartupArgument"},
 | 
				
			||||||
    {0x00550040, nullptr,                      "WriteInputToNsState?"},
 | 
					    {0x00550040, nullptr,                      "WriteInputToNsState?"},
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -13,8 +13,8 @@ const Interface::FunctionInfo FunctionTable[] = {
 | 
				
			|||||||
    {0x00020080, Initialize,            "Initialize"},
 | 
					    {0x00020080, Initialize,            "Initialize"},
 | 
				
			||||||
    {0x00030040, Enable,                "Enable"},
 | 
					    {0x00030040, Enable,                "Enable"},
 | 
				
			||||||
    {0x00040040, nullptr,               "Finalize"},
 | 
					    {0x00040040, nullptr,               "Finalize"},
 | 
				
			||||||
    {0x00050040, nullptr,               "GetAppletManInfo"},
 | 
					    {0x00050040, GetAppletManInfo,      "GetAppletManInfo"},
 | 
				
			||||||
    {0x00060040, nullptr,               "GetAppletInfo"},
 | 
					    {0x00060040, GetAppletInfo,         "GetAppletInfo"},
 | 
				
			||||||
    {0x00070000, nullptr,               "GetLastSignaledAppletId"},
 | 
					    {0x00070000, nullptr,               "GetLastSignaledAppletId"},
 | 
				
			||||||
    {0x00080000, nullptr,               "CountRegisteredApplet"},
 | 
					    {0x00080000, nullptr,               "CountRegisteredApplet"},
 | 
				
			||||||
    {0x00090040, nullptr,               "IsRegistered"},
 | 
					    {0x00090040, nullptr,               "IsRegistered"},
 | 
				
			||||||
@ -87,9 +87,9 @@ const Interface::FunctionInfo FunctionTable[] = {
 | 
				
			|||||||
    {0x004C0000, nullptr,               "SetFatalErrDispMode"},
 | 
					    {0x004C0000, nullptr,               "SetFatalErrDispMode"},
 | 
				
			||||||
    {0x004D0080, nullptr,               "GetAppletProgramInfo"},
 | 
					    {0x004D0080, nullptr,               "GetAppletProgramInfo"},
 | 
				
			||||||
    {0x004E0000, nullptr,               "HardwareResetAsync"},
 | 
					    {0x004E0000, nullptr,               "HardwareResetAsync"},
 | 
				
			||||||
    {0x004F0080, nullptr,               "SetApplicationCpuTimeLimit"},
 | 
					    {0x004F0080, SetAppCpuTimeLimit,    "SetAppCpuTimeLimit"},
 | 
				
			||||||
    {0x00500040, nullptr,               "GetApplicationCpuTimeLimit"},
 | 
					    {0x00500040, GetAppCpuTimeLimit,    "GetAppCpuTimeLimit"},
 | 
				
			||||||
    {0x00510080, nullptr,               "GetStartupArgument"},
 | 
					    {0x00510080, GetStartupArgument,    "GetStartupArgument"},
 | 
				
			||||||
    {0x00520104, nullptr,               "Wrap1"},
 | 
					    {0x00520104, nullptr,               "Wrap1"},
 | 
				
			||||||
    {0x00530104, nullptr,               "Unwrap1"},
 | 
					    {0x00530104, nullptr,               "Unwrap1"},
 | 
				
			||||||
    {0x00580002, nullptr,               "GetProgramID"},
 | 
					    {0x00580002, nullptr,               "GetProgramID"},
 | 
				
			||||||
 | 
				
			|||||||
@ -89,7 +89,7 @@ const Interface::FunctionInfo FunctionTable[] = {
 | 
				
			|||||||
    {0x004E0000, nullptr,                         "HardwareResetAsync"},
 | 
					    {0x004E0000, nullptr,                         "HardwareResetAsync"},
 | 
				
			||||||
    {0x004F0080, SetAppCpuTimeLimit,              "SetAppCpuTimeLimit"},
 | 
					    {0x004F0080, SetAppCpuTimeLimit,              "SetAppCpuTimeLimit"},
 | 
				
			||||||
    {0x00500040, GetAppCpuTimeLimit,              "GetAppCpuTimeLimit"},
 | 
					    {0x00500040, GetAppCpuTimeLimit,              "GetAppCpuTimeLimit"},
 | 
				
			||||||
    {0x00510080, nullptr,                         "GetStartupArgument"},
 | 
					    {0x00510080, GetStartupArgument,              "GetStartupArgument"},
 | 
				
			||||||
    {0x00520104, nullptr,                         "Wrap1"},
 | 
					    {0x00520104, nullptr,                         "Wrap1"},
 | 
				
			||||||
    {0x00530104, nullptr,                         "Unwrap1"},
 | 
					    {0x00530104, nullptr,                         "Unwrap1"},
 | 
				
			||||||
    {0x00580002, nullptr,                         "GetProgramID"},
 | 
					    {0x00580002, nullptr,                         "GetProgramID"},
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user