Updated bossCmd34 and added bossGetTaskState().

This commit is contained in:
yellows8 2016-12-22 02:18:26 -05:00
parent ee23569db8
commit 955ae2af3e
2 changed files with 42 additions and 4 deletions

View File

@ -52,8 +52,18 @@ Result bossStartBgImmediate(char *taskID);
Result bossDeleteTask(char *taskID, u32 unk);
/**
* @brief ?
* @brief Returns task state.
* @param taskID BOSS taskID.
* @param inval Unknown, normally 0?
* @param out0 Output field.
* @param out1 Output field.
* @param out2 Output field.
*/
Result bossGetTaskState(char *taskID, s8 inval, u8 *out0, u32 *out1, u8 *out2);
/**
* @brief Returns task state info.
* @param taskID BOSS taskID.
*/
Result bossCmd34(char *taskID);
Result bossCmd34(char *taskID, u8 *out);

View File

@ -170,6 +170,31 @@ Result bossDeleteTask(char *taskID, u32 unk)
return ret;
}
Result bossGetTaskState(char *taskID, s8 inval, u8 *out0, u32 *out1, u8 *out2)
{
Result ret = 0;
u32 *cmdbuf = getThreadCommandBuffer();
u32 size = strlen(taskID)+1;
cmdbuf[0] = IPC_MakeHeader(0x20,2,2); // 0x200082
cmdbuf[1] = size;
cmdbuf[2] = inval;
cmdbuf[3] = IPC_Desc_Buffer(size, IPC_BUFFER_R);
cmdbuf[4] = (u32)taskID;
if(R_FAILED(ret = svcSendSyncRequest(bossHandle)))return ret;
ret = (Result)cmdbuf[1];
if(R_SUCCEEDED(ret))
{
if(out0)*out0 = cmdbuf[2];
if(out1)*out1 = cmdbuf[3];
if(out2)*out2 = cmdbuf[4];
}
return ret;
}
Result bossStartBgImmediate(char *taskID)
{
Result ret = 0;
@ -186,7 +211,7 @@ Result bossStartBgImmediate(char *taskID)
return (Result)cmdbuf[1];
}
Result bossCmd34(char *taskID)
Result bossCmd34(char *taskID, u8 *out)
{
Result ret = 0;
u32 *cmdbuf = getThreadCommandBuffer();
@ -198,7 +223,10 @@ Result bossCmd34(char *taskID)
cmdbuf[3] = (u32)taskID;
if(R_FAILED(ret = svcSendSyncRequest(bossHandle)))return ret;
ret = (Result)cmdbuf[1];
return (Result)cmdbuf[1];
if(R_SUCCEEDED(ret) && out)*out = cmdbuf[2];
return ret;
}