mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-12 16:48:41 +00:00
187 lines
4.2 KiB
C
187 lines
4.2 KiB
C
/*
|
|
* Copyright (c) 2018-2019 Atmosphère-NX
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <switch.h>
|
|
#include "pm_ams.h"
|
|
|
|
Result pminfoAtmosphereGetProcessId(u64 *out_pid, u64 tid) {
|
|
IpcCommand c;
|
|
ipcInitialize(&c);
|
|
Service *srv = pminfoGetServiceSession();
|
|
|
|
struct {
|
|
u64 magic;
|
|
u64 cmd_id;
|
|
u64 title_id;
|
|
} *raw;
|
|
|
|
raw = serviceIpcPrepareHeader(srv, &c, sizeof(*raw));
|
|
raw->magic = SFCI_MAGIC;
|
|
raw->cmd_id = 65000;
|
|
raw->title_id = tid;
|
|
|
|
Result rc = serviceIpcDispatch(srv);
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
IpcParsedCommand r;
|
|
struct {
|
|
u64 magic;
|
|
u64 result;
|
|
u64 pid;
|
|
} *resp;
|
|
|
|
serviceIpcParse(srv, &r, sizeof(*resp));
|
|
resp = r.Raw;
|
|
|
|
rc = resp->result;
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
*out_pid = resp->pid;
|
|
}
|
|
}
|
|
|
|
return rc;
|
|
}
|
|
|
|
Result pminfoAtmosphereHasLaunchedTitle(bool *out, u64 tid) {
|
|
IpcCommand c;
|
|
ipcInitialize(&c);
|
|
Service *srv = pminfoGetServiceSession();
|
|
|
|
struct {
|
|
u64 magic;
|
|
u64 cmd_id;
|
|
u64 title_id;
|
|
} *raw;
|
|
|
|
raw = serviceIpcPrepareHeader(srv, &c, sizeof(*raw));
|
|
raw->magic = SFCI_MAGIC;
|
|
raw->cmd_id = 65001;
|
|
raw->title_id = tid;
|
|
|
|
Result rc = serviceIpcDispatch(srv);
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
IpcParsedCommand r;
|
|
struct {
|
|
u64 magic;
|
|
u64 result;
|
|
u8 has_launched_title;
|
|
} *resp;
|
|
|
|
serviceIpcParse(srv, &r, sizeof(*resp));
|
|
resp = r.Raw;
|
|
|
|
rc = resp->result;
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
*out = resp->has_launched_title != 0;
|
|
}
|
|
}
|
|
|
|
return rc;
|
|
}
|
|
|
|
Result pmdmntAtmosphereGetProcessInfo(Handle* out, u64 *tid_out, u8 *sid_out, u64 pid) {
|
|
IpcCommand c;
|
|
ipcInitialize(&c);
|
|
Service *s = pmdmntGetServiceSession();
|
|
|
|
struct {
|
|
u64 magic;
|
|
u64 cmd_id;
|
|
u64 pid;
|
|
} *raw;
|
|
|
|
raw = serviceIpcPrepareHeader(s, &c, sizeof(*raw));
|
|
|
|
raw->magic = SFCI_MAGIC;
|
|
raw->cmd_id = 65000;
|
|
raw->pid = pid;
|
|
|
|
Result rc = serviceIpcDispatch(s);
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
IpcParsedCommand r;
|
|
struct {
|
|
u64 magic;
|
|
u64 result;
|
|
u64 title_id;
|
|
FsStorageId storage_id;
|
|
} *resp;
|
|
|
|
serviceIpcParse(s, &r, sizeof(*resp));
|
|
resp = r.Raw;
|
|
|
|
rc = resp->result;
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
if (out) {
|
|
*out = r.Handles[0];
|
|
} else {
|
|
svcCloseHandle(r.Handles[0]);
|
|
}
|
|
if (tid_out) *tid_out = resp->title_id;
|
|
if (sid_out) *sid_out = resp->storage_id;
|
|
}
|
|
}
|
|
|
|
return rc;
|
|
}
|
|
|
|
Result pmdmntAtmosphereGetCurrentLimitInfo(u64 *out_cur, u64 *out_lim, u32 group, u32 resource) {
|
|
IpcCommand c;
|
|
ipcInitialize(&c);
|
|
Service *s = pmdmntGetServiceSession();
|
|
|
|
struct {
|
|
u64 magic;
|
|
u64 cmd_id;
|
|
u32 group;
|
|
u32 resource;
|
|
} *raw;
|
|
|
|
raw = serviceIpcPrepareHeader(s, &c, sizeof(*raw));
|
|
|
|
raw->magic = SFCI_MAGIC;
|
|
raw->cmd_id = 65001;
|
|
raw->group = group;
|
|
raw->resource = resource;
|
|
|
|
Result rc = serviceIpcDispatch(s);
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
IpcParsedCommand r;
|
|
struct {
|
|
u64 magic;
|
|
u64 result;
|
|
u64 cur_value;
|
|
u64 lim_value;
|
|
} *resp;
|
|
|
|
serviceIpcParse(s, &r, sizeof(*resp));
|
|
resp = r.Raw;
|
|
|
|
rc = resp->result;
|
|
|
|
if (R_SUCCEEDED(rc)) {
|
|
if (out_cur) *out_cur = resp->cur_value;
|
|
if (out_lim) *out_lim = resp->lim_value;
|
|
}
|
|
}
|
|
|
|
return rc;
|
|
}
|