RO services: Difference between revisions
No edit summary |
|||
(6 intermediate revisions by 2 users not shown) | |||
Line 12: | Line 12: | ||
! Cmd || Name | ! Cmd || Name | ||
|- | |- | ||
| 0 || [[# | | 0 || [[#MapManualLoadModuleMemory]] | ||
|- | |- | ||
| 1 || [[# | | 1 || [[#UnmapManualLoadModuleMemory]] | ||
|- | |- | ||
| 2 || [[#RegisterModuleInfo]] | | 2 || [[#RegisterModuleInfo]] | ||
Line 20: | Line 20: | ||
| 3 || [[#UnregisterModuleInfo]] | | 3 || [[#UnregisterModuleInfo]] | ||
|- | |- | ||
| 4 || [[# | | 4 || [[#RegisterProcessHandle]] | ||
|- | |- | ||
| 10 || [7.0.0+] [[# | | 10 || [7.0.0+] [[#RegisterModuleInfoWithUserProcessHandle]] | ||
|} | |} | ||
== | == MapManualLoadModuleMemory == | ||
Takes a PID-descriptor, | Takes a PID-descriptor, an u64 pid_reserved, and 4 input u64s ('''nro_address''', '''nro_size''', '''bss_address''' and '''bss_size'''). Returns an output u64 ('''out_address'''). | ||
== | == UnmapManualLoadModuleMemory == | ||
Takes a PID-descriptor and | Takes a PID-descriptor, an u64 pid_reserved, and an input u64 ('''nro_address'''). | ||
== RegisterModuleInfo == | == RegisterModuleInfo == | ||
Takes a PID-descriptor and | Takes a PID-descriptor, an u64 pid_reserved, and 2 input u64s ('''nrr_address''' and '''nrr_size'''). | ||
[7.0.0+] [[NRR|NrrKind]] must be 0 (User) for this function to succeed. | [7.0.0+] [[NRR|NrrKind]] must be 0 (User) for this function to succeed. | ||
== UnregisterModuleInfo == | == UnregisterModuleInfo == | ||
Takes a PID-descriptor and | Takes a PID-descriptor, an u64 pid_reserved, and an input u64 ('''nrr_address'''). | ||
== | == RegisterProcessHandle == | ||
Takes PID-descriptor, a process handle and an | Takes a PID-descriptor, a process handle, and an u64 pid_reserved. | ||
== | == RegisterModuleInfoWithUserProcessHandle == | ||
Takes a PID-descriptor, a process handle and | Takes a PID-descriptor, a process handle, an u64 pid_reserved, and 2 input u64s ('''nrr_address''' and '''nrr_size'''). | ||
First, this validates that the pid descriptor matches the pid for the process handle sent to this->Initialize() earlier. Then, this calls the same function as | First, this validates that the pid descriptor matches the pid for the process handle sent to this->Initialize() earlier. Then, this calls the same function as [[#RegisterModuleInfo|RegisterModuleInfo]], except using the passed process handle instead of the one sent to Initialize. | ||
When called from an ro:1 session, [[NRR|NrrKind]] must be 1 (JitPlugin). When called from ldr:ro session, [[NRR|NrrKind]] must be 0 (User). | When called from an ro:1 session, [[NRR|NrrKind]] must be 1 (JitPlugin). When called from ldr:ro session, [[NRR|NrrKind]] must be 0 (User). | ||
Line 60: | Line 60: | ||
== GetProcessModuleInfo == | == GetProcessModuleInfo == | ||
Same as [[# | Same as [[Loader_services#GetProcessModuleInfo|GetProcessModuleInfo]] from [[Loader_services#ldr:dmnt|ldr:dmnt]]. | ||
[[Category:Services]] | [[Category:Services]] |