Since 2.4 with commit 
f50906519 ("MEDIUM: fd: merge fdtab[].ev and state
for FD_EV_* and FD_POLL_* into state") we can merge all flag updates at
once in fd_update_events(). Previously this was performed in 1 to 3 steps,
setting the polling state, then setting READY_R if in/err/hup, and setting
READY_W if out/err. But since the commit above, all flags are stored
together in the same structure field that is being updated with the new
flags, thus we can simply update the flags altogether and avoid multiple
atomic operations. This even removes the need for atomic ops for FDs that
are not shared.
                must_stop = FD_POLL_OUT;
        }
 
+       if (new_flags & (FD_POLL_IN | FD_POLL_HUP | FD_POLL_ERR))
+               new_flags |= FD_EV_READY_R;
+
+       if (new_flags & (FD_POLL_OUT | FD_POLL_ERR))
+               new_flags |= FD_EV_READY_W;
+
        old = fdtab[fd].state;
        new = (old & ~FD_POLL_UPDT_MASK) | new_flags;
 
                        fdtab[fd].state = new;
        }
 
-       if (fdtab[fd].state & (FD_POLL_IN | FD_POLL_HUP | FD_POLL_ERR))
-               fd_may_recv(fd);
-
-       if (fdtab[fd].state & (FD_POLL_OUT | FD_POLL_ERR))
-               fd_may_send(fd);
-
        if (fdtab[fd].iocb && fd_active(fd)) {
                fdtab[fd].iocb(fd);
        }