forked from eden-emu/eden
		
	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
					
				
					 5 changed files with 47 additions and 8 deletions
				
			
		|  | @ -397,6 +397,23 @@ void GetAppletInfo(Service::Interface* self) { | |||
|     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() { | ||||
|     AddService(new APT_A_Interface); | ||||
|     AddService(new APT_S_Interface); | ||||
|  |  | |||
|  | @ -67,6 +67,12 @@ enum class AppletId : u32 { | |||
|     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
 | ||||
| void SendParameter(const MessageParameter& parameter); | ||||
| 
 | ||||
|  | @ -344,6 +350,17 @@ void PreloadLibraryApplet(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
 | ||||
| void Init(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,9 +13,10 @@ const Interface::FunctionInfo FunctionTable[] = { | |||
|     {0x00020080, Initialize,                   "Initialize?"}, | ||||
|     {0x00030040, Enable,                       "Enable?"}, | ||||
|     {0x00040040, nullptr,                      "Finalize?"}, | ||||
|     {0x00050040, nullptr,                      "GetAppletManInfo?"}, | ||||
|     {0x00060040, nullptr,                      "GetAppletInfo?"}, | ||||
|     {0x00050040, GetAppletManInfo,             "GetAppletManInfo"}, | ||||
|     {0x00060040, GetAppletInfo,                "GetAppletInfo"}, | ||||
|     {0x00090040, IsRegistered,                 "IsRegistered"}, | ||||
|     {0x000B0040, InquireNotification,          "InquireNotification"}, | ||||
|     {0x000C0104, SendParameter,                "SendParameter"}, | ||||
|     {0x000D0080, ReceiveParameter,             "ReceiveParameter"}, | ||||
|     {0x000E0080, GlanceParameter,              "GlanceParameter"}, | ||||
|  | @ -24,9 +25,13 @@ const Interface::FunctionInfo FunctionTable[] = { | |||
|     {0x00180040, PrepareToStartLibraryApplet,  "PrepareToStartLibraryApplet"}, | ||||
|     {0x001E0084, StartLibraryApplet,           "StartLibraryApplet"}, | ||||
|     {0x003B0040, nullptr,                      "CancelLibraryApplet?"}, | ||||
|     {0x003E0080, nullptr,                      "ReplySleepQuery"}, | ||||
|     {0x00430040, NotifyToWait,                 "NotifyToWait?"}, | ||||
|     {0x00440000, GetSharedFont,                "GetSharedFont?"}, | ||||
|     {0x004B00C2, AppletUtility,                "AppletUtility?"}, | ||||
|     {0x004F0080, SetAppCpuTimeLimit,           "SetAppCpuTimeLimit"}, | ||||
|     {0x00500040, GetAppCpuTimeLimit,           "GetAppCpuTimeLimit"}, | ||||
|     {0x00510080, GetStartupArgument,           "GetStartupArgument"}, | ||||
|     {0x00550040, nullptr,                      "WriteInputToNsState?"}, | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,8 +13,8 @@ const Interface::FunctionInfo FunctionTable[] = { | |||
|     {0x00020080, Initialize,            "Initialize"}, | ||||
|     {0x00030040, Enable,                "Enable"}, | ||||
|     {0x00040040, nullptr,               "Finalize"}, | ||||
|     {0x00050040, nullptr,               "GetAppletManInfo"}, | ||||
|     {0x00060040, nullptr,               "GetAppletInfo"}, | ||||
|     {0x00050040, GetAppletManInfo,      "GetAppletManInfo"}, | ||||
|     {0x00060040, GetAppletInfo,         "GetAppletInfo"}, | ||||
|     {0x00070000, nullptr,               "GetLastSignaledAppletId"}, | ||||
|     {0x00080000, nullptr,               "CountRegisteredApplet"}, | ||||
|     {0x00090040, nullptr,               "IsRegistered"}, | ||||
|  | @ -87,9 +87,9 @@ const Interface::FunctionInfo FunctionTable[] = { | |||
|     {0x004C0000, nullptr,               "SetFatalErrDispMode"}, | ||||
|     {0x004D0080, nullptr,               "GetAppletProgramInfo"}, | ||||
|     {0x004E0000, nullptr,               "HardwareResetAsync"}, | ||||
|     {0x004F0080, nullptr,               "SetApplicationCpuTimeLimit"}, | ||||
|     {0x00500040, nullptr,               "GetApplicationCpuTimeLimit"}, | ||||
|     {0x00510080, nullptr,               "GetStartupArgument"}, | ||||
|     {0x004F0080, SetAppCpuTimeLimit,    "SetAppCpuTimeLimit"}, | ||||
|     {0x00500040, GetAppCpuTimeLimit,    "GetAppCpuTimeLimit"}, | ||||
|     {0x00510080, GetStartupArgument,    "GetStartupArgument"}, | ||||
|     {0x00520104, nullptr,               "Wrap1"}, | ||||
|     {0x00530104, nullptr,               "Unwrap1"}, | ||||
|     {0x00580002, nullptr,               "GetProgramID"}, | ||||
|  |  | |||
|  | @ -89,7 +89,7 @@ const Interface::FunctionInfo FunctionTable[] = { | |||
|     {0x004E0000, nullptr,                         "HardwareResetAsync"}, | ||||
|     {0x004F0080, SetAppCpuTimeLimit,              "SetAppCpuTimeLimit"}, | ||||
|     {0x00500040, GetAppCpuTimeLimit,              "GetAppCpuTimeLimit"}, | ||||
|     {0x00510080, nullptr,                         "GetStartupArgument"}, | ||||
|     {0x00510080, GetStartupArgument,              "GetStartupArgument"}, | ||||
|     {0x00520104, nullptr,                         "Wrap1"}, | ||||
|     {0x00530104, nullptr,                         "Unwrap1"}, | ||||
|     {0x00580002, nullptr,                         "GetProgramID"}, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei