Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
47a8febe
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
47a8febe
编写于
2月 11, 2011
作者:
P
prr
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
7018364: XShmGetImage with image's > drawable's size causes BadMatch
Reviewed-by: art, anthony Contributed-by: linuxhippy@gmail.com
上级
c24e1cd1
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
47 addition
and
15 deletion
+47
-15
src/solaris/native/sun/java2d/x11/X11SurfaceData.c
src/solaris/native/sun/java2d/x11/X11SurfaceData.c
+39
-13
src/solaris/native/sun/java2d/x11/X11SurfaceData.h
src/solaris/native/sun/java2d/x11/X11SurfaceData.h
+8
-2
未找到文件。
src/solaris/native/sun/java2d/x11/X11SurfaceData.c
浏览文件 @
47a8febe
...
@@ -595,15 +595,16 @@ XImage* X11SD_CreateSharedImage(X11SDOps *xsdo,
...
@@ -595,15 +595,16 @@ XImage* X11SD_CreateSharedImage(X11SDOps *xsdo,
}
}
XImage
*
X11SD_GetSharedImage
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
,
XImage
*
X11SD_GetSharedImage
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
,
jboolean
readBits
)
j
int
maxWidth
,
jint
maxHeight
,
j
boolean
readBits
)
{
{
XImage
*
retImage
=
NULL
;
XImage
*
retImage
=
NULL
;
if
(
cachedXImage
!=
NULL
&&
if
(
cachedXImage
!=
NULL
&&
X11SD_CachedXImageFits
(
width
,
height
,
xsdo
->
depth
,
readBits
))
{
X11SD_CachedXImageFits
(
width
,
height
,
maxWidth
,
maxHeight
,
/* sync so previous data gets flushed */
xsdo
->
depth
,
readBits
))
{
XSync
(
awt_display
,
False
);
/* sync so previous data gets flushed */
retImage
=
cachedXImage
;
XSync
(
awt_display
,
False
);
cachedXImage
=
(
XImage
*
)
NULL
;
retImage
=
cachedXImage
;
cachedXImage
=
(
XImage
*
)
NULL
;
}
else
if
(
width
*
height
*
xsdo
->
depth
>
0x10000
)
{
}
else
if
(
width
*
height
*
xsdo
->
depth
>
0x10000
)
{
retImage
=
X11SD_CreateSharedImage
(
xsdo
,
width
,
height
);
retImage
=
X11SD_CreateSharedImage
(
xsdo
,
width
,
height
);
}
}
...
@@ -728,8 +729,8 @@ void X11SD_UnPuntPixmap(X11SDOps *xsdo)
...
@@ -728,8 +729,8 @@ void X11SD_UnPuntPixmap(X11SDOps *xsdo)
* it must be close enough to avoid excessive reading from the screen;
* it must be close enough to avoid excessive reading from the screen;
* otherwise it should just be at least the size requested.
* otherwise it should just be at least the size requested.
*/
*/
jboolean
X11SD_CachedXImageFits
(
jint
width
,
jint
height
,
jint
dep
th
,
jboolean
X11SD_CachedXImageFits
(
jint
width
,
jint
height
,
jint
maxWid
th
,
jboolean
readBits
)
j
int
maxHeight
,
jint
depth
,
j
boolean
readBits
)
{
{
/* we assume here that the cached image exists */
/* we assume here that the cached image exists */
jint
imgWidth
=
cachedXImage
->
width
;
jint
imgWidth
=
cachedXImage
->
width
;
...
@@ -747,10 +748,14 @@ jboolean X11SD_CachedXImageFits(jint width, jint height, jint depth,
...
@@ -747,10 +748,14 @@ jboolean X11SD_CachedXImageFits(jint width, jint height, jint depth,
return
JNI_TRUE
;
return
JNI_TRUE
;
}
}
if
((
imgWidth
<
width
+
64
)
&&
(
imgHeight
<
height
+
64
))
{
if
((
imgWidth
<
width
+
64
)
&&
(
imgHeight
<
height
+
64
)
&&
imgWidth
<=
maxWidth
&&
imgHeight
<=
maxHeight
)
{
/* Cached image's width/height shouldn't be more than 64 pixels
/* Cached image's width/height shouldn't be more than 64 pixels
* larger than requested, because the region in XShmGetImage
* larger than requested, because the region in XShmGetImage
* can't be specified and we don't want to read too much.
* can't be specified and we don't want to read too much.
* Furthermore it has to be smaller than maxWidth/Height
* so drawables are not read out of bounds.
*/
*/
return
JNI_TRUE
;
return
JNI_TRUE
;
}
}
...
@@ -1295,7 +1300,7 @@ static XImage * X11SD_GetImage(JNIEnv *env, X11SDOps *xsdo,
...
@@ -1295,7 +1300,7 @@ static XImage * X11SD_GetImage(JNIEnv *env, X11SDOps *xsdo,
SurfaceDataBounds
*
bounds
,
SurfaceDataBounds
*
bounds
,
jint
lockFlags
)
jint
lockFlags
)
{
{
int
x
,
y
,
w
,
h
;
int
x
,
y
,
w
,
h
,
maxWidth
,
maxHeight
;
int
scan
;
int
scan
;
XImage
*
img
=
NULL
;
XImage
*
img
=
NULL
;
Drawable
drawable
;
Drawable
drawable
;
...
@@ -1311,10 +1316,31 @@ static XImage * X11SD_GetImage(JNIEnv *env, X11SDOps *xsdo,
...
@@ -1311,10 +1316,31 @@ static XImage * X11SD_GetImage(JNIEnv *env, X11SDOps *xsdo,
#ifdef MITSHM
#ifdef MITSHM
if
(
useMitShmExt
==
CAN_USE_MITSHM
)
{
if
(
useMitShmExt
==
CAN_USE_MITSHM
)
{
if
(
xsdo
->
isPixmap
&&
readBits
)
{
if
(
xsdo
->
isPixmap
)
{
X11SD_PuntPixmap
(
xsdo
,
w
,
h
);
if
(
readBits
)
{
X11SD_PuntPixmap
(
xsdo
,
w
,
h
);
}
maxWidth
=
xsdo
->
pmWidth
;
maxHeight
=
xsdo
->
pmHeight
;
}
else
{
XWindowAttributes
winAttr
;
if
(
XGetWindowAttributes
(
awt_display
,
(
Window
)
xsdo
->
drawable
,
&
winAttr
)
!=
0
)
{
maxWidth
=
winAttr
.
width
;
maxHeight
=
winAttr
.
height
;
}
else
{
/* XGWA failed which isn't a good thing. Defaulting to using
* x,y means that after the subtraction of these we will use
* w=0, h=0 which is a reasonable default on such a failure.
*/
maxWidth
=
x
;
maxHeight
=
y
;
}
}
}
img
=
X11SD_GetSharedImage
(
xsdo
,
w
,
h
,
readBits
);
maxWidth
-=
x
;
maxHeight
-=
y
;
img
=
X11SD_GetSharedImage
(
xsdo
,
w
,
h
,
maxWidth
,
maxHeight
,
readBits
);
}
}
#endif
/* MITSHM */
#endif
/* MITSHM */
drawable
=
xsdo
->
drawable
;
drawable
=
xsdo
->
drawable
;
...
...
src/solaris/native/sun/java2d/x11/X11SurfaceData.h
浏览文件 @
47a8febe
...
@@ -125,15 +125,21 @@ struct _X11SDOps {
...
@@ -125,15 +125,21 @@ struct _X11SDOps {
#define X11SD_LOCK_BY_SHMEM 4
/* surface locked by ShMemExt */
#define X11SD_LOCK_BY_SHMEM 4
/* surface locked by ShMemExt */
#ifdef MITSHM
#ifdef MITSHM
XImage
*
X11SD_GetSharedImage
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
,
jboolean
readBits
);
XImage
*
X11SD_GetSharedImage
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
,
jint
maxWidth
,
jint
maxHeight
,
jboolean
readBits
);
XImage
*
X11SD_CreateSharedImage
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
);
XImage
*
X11SD_CreateSharedImage
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
);
Drawable
X11SD_CreateSharedPixmap
(
X11SDOps
*
xsdo
);
Drawable
X11SD_CreateSharedPixmap
(
X11SDOps
*
xsdo
);
void
X11SD_DropSharedSegment
(
XShmSegmentInfo
*
shminfo
);
void
X11SD_DropSharedSegment
(
XShmSegmentInfo
*
shminfo
);
void
X11SD_PuntPixmap
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
);
void
X11SD_PuntPixmap
(
X11SDOps
*
xsdo
,
jint
width
,
jint
height
);
void
X11SD_UnPuntPixmap
(
X11SDOps
*
xsdo
);
void
X11SD_UnPuntPixmap
(
X11SDOps
*
xsdo
);
jboolean
X11SD_CachedXImageFits
(
jint
width
,
jint
height
,
jint
depth
,
jboolean
readBits
);
jboolean
X11SD_CachedXImageFits
(
jint
width
,
jint
height
,
jint
maxWidth
,
jint
maxHeight
,
jint
depth
,
jboolean
readBits
);
XImage
*
X11SD_GetCachedXImage
(
jint
width
,
jint
height
,
jboolean
readBits
);
XImage
*
X11SD_GetCachedXImage
(
jint
width
,
jint
height
,
jboolean
readBits
);
#endif
/* MITSHM */
#endif
/* MITSHM */
jint
X11SD_InitWindow
(
JNIEnv
*
env
,
X11SDOps
*
xsdo
);
void
X11SD_DisposeOrCacheXImage
(
XImage
*
image
);
void
X11SD_DisposeOrCacheXImage
(
XImage
*
image
);
void
X11SD_DisposeXImage
(
XImage
*
image
);
void
X11SD_DisposeXImage
(
XImage
*
image
);
void
X11SD_DirectRenderNotify
(
JNIEnv
*
env
,
X11SDOps
*
xsdo
);
void
X11SD_DirectRenderNotify
(
JNIEnv
*
env
,
X11SDOps
*
xsdo
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录