7200742: (se) Selector.select does not block when starting Coherence (sol11u1)

Alan Bateman Alan.Bateman at oracle.com
Wed Sep 26 04:36:42 PDT 2012


I need a reviewer for a change that resolves a regression in the Solaris 
/dev/poll based Selector. The regression stems from the changes for 
7169050 [1] whereby a POLLREMOVE is no longer written to the driver when 
changing events. As the events are OR'ed in the kernel it creates the 
potential for spinning when changing the interest ops from say OP_WRITE 
to OP_READ and vice versa.

It's somewhat surprising that the issue wasn't caught by any of the 
tests but they tend not to notice performance issues.  It probably 
hasn't been noticed by many servers either as typically events are 
handed over to worker threads and that typically involves setting the 
interest ops to 0 before the hand off (changing the interest ops to 0 
causes a POLLREMOVE to be written). The issue only arises when changing 
the interest ops without changing to 0.

The webrev with the changes is here and I've got a test that exercises 
all possible transitions.

http://cr.openjdk.java.net/~alanb/7200742/webrev/

As 7169050 was back-ported to jdk7u it means that the changes here will 
need to be back-ported too.

Thanks,

Alan.

[1] http://hg.openjdk.java.net/jdk8/tl/jdk/rev/21703d431217


More information about the nio-dev mailing list