Summary: | NewtCanvasSWT Hangs Sporadically During Window Resizing | ||
---|---|---|---|
Product: | [JogAmp] Newt | Reporter: | Rob Hatcherson <rob.hatcherson> |
Component: | x11 | Assignee: | Sven Gothel <sgothel> |
Status: | RESOLVED FIXED | ||
Severity: | major | ||
Priority: | --- | ||
Version: | 1 | ||
Hardware: | pc_x86_32 | ||
OS: | linux | ||
Type: | --- | SCM Refs: |
jogl a349db5086a7be7dd80fc2ad29a8a4b55f343e01
jogl f24844c5e6c57a43df79224f2d3a89e9720726f7
jogl b6fa407d4bf19ef9fe387454b5eeca68853532b9
jogl 8cf694c1424277e6358039a964ecd75c54cf9af9
jogl 17dd761d7c2b224f0505a399bf4ecb18634e9250
|
Workaround: | --- | ||
Attachments: | test.sh output plus standalone SWT app that demos the issue |
Description
Rob Hatcherson
2012-10-11 19:42:49 CEST
On second thought, should this be filed as a NEWT bug (?). (In reply to comment #1) > On second thought, should this be filed as a NEWT bug (?). Yes, done :) Any progress ? I had not time yet to test this issue, maybe next weeks. This one I have not looked at. It has the feel of something that you could fix a lot quicker than you could field the pile of questions I'd probably have about your exclusive access policies as I tried to figure out what's going on. Regardless, if time permits at some point soon then I'll take a closer look. If I don't get anywhere then we're no worse off. (In reply to comment #3) > This one I have not looked at. It has the feel of something that you could fix > a lot quicker than you could field the pile of questions I'd probably have > about your exclusive access policies as I tried to figure out what's going on. Whats 'exclusive access policies' ? > > Regardless, if time permits at some point soon then I'll take a closer look. > If I don't get anywhere then we're no worse off. It's ok .. maybe next week I can at least validate and try to reproduce the issue. If it is reproducible, I agree .. I may be able to handle it 'quicker'. So .. let's say till next week on this issue. > Whats 'exclusive access policies' ?
As in an understanding about what resources need to be protected with locks and why. "Critical sections" might have been a better term to use.
Judging by the backtrace there is some of that going on here. It is often a recipe for disaster when a less-familiar-with-the-project-yet-generally-not-too-afraid-of-changing-stuff individual (such as myself in this case :-) ) comes along and starts swinging a bat around in code whose motivations are not well understood.
As mentioned in one of my previous blurbs, on my machine at least the test app was able to reproduce the issue reliably, but not deterministically. So... hopefully if you are patient with the test app it eventually will reward you with a lockup.
Not sure why it is so much quicker to lock up when it's SWT running in a RCP app. In that case I can pretty much get the lockup within 5 seconds. The standalone SWT test app on the other hand may require up to a minute. But... the SWT test app is so much simpler than the RCP test app it seemed like that's what I should provide. Plus I needed to be sure RCP itself wasn't causing the problem, though clearly its presence has an effect.
reproduced, currently analyzing deadlock which is due to running a mutable NEWT Window operation not on it's EDT. Reliable reproduction of deadlock: http://jogamp.org/git/?p=jogl.git;a=commit;h=a349db5086a7be7dd80fc2ad29a8a4b55f343e01 Fix: http://jogamp.org/git/?p=jogl.git;a=commit;h=f24844c5e6c57a43df79224f2d3a89e9720726f7 Following JOGL commits complements the SWT/AWT deadlock fix b6fa407d4bf19ef9fe387454b5eeca68853532b9 8cf694c1424277e6358039a964ecd75c54cf9af9 17dd761d7c2b224f0505a399bf4ecb18634e9250 Commit 8cf694c1424277e6358039a964ecd75c54cf9af9 also allows usage of SWT 4.3.0 I've been unable to reproduce the deadlock after the fix, so that part is good. However, assuming all my builds are good, the problem discussed at the forum link below appears to have come back: http://forum.jogamp.org/Reshape-Problem-Using-NewtCanvasSWT-td4026385.html Not exactly sure of the right way to report this with git, but the last commit I see in my project from Sven's master using "git log" says: commit f25b5c973150252af5c5fbf4ca87b03e2e9aee32 Author: Sven Gothel <sgothel@jausoft.com> Date: Tue Nov 27 19:04:20 2012 +0100 (In reply to comment #9) > I've been unable to reproduce the deadlock after the fix, so that part is good. > However, assuming all my builds are good, the problem discussed at the forum > link below appears to have come back: > > http://forum.jogamp.org/Reshape-Problem-Using-NewtCanvasSWT-td4026385.html > > > Not exactly sure of the right way to report this with git, but the last commit > I see in my project from Sven's master using "git log" says: > > commit f25b5c973150252af5c5fbf4ca87b03e2e9aee32 > Author: Sven Gothel <sgothel@jausoft.com> > Date: Tue Nov 27 19:04:20 2012 +0100 Well, I don't know - just passed all SWT unit tests incl.: <http://jogamp.org/git/?p=jogl.git;a=blob;f=src/test/com/jogamp/opengl/test/junit/jogl/swt/TestNewtCanvasSWTBug628ResizeDeadlock.java;h=a0874e609dfd28da3c220b65948a8cd6943f076d;hb=HEAD> If you still have troubles, pls try to adapt this unit test to reproduce the freeze. Hi Sven, Just to be sure I was clear... I was *not* having problems with the freeze anymore; that all worked great after your fix for this bug. However, an earlier problem where expose, resize, etc events would not get delivered seems to have reappeared. You had fixed this problem a while back, so it looks like a regression (?). The forum post I mentioned discussed this issue. Can't remember if we filed bug on it. Are you saying that you aren't seeing the event delivery issue in your latest build, and/or you have a test case for it that suggests the problem is not there in a build from your current master? (In reply to comment #11) > Hi Sven, > > Just to be sure I was clear... I was *not* having problems with the freeze > anymore; that all worked great after your fix for this bug. Ah .. ok, thx a lot - I was confused w/ the many SWT issues :) > > However, an earlier problem where expose, resize, etc events would not get > delivered seems to have reappeared. You had fixed this problem a while back, > so it looks like a regression (?). The forum post I mentioned discussed this > issue. Can't remember if we filed bug on it. No bug report, but I fixed the 'sendReshape' in SWT GLCanvas updateSizeCheck(). > > Are you saying that you aren't seeing the event delivery issue in your latest > build, and/or you have a test case for it that suggests the problem is not > there in a build from your current master? I did overhaul our SWT GLCanvas, see: <http://jogamp.org/git/?p=jogl.git;&a=commit&h=7cb6cf2a9708d3f4e06f2215eb0d06b00fa6cd15> tested manual here on X11 and Windows .. jenkins busy now, let's see. I just now (12/6/2012, noon local time) sync'd up with your master and tried this again, and at the moment everything appears to be work correctly. No deadlock, and reshapes are happening when they should. This is most excellent. FWIW the last commit I see from you in my clone is 7a6f6b7a5b028e918a843de9fe16c38da75edba9. |