Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
a053b4e0
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看板
提交
a053b4e0
编写于
12月 20, 2016
作者:
P
prr
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8130737: AffineTransformOp can't handle child raster with non-zero x-offset
Reviewed-by: serb, flar
上级
da3983d9
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
109 addition
and
8 deletion
+109
-8
src/share/native/sun/awt/medialib/awt_ImagingLib.c
src/share/native/sun/awt/medialib/awt_ImagingLib.c
+8
-6
src/share/native/sun/awt/medialib/safe_alloc.h
src/share/native/sun/awt/medialib/safe_alloc.h
+2
-2
test/java/awt/image/Raster/TestChildRasterOp.java
test/java/awt/image/Raster/TestChildRasterOp.java
+99
-0
未找到文件。
src/share/native/sun/awt/medialib/awt_ImagingLib.c
浏览文件 @
a053b4e0
...
...
@@ -2418,7 +2418,7 @@ allocateRasterArray(JNIEnv *env, RasterS_t *rasterP,
case
sun_awt_image_IntegerComponentRaster_TYPE_INT_8BIT_SAMPLES
:
if
(
!
((
rasterP
->
chanOffsets
[
0
]
==
0
||
SAFE_TO_ALLOC_2
(
rasterP
->
chanOffsets
[
0
],
4
))
&&
SAFE_TO_ALLOC_2
(
width
,
4
)
&&
SAFE_TO_ALLOC_3
(
height
,
rasterP
->
scanlineStride
,
4
)))
SAFE_TO_ALLOC_3
(
rasterP
->
scanlineStride
,
height
,
4
)))
{
return
-
1
;
}
...
...
@@ -2427,7 +2427,7 @@ allocateRasterArray(JNIEnv *env, RasterS_t *rasterP,
if
(
offset
<
0
||
offset
>=
dataSize
||
width
>
rasterP
->
scanlineStride
||
height
*
rasterP
->
scanlineStride
*
4
>
dataSize
-
offset
)
((
width
+
(
height
-
1
)
*
rasterP
->
scanlineStride
)
*
4
)
>
dataSize
-
offset
)
{
// raster data buffer is too short
return
-
1
;
...
...
@@ -2445,7 +2445,7 @@ allocateRasterArray(JNIEnv *env, RasterS_t *rasterP,
return
0
;
case
sun_awt_image_IntegerComponentRaster_TYPE_BYTE_SAMPLES
:
if
(
!
(
SAFE_TO_ALLOC_2
(
width
,
rasterP
->
numBands
)
&&
SAFE_TO_ALLOC_2
(
height
,
rasterP
->
scanlineStride
)))
SAFE_TO_ALLOC_2
(
rasterP
->
scanlineStride
,
height
)))
{
return
-
1
;
}
...
...
@@ -2454,7 +2454,8 @@ allocateRasterArray(JNIEnv *env, RasterS_t *rasterP,
if
(
offset
<
0
||
offset
>=
dataSize
||
width
*
rasterP
->
numBands
>
rasterP
->
scanlineStride
||
height
*
rasterP
->
scanlineStride
>
dataSize
-
offset
)
((
width
*
rasterP
->
numBands
)
+
(
height
-
1
)
*
rasterP
->
scanlineStride
)
>
dataSize
-
offset
)
{
// raster data buffer is too short
return
-
1
;
...
...
@@ -2473,7 +2474,7 @@ allocateRasterArray(JNIEnv *env, RasterS_t *rasterP,
case
sun_awt_image_IntegerComponentRaster_TYPE_USHORT_SAMPLES
:
if
(
!
((
rasterP
->
chanOffsets
[
0
]
==
0
||
SAFE_TO_ALLOC_2
(
rasterP
->
chanOffsets
[
0
],
2
))
&&
SAFE_TO_ALLOC_3
(
width
,
rasterP
->
numBands
,
2
)
&&
SAFE_TO_ALLOC_3
(
height
,
rasterP
->
scanlineStride
,
2
)))
SAFE_TO_ALLOC_3
(
rasterP
->
scanlineStride
,
height
,
2
)))
{
return
-
1
;
}
...
...
@@ -2482,7 +2483,8 @@ allocateRasterArray(JNIEnv *env, RasterS_t *rasterP,
if
(
offset
<
0
||
offset
>=
dataSize
||
width
*
rasterP
->
numBands
>
rasterP
->
scanlineStride
||
height
*
rasterP
->
scanlineStride
*
2
>
dataSize
-
offset
)
(((
width
*
rasterP
->
numBands
)
+
(
height
-
1
)
*
rasterP
->
scanlineStride
))
*
2
>
dataSize
-
offset
)
{
// raster data buffer is too short
return
-
1
;
...
...
src/share/native/sun/awt/medialib/safe_alloc.h
浏览文件 @
a053b4e0
...
...
@@ -35,10 +35,10 @@
*/
#define SAFE_TO_ALLOC_2(c, sz) \
(((c) > 0) && ((sz) > 0) && \
((0x
ffffffffu / ((juint)(c))) > ((juint)(sz)
)))
((0x
7fffffff / (c)) > (sz
)))
#define SAFE_TO_ALLOC_3(w, h, sz) \
(((w) > 0) && ((h) > 0) && ((sz) > 0) && \
(((0x
ffffffffu / ((juint)(w))) / ((juint)(h))) > ((juint)(sz)
)))
(((0x
7fffffff / (w)) / (h)) > (sz
)))
#endif // __SAFE_ALLOC_H__
test/java/awt/image/Raster/TestChildRasterOp.java
0 → 100644
浏览文件 @
a053b4e0
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* @bug 8130737
* @test
* @summary test no exception rasterop for child raster with non-zero offset
*/
import
java.awt.geom.AffineTransform
;
import
java.awt.image.AffineTransformOp
;
import
java.awt.image.DataBuffer
;
import
java.awt.image.DataBufferByte
;
import
java.awt.image.DataBufferInt
;
import
java.awt.image.DataBufferUShort
;
import
java.awt.image.Raster
;
import
java.awt.image.WritableRaster
;
public
class
TestChildRasterOp
{
private
static
AffineTransform
at
=
new
AffineTransform
();
private
static
final
AffineTransformOp
rop
=
new
AffineTransformOp
(
at
,
AffineTransformOp
.
TYPE_NEAREST_NEIGHBOR
);
private
static
int
[]
offsets
=
{
0
};
public
static
void
main
(
String
[]
args
)
{
testByteRaster
();
testShortRaster
();
testIntRaster
();
}
private
static
void
testByteRaster
()
{
WritableRaster
srcRaster
,
dstRaster
;
byte
[]
pixels
=
{
11
,
12
,
13
,
14
,
21
,
22
,
23
,
24
,
31
,
32
,
33
,
34
,
41
,
42
,
43
,
44
};
DataBuffer
db
=
new
DataBufferByte
(
pixels
,
pixels
.
length
);
srcRaster
=
Raster
.
createInterleavedRaster
(
db
,
4
,
4
,
4
,
1
,
offsets
,
null
);
srcRaster
=
srcRaster
.
createWritableChild
(
1
,
1
,
3
,
3
,
0
,
0
,
null
);
dstRaster
=
rop
.
filter
(
srcRaster
,
null
);
}
private
static
void
testShortRaster
()
{
WritableRaster
srcRaster
,
dstRaster
;
short
[]
pixels
=
{
11
,
12
,
13
,
14
,
21
,
22
,
23
,
24
,
31
,
32
,
33
,
34
,
41
,
42
,
43
,
44
};
DataBuffer
db
=
new
DataBufferUShort
(
pixels
,
pixels
.
length
);
srcRaster
=
Raster
.
createInterleavedRaster
(
db
,
4
,
4
,
4
,
1
,
offsets
,
null
);
srcRaster
=
srcRaster
.
createWritableChild
(
1
,
1
,
3
,
3
,
0
,
0
,
null
);
dstRaster
=
rop
.
filter
(
srcRaster
,
null
);
}
private
static
void
testIntRaster
()
{
WritableRaster
srcRaster
,
dstRaster
;
int
[]
pixels
=
{
11
,
12
,
13
,
14
,
21
,
22
,
23
,
24
,
31
,
32
,
33
,
34
,
41
,
42
,
43
,
44
};
DataBuffer
db
=
new
DataBufferInt
(
pixels
,
pixels
.
length
);
srcRaster
=
Raster
.
createPackedRaster
(
db
,
4
,
4
,
4
,
offsets
,
null
);
srcRaster
=
srcRaster
.
createWritableChild
(
1
,
1
,
3
,
3
,
0
,
0
,
null
);
dstRaster
=
rop
.
filter
(
srcRaster
,
null
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录