Add nsGetSpace commands

This commit is contained in:
Joel16 2018-06-05 13:52:27 -05:00
parent d3889fb9ed
commit 4a3e8e805c
2 changed files with 86 additions and 0 deletions

View File

@ -18,6 +18,18 @@ void nsExit(void);
Result nsGetApplicationControlData(u8 flag, u64 titleID, NsApplicationControlData* buffer, size_t size, size_t* actual_size); Result nsGetApplicationControlData(u8 flag, u64 titleID, NsApplicationControlData* buffer, size_t size, size_t* actual_size);
/**
* @brief Returns the total storage from content manager services.
* @param size Pointer to output the total storage size to.
*/
Result nsGetTotalSpaceSize(u64 *size);
/**
* @brief Returns the available storage from content manager services.
* @param size Pointer to output the free storage size to.
*/
Result nsGetFreeSpaceSize(u64 *size);
Result nsvmInitialize(void); Result nsvmInitialize(void);
void nsvmExit(void); void nsvmExit(void);

View File

@ -117,6 +117,80 @@ Result nsGetApplicationControlData(u8 flag, u64 titleID, NsApplicationControlDat
return rc; return rc;
} }
Result nsGetTotalSpaceSize(u64 *size)
{
IpcCommand c;
ipcInitialize(&c);
struct {
u64 magic;
u64 cmd_id;
u64 media_id;
} *raw;
raw = ipcPrepareHeader(&c, sizeof(*raw));
raw->magic = SFCI_MAGIC;
raw->cmd_id = 47;
raw->media_id = 5;
Result rc = serviceIpcDispatch(&g_nsAppManSrv);
if (R_SUCCEEDED(rc)) {
IpcParsedCommand r;
ipcParse(&r);
struct {
u64 magic;
u64 result;
u64 size;
} *resp = r.Raw;
rc = resp->result;
if (R_SUCCEEDED(rc) && size) *size = resp->size;
}
return rc;
}
Result nsGetFreeSpaceSize(u64 *size)
{
IpcCommand c;
ipcInitialize(&c);
struct {
u64 magic;
u64 cmd_id;
u64 media_id;
} *raw;
raw = ipcPrepareHeader(&c, sizeof(*raw));
raw->magic = SFCI_MAGIC;
raw->cmd_id = 48;
raw->media_id = 5;
Result rc = serviceIpcDispatch(&g_nsAppManSrv);
if (R_SUCCEEDED(rc)) {
IpcParsedCommand r;
ipcParse(&r);
struct {
u64 magic;
u64 result;
u64 size;
} *resp = r.Raw;
rc = resp->result;
if (R_SUCCEEDED(rc) && size) *size = resp->size;
}
return rc;
}
Result nsvmInitialize(void) Result nsvmInitialize(void)
{ {
if (!kernelAbove300()) if (!kernelAbove300())