<AWT Dev> [7u] Review request for 8005607: Recursion in J2DXErrHandler() Causes a Stack Overflow on Linux

Anton Litvinov anton.litvinov at oracle.com
Tue Jul 9 02:30:16 PDT 2013


Hello Artem and Anthony,

Could you please review this backport of the fix, which was approved by you for JDK 8, from JDK 8 to JDK 7.

Bug: http://bugs.sun.com/view_bug.do?bug_id=8005607
Webrev: http://cr.openjdk.java.net/~alitvinov/8005607/jdk7/webrev.00
JDK 8 webrev: http://cr.openjdk.java.net/~alitvinov/8005607/webrev.05

This fix is identical to the original fix for JDK 8 with the exception of the following places:

1) The new macro "GET_XERROR_CODE" was added in the file "src/solaris/native/sun/awt/awt_util.h". This macro allows native code to get "error_code" value of a saved XErrorEvent object from the global toolkit error handler in Java code. This variable is used in functions defined in the files "awt_wm.c", "awt_xembed_server.c".

138 #define GET_XERROR_CODE(env, savedError, errorCode) do {

2) The following 3 native XError handlers were substituted for the corresponding Java synthetic analogs in the files "src/solaris/native/sun/awt/awt_wm.c", "src/solaris/native/sun/awt/awt_xembed_server.c".

a. xerror_ignore_bad_window(Display *dpy, XErrorEvent *err) --> Existing "sun.awt.X11.XErrorHandler.IgnoreBadWindowHandler"

b. xerror_verify_change_property(Display *dpy, XErrorEvent *err) --> Existing "sun.awt.X11.XErrorHandler.VerifyChangePropertyHandler"

c. xerror_detect_wm(Display *dpy, XErrorEvent *err) --> Created "sun.awt.X11.XErrorHandler.XChangeWindowAttributesHandler"

3) The fix for JDK-8015730, which is the regression of the fix for JDK-8005607 discovered in JDK 8, was ported to JDK 7 as part of this backport fix without any changes.

The fix was tested by means of a manual testcase attached to the bug's record in JBS both on Linux OS and on Oracle Solaris OS.

Thank you,
Anton



More information about the awt-dev mailing list