mirror of
https://github.com/switchbrew/libnx.git
synced 2025-06-21 12:32:40 +02:00
Fix ipc session close race properly
This commit is contained in:
parent
e162da18ff
commit
e112ab6968
@ -449,6 +449,16 @@ static inline Result ipcQueryPointerBufferSize(Handle session, size_t *size) {
|
||||
return rc;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Closes the IPC session with proper clean up.
|
||||
* @param session IPC session handle.
|
||||
* @return Result code.
|
||||
*/
|
||||
static inline Result ipcCloseSession(Handle session) {
|
||||
u32* buf = (u32*)armGetTls();
|
||||
buf[0] = 2;
|
||||
return ipcDispatch(session);
|
||||
}
|
||||
///@}
|
||||
|
||||
///@name IPC domain handling
|
||||
|
@ -134,6 +134,7 @@ static inline void serviceClose(Service* s) {
|
||||
|
||||
case ServiceType_Normal:
|
||||
case ServiceType_Domain:
|
||||
ipcCloseSession(s->handle);
|
||||
svcCloseHandle(s->handle);
|
||||
break;
|
||||
|
||||
|
@ -92,25 +92,7 @@ Result tmemClose(TransferMemory* t)
|
||||
rc = svcCloseHandle(t->handle);
|
||||
}
|
||||
|
||||
if (t->src_addr != NULL)
|
||||
{
|
||||
// This fixes a race condition where a remote process that has transfer
|
||||
// memory mapped, but has not yet had time to unmap it.
|
||||
// It will still be non-readable in our process until the other process has
|
||||
// unmapped it, and we cannot free() it without crashing.
|
||||
while (1) {
|
||||
MemoryInfo info;
|
||||
u32 who_cares;
|
||||
|
||||
if (R_FAILED(svcQueryMemory(&info, &who_cares, (u64) t->src_addr)))
|
||||
fatalSimple(MAKERESULT(Module_Libnx, LibnxError_BadQueryMemory));
|
||||
|
||||
if (!(info.attr & MemAttr_IsBorrowed))
|
||||
break;
|
||||
|
||||
svcSleepThread(1000000);
|
||||
}
|
||||
|
||||
if (t->src_addr != NULL) {
|
||||
free(t->src_addr);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user