Fix potential memory leak of tev->e_list by reordering list_add before epoll_ctl #66
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This commit addresses a potential memory leak in
tgt_event_add
related totev->e_list
. Previously,epoll_ctl(EPOLL_CTL_ADD)
was called beforelist_add
. This sequence could lead to a race condition where the epoll eventis registered and immediately triggered, leading to
EPOLL_CTL_DEL
andlist_del
being called beforelist_add
, resulting in the event being removedfrom epoll but never added to the list, causing a memory leak after calling
list_add
(Because no one will calllist_del
to remove thistev->e_list
anymore).To prevent this,
list_add
is now called beforeepoll_ctl(EPOLL_CTL_ADD)
.This ensures that the
tev->e_list
is added to the list before anyepoll events can be triggered, allowing proper cleanup by
list_del
in caseof an early
EPOLL_CTL_DEL
.