diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-03 14:16:24 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-03 14:16:24 +0200 |
| commit | 1f8b6804f69632914ad0ab64892021315e99f421 (patch) | |
| tree | 0d5a37489c42beaaeeab2a255606919708712609 /internal/eventloop.go | |
| parent | 1d3a888c8db742ac5f2ba1c6cbb10603855dacb1 (diff) | |
Invalidate proc-fd cache on close_range
Diffstat (limited to 'internal/eventloop.go')
| -rw-r--r-- | internal/eventloop.go | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/internal/eventloop.go b/internal/eventloop.go index 562a802..7d33f87 100644 --- a/internal/eventloop.go +++ b/internal/eventloop.go @@ -566,6 +566,7 @@ func (e *eventLoop) handleFdExit(ep *event.Pair, fdEv *FdEvent) bool { retEv, ok := ep.ExitEv.(*types.RetEvent) if ok && retEv.Ret == 0 { e.fdState().closeRangeFrom(fd) + e.deleteProcFdCacheFrom(fd, fdEv.Pid) } } ep.Comm = e.comm(fdEv.GetTid()) @@ -787,6 +788,17 @@ func (e *eventLoop) deleteProcFdCache(fd int32, pid uint32) { delete(e.procFdCacheState(), procFdCacheKey(pid, fd)) } +func (e *eventLoop) deleteProcFdCacheFrom(first int32, pid uint32) { + cache := e.procFdCacheState() + for key := range cache { + cachePid := uint32(key >> 32) + cacheFd := int32(uint32(key)) + if cachePid == pid && cacheFd >= first { + delete(cache, key) + } + } +} + func (e *eventLoop) procFdCacheState() map[uint64]file.FdFile { if e.procFdCache == nil { e.procFdCache = make(map[uint64]file.FdFile) |
