Difference between revisions of "Services API"
Line 56: | Line 56: | ||
! scope="col" width="200" | Notes | ! scope="col" width="200" | Notes | ||
|- | |- | ||
− | | acc:u0, acc:u1, acc:aa, acc:su | + | | acc:u0, acc:u1, acc:aa, acc:su, [5.0.0+] dauth:0 |
| [[Account services]] | | [[Account services]] | ||
| u0: System, u1: User, su: Admin, aa: Baas | | u0: System, u1: User, su: Admin, aa: Baas | ||
|- | |- | ||
− | | ahid:cd, ahid:hdr, hid, hid:dbg, hid:sys, irs, irs:sys, xcd:sys | + | | ahid:cd, ahid:hdr, hid, hid:dbg, hid:sys, irs, irs:sys, xcd:sys, [4.0.0+] hid:tmp, [5.0.0+] hidbus |
| [[HID services]] | | [[HID services]] | ||
| | | | ||
Line 106: | Line 106: | ||
| | | | ||
|- | |- | ||
− | | btdrv | + | | btdrv, [5.0.0+] bt |
| [[Bluetooth Driver services]] | | [[Bluetooth Driver services]] | ||
| | | | ||
|- | |- | ||
− | | btm, btm:dbg, btm:sys | + | | btm, btm:dbg, btm:sys, [5.0.0+] btm:u |
| Battery services | | Battery services | ||
| | | | ||
|- | |- | ||
− | | caps:a, caps:c | + | | caps:a, caps:c, [5.0.0+] caps:u |
| [[Capture services]] | | [[Capture services]] | ||
| a: AlbumAccessor, c: AlbumControl | | a: AlbumAccessor, c: AlbumControl | ||
|- | |- | ||
− | | caps:sc, caps:ss, mm:u, vi:m, vi:s, vi:u, cec-mgr | + | | caps:sc, caps:ss, mm:u, vi:m, vi:s, vi:u, cec-mgr, [4.0.0+] caps:su |
| [[Display services]] | | [[Display services]] | ||
| | | | ||
Line 142: | Line 142: | ||
| u: User, p: Privileged | | u: User, p: Privileged | ||
|- | |- | ||
− | | friend:u, friend:v, friend:m, friend:s, friend:a | + | | friend:u, friend:v, friend:m, friend:s, friend:a, [5.0.0+] nd:app, nd:sys |
| Friend services | | Friend services | ||
| | | | ||
Line 162: | Line 162: | ||
| | | | ||
|- | |- | ||
− | | ldn:m, ldn:s, ldn:u | + | | ldn:m, ldn:s, ldn:u, [5.0.0+] ndd |
| [[LDN services]] | | [[LDN services]] | ||
| | | | ||
Line 192: | Line 192: | ||
| | | | ||
|- | |- | ||
− | | nim, nim:shp, ntc, [5.0.0] | + | | nim, nim:shp, ntc, [5.0.0+] nim:eca |
| [[NIM services]] | | [[NIM services]] | ||
| shp: eShop | | shp: eShop | ||
Line 228: | Line 228: | ||
| cal: calibration, sys: System Settings | | cal: calibration, sys: System Settings | ||
|- | |- | ||
− | | [3.0.0+] mii:u, mii:e, pdm:ntfy, pdm:qry, pl:u | + | | [3.0.0+] mii:u, mii:e, pdm:ntfy, pdm:qry, pl:u, [5.0.0+] miiimg |
| [[Shared Database services]] | | [[Shared Database services]] | ||
| | | |
Revision as of 22:13, 14 March 2018
Services are system processes running in the background which wait for incoming requests. When a process wants to communicate with a service, it first needs to get a handle to the named service, and then it can communicate with the service via inter-process communication (each service has a name up to 8 characters).
Handles for services are retrieved from the service manager port, "sm:", and are released via svcCloseHandle or when a process is terminated or crashes. Manager service "sm:m" also exists. Services are an abstraction of ports, they operate the same way except regular ports can have their handles retrieved directly from a SVC. Services are also able to limit the number of handles given to other processes.
sm:
This is "nn::sm::detail::IUserInterface".
Cmd | Name |
---|---|
0 | #Initialize |
1 | #GetService |
2 | #RegisterService |
3 | #UnregisterService |
Initialize
Takes a pid descriptor and a reserved input u64.
GetService
Takes a zero-padded service name encoded as an u64 integer. Returns a handle.
RegisterService
Takes a zero-padded service name encoded as an u64 integer, an u8 bool, and an u32 (session count) at the next word. Returns a handle.
UnregisterService
Takes a zero-padded service name encoded as an u64 integer.
sm:m
This is "nn::sm::detail::IManagerInterface".
Cmd | Name |
---|---|
0 | #RegisterProcess |
1 | #UnregisterProcess |
RegisterProcess
Takes a pid and two A descriptors with the ACID and ACI0 service lists. That data originates from NPDM.
UnregisterProcess
Takes a pid.
Service List
Service names | Description | Notes |
---|---|---|
acc:u0, acc:u1, acc:aa, acc:su, [5.0.0+] dauth:0 | Account services | u0: System, u1: User, su: Admin, aa: Baas |
ahid:cd, ahid:hdr, hid, hid:dbg, hid:sys, irs, irs:sys, xcd:sys, [4.0.0+] hid:tmp, [5.0.0+] hidbus | HID services | |
appletAE, appletOE, idle:sys, omm, spsm, [5.0.0+] tcap | AM services | tcap: Thermal-related? |
[1.0.0+] aoc:u, mii:u, mii:e, ns:am, ns:su, ns:dev, pl:u, ovln:rcv, ovln:snd, pdm:ntfy, pdm:qry
[3.0.0+] aoc:u, ns:am2, ns:dev, ns:ec, ns:rid, ns:rt, ns:su, ns:vm, ns:web, ovln:rcv, ovln:snd |
NS Services | am: Application Manager, su: System Update |
apm, apm:p, apm:sys, fgm, fgm:0, fgm:9, (fgm:dbg?) | APM services | |
arp:r, arp:w, bgtc:t, bgtc:sc | Glue services | r: Reader, w: Writer |
audin:a, audin:d, audin:u, audout:a, audout:d, audout:u, audren:a, audren:d, audren:u, audrec:a, audrec:d, audrec:u, audctl, codecctl, hwopus, auddebug | Audio services | |
banana | ? | Some games on [3.0.0+] have access to this service, but it doesn't appear to be present on retail devices. |
bcat:a, bcat:u, bcat:m, bcat:s, news:a, news:c, news:m, news:p, news:v, prepo:u, prepo:s, prepo:m, prepo:a | BCAT services | |
pcm | ? | Power consumption measurement? Not present on retail units. |
bpc, bpc:r, pcv, pcv:arb, pcv:imm, time:u, time:a, time:s | PCV services | |
bsd:u, bsd:s, bsdcfg, ethc:c, ethc:i, nsd:u, nsd:a, sfdnsres | Sockets services | |
btdrv, [5.0.0+] bt | Bluetooth Driver services | |
btm, btm:dbg, btm:sys, [5.0.0+] btm:u | Battery services | |
caps:a, caps:c, [5.0.0+] caps:u | Capture services | a: AlbumAccessor, c: AlbumControl |
caps:sc, caps:ss, mm:u, vi:m, vi:s, vi:u, cec-mgr, [4.0.0+] caps:su | Display services | |
dispdrv | Nvnflinger services | |
erpt:c, erpt:r | Error Report services | |
es | ETicket services | |
fan, psm, tc, ts | PTM services | |
fatal:u, fatal:p | Fatal services | u: User, p: Privileged |
friend:u, friend:v, friend:m, friend:s, friend:a, [5.0.0+] nd:app, nd:sys | Friend services | |
fsp-srv, fsp-ldr, fsp-pr | Filesystem services | srv: Main, ldr: Loader, pr: Program Registry |
gpio, i2c, i2c:pcv, pinmux, pwm, uart, [3.0.0+] sasbus | Bus services | |
htc, htcs, htc:tenv | TMA services | |
lbl | Backlight services | |
ldn:m, ldn:s, ldn:u, [5.0.0+] ndd | LDN services | |
[1.0.0+] ldr:pm, ldr:ro, ldr:shel, ldr:dmnt
[3.0.0+] ldr:pm, ldr:shel, ldr:dmnt |
Loader services | |
lm | Log services | |
manu | Manu Services | "Manufacturing", present in factory firmware but not installed on retail systems. |
lr, ncm, ncm:v | NCM services | |
nfc:am, nfc:mf:u, nfc:user, nfc:sys, nfp:user, nfp:dbg, nfp:sys | NFC services | |
nifm:u, nifm:a, nifm:s | Network Interface services | |
nim, nim:shp, ntc, [5.0.0+] nim:eca | NIM services | shp: eShop |
npns:u, npns:s | NPNS services | |
nvdrv:a, nvdrv:s, nvdrv:t, nvdrv, nvdrvdbg, nvgem:c, nvgem:cd, nvmemp | NV services | |
pcie | PCIe services | |
pctl, pctl:a, pctl:s, pctl:r | Parental Control services | |
pm:bm, pm:info, pm:shell | Process Manager services | |
psc:c, psc:m | PSC services | |
[3.0.0+] ldr:ro, ro:dmnt | RO services | |
set, set:fd, set:cal, set:sys | Settings services | cal: calibration, sys: System Settings |
[3.0.0+] mii:u, mii:e, pdm:ntfy, pdm:qry, pl:u, [5.0.0+] miiimg | Shared Database services | |
ssl | SSL services | |
[1.0.0+] csrng, spl:
[4.0.0+] csrng, spl:, spl:mig, spl:fs, spl:ssl, spl:es |
SPL services | |
usb:ds, usb:hs, usb:pd, usb:pd:c, usb:pm | USB services | |
wlan:inf, wlan:lcl, wlan:lg, wlan:lga, wlan:sg, wlan:soc | WLAN services | |
[4.0.0+] grc:c | GRC services | |
[4.0.0+] mig:usr | Migration services | |
[4.0.0+] caps:dc | Jpegdec services |