[rfc][icedtea-web] Ensure applet shutdown finishes without exceptions

Pavel Tisnovsky ptisnovs at redhat.com
Thu Mar 28 06:39:44 PDT 2013


Hi Adam,

points #2 and #3 looks ok.

Do you want to push this change into HEAD or also into some branch?

Cheers,
Pavel

----- Adam Domurad <adomurad at redhat.com> wrote:
> On 01/31/2013 05:05 PM, Adam Domurad wrote:
> > Hi all. Another round of what I think could be important stability 
> > fixes for icedtea-web.
> >
> > I noticed while doing my unsigned-applet-confirmation patch that 
> > JNLPClassLoader instances did not always reach reference-count == 0 
> > when all their instances should have been destroyed. The first part of 
> > that was the applet synchronization issue, that I have posted a patch 
> > for.
> >
> > 3 additional problems fixed here:
> >
> > Fixed in npe-fix-and-wait-for-init.patch:
> > 1.) There was a sometimes-occurring NPE in 
> > JNLPClassLoader#getPermisions, when a CodeSource did not have an 
> > associated location when an applet was destroyed. This could cause the 
> > destroyApplet code to not finish. This was fixed with a simple null 
> > check guard. This fixes some spurious exceptions being printed out 
> > during shutdown (causing some noise in reproducer system).
> >
> > 2.) Applets can actually be destroyed from one thread *in the middle 
> > of initialization*, while somewhat hard to reproduce, spamming refresh 
> > on a many-applet page inevitably caused it. Luckily a mechanism was 
> > already in place for efficiently waiting for applets to initialize.
> >
> > Fixed in dont-interrupt-workers.patch:
> >
> > 3.) Applets were being interrupted while shutting down -- a major 
> > cause of spurious exceptions being printed out (causing even more 
> > noise in reproducer system). This interrupt facility was too 
> > heavy-weight for the desired task. Instead Java's builtin wait & 
> > notify facilities are now used to perform the same operation on a much 
> > finer scale.
> >
> > ** Note that I looked into the matter and saw that the method 
> > notifyWorkerIsFree did not actually perform the desired task and was 
> > removed as misleading. In fact the consumer thread spins around 
> > looking for free workers and did not wait for an interruption. This 
> > behaviour has not changed, and the method is not needed (nor was it 
> > needed how the code was before).
> >
> > npe-fix-and-wait-for-init.patch changes:
> > 2013-XX-XX  Adam Domurad  <adomurad at redhat.com>
> >
> >     Ensure applet destruction cannot in the middle of initialization.
> >     Prevent NPE that can sometimes occurs (especially with this change).
> >     * netx/net/sourceforge/jnlp/NetxPanel.java
> >     (destroyApplet): wait for applet initialization
> >     * netx/net/sourceforge/jnlp/runtime/JNLPClassLoader.java
> >     (getPermissions): avoid potential NPE if code source location is
> >     missing
> >
> > dont-interrupt-workers.patch changes:
> > 2013-XX-XX  Adam Domurad  <adomurad at redhat.com>
> >
> >     Don't interrupt worker/consumer threads (can prevent shutdown code 
> > from
> >     executing); instead use Object wait/notify methods.
> >     * plugin/icedteanp/java/sun/applet/PluginMessageConsumer.java
> >     (notifyHasWork): Replacement for thread interruption
> >     (waitForWork): Replacement for thread sleeping
> >     (run): Use waitForWork instead of Thread.sleep
> >     (notifyWorkerIsFree): Removed -- misleading method.
> >     * netx/net/sourceforge/jnlp/runtime/JNLPClassLoader.java
> >     (message): Make volatile, as it should have always been.
> >     (notifyHasWork): Replacement for thread interruption
> >     (waitForWork): Replacement for thread sleeping
> >     (run): Use waitForWork instead of Thread.sleep
> >     (getPermissions): avoid potential NPE if code source location is
> >     missing
> >     (free): Remove reference to notifyWorkerIsFree.
> 
> Ping ? (for dont-interrupt-workers.patch) This is IMO quite an 
> improvement for stability. It's also bugging me seeing this avoidable 
> InterruptedException over and over.
> 
> >
> >
> > I am excited to see these changes get in. I will see soon if there's 
> > any effect on the amount of noise in the test system.
> >
> > Happy hacking,
> > -Adam
> 
> -Adam




More information about the distro-pkg-dev mailing list