# HG changeset patch # User ceisserer # Date 1299019793 28800 # Node ID 78ea3ec4877b8da0b531e4bab15734779f8305de # Parent 04d00feba4883dae918033a2f51cc85b84bf0149 6974985: Jave2Demo threw exceptions when xrender enabled in OEL5.5 Reviewed-by: prr diff -r 04d00feba488 -r 78ea3ec4877b jdk/make/sun/awt/mapfile-mawt-vers --- a/jdk/make/sun/awt/mapfile-mawt-vers Mon Feb 28 10:25:17 2011 -0800 +++ b/jdk/make/sun/awt/mapfile-mawt-vers Tue Mar 01 14:49:53 2011 -0800 @@ -424,6 +424,7 @@ Java_sun_java2d_xr_XRSurfaceData_initXRPicture; Java_sun_java2d_xr_XRSurfaceData_initIDs; Java_sun_java2d_xr_XRSurfaceData_XRInitSurface; + Java_sun_java2d_xr_XRSurfaceData_freeXSDOPicture; Java_sun_java2d_xr_XRBackendNative_initIDs; Java_sun_java2d_xr_XIDGenerator_bufferXIDs; Java_sun_java2d_xr_XRBackendNative_freeGC; diff -r 04d00feba488 -r 78ea3ec4877b jdk/make/sun/xawt/mapfile-vers --- a/jdk/make/sun/xawt/mapfile-vers Mon Feb 28 10:25:17 2011 -0800 +++ b/jdk/make/sun/xawt/mapfile-vers Tue Mar 01 14:49:53 2011 -0800 @@ -374,6 +374,7 @@ Java_sun_java2d_xr_XRSurfaceData_initXRPicture; Java_sun_java2d_xr_XRSurfaceData_initIDs; Java_sun_java2d_xr_XRSurfaceData_XRInitSurface; + Java_sun_java2d_xr_XRSurfaceData_freeXSDOPicture; Java_sun_java2d_xr_XRBackendNative_initIDs; Java_sun_java2d_xr_XRBackendNative_freeGC; Java_sun_java2d_xr_XRBackendNative_createGC; diff -r 04d00feba488 -r 78ea3ec4877b jdk/src/solaris/classes/sun/java2d/xr/XRSurfaceData.java --- a/jdk/src/solaris/classes/sun/java2d/xr/XRSurfaceData.java Mon Feb 28 10:25:17 2011 -0800 +++ b/jdk/src/solaris/classes/sun/java2d/xr/XRSurfaceData.java Tue Mar 01 14:49:53 2011 -0800 @@ -55,6 +55,8 @@ native void initXRPicture(long xsdo, int pictForm); + native void freeXSDOPicture(long xsdo); + public static final String DESC_BYTE_A8_X11 = "Byte A8 Pixmap"; public static final String DESC_INT_RGB_X11 = "Integer RGB Pixmap"; public static final String DESC_INT_ARGB_X11 = "Integer ARGB-Pre Pixmap"; @@ -531,6 +533,17 @@ public Object getDestination() { return peer.getTarget(); } + + public void invalidate() { + try { + SunToolkit.awtLock(); + freeXSDOPicture(getNativeOps()); + }finally { + SunToolkit.awtUnlock(); + } + + super.invalidate(); + } } public static class XRInternalSurfaceData extends XRSurfaceData { diff -r 04d00feba488 -r 78ea3ec4877b jdk/src/solaris/native/sun/java2d/x11/X11SurfaceData.c --- a/jdk/src/solaris/native/sun/java2d/x11/X11SurfaceData.c Mon Feb 28 10:25:17 2011 -0800 +++ b/jdk/src/solaris/native/sun/java2d/x11/X11SurfaceData.c Tue Mar 01 14:49:53 2011 -0800 @@ -375,6 +375,12 @@ AWT_LOCK(); xsdo->invalid = JNI_TRUE; + + if (xsdo->xrPic != None) { + XRenderFreePicture(awt_display, xsdo->xrPic); + xsdo->xrPic = None; + } + if (xsdo->isPixmap == JNI_TRUE && xsdo->drawable != 0) { #ifdef MITSHM if (xsdo->shmPMData.shmSegInfo != NULL) { diff -r 04d00feba488 -r 78ea3ec4877b jdk/src/solaris/native/sun/java2d/x11/XRSurfaceData.c --- a/jdk/src/solaris/native/sun/java2d/x11/XRSurfaceData.c Mon Feb 28 10:25:17 2011 -0800 +++ b/jdk/src/solaris/native/sun/java2d/x11/XRSurfaceData.c Tue Mar 01 14:49:53 2011 -0800 @@ -114,3 +114,26 @@ XShared_initSurface(env, xsdo, depth, width, height, drawable); #endif /* !HEADLESS */ } + + + +JNIEXPORT void JNICALL +Java_sun_java2d_xr_XRSurfaceData_freeXSDOPicture(JNIEnv *env, jobject xsd, + jlong pXSData) +{ +#ifndef HEADLESS + X11SDOps *xsdo; + + J2dTraceLn(J2D_TRACE_INFO, "in XRSurfaceData_freeXSDOPicture"); + + xsdo = X11SurfaceData_GetOps(env, xsd); + if (xsdo == NULL) { + return; + } + + if(xsdo->xrPic != None) { + XRenderFreePicture(awt_display, xsdo->xrPic); + xsdo->xrPic = None; + } +#endif /* !HEADLESS */ +}