Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
fbacd3c5
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看板
提交
fbacd3c5
编写于
3月 21, 2017
作者:
A
asaha
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
fc9353fb
cff5f878
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
132 addition
and
24 deletion
+132
-24
.hgtags
.hgtags
+1
-0
src/share/classes/java/util/concurrent/ThreadPoolExecutor.java
...hare/classes/java/util/concurrent/ThreadPoolExecutor.java
+20
-1
src/share/classes/java/util/jar/JarVerifier.java
src/share/classes/java/util/jar/JarVerifier.java
+7
-5
src/share/classes/javax/imageio/spi/ServiceRegistry.java
src/share/classes/javax/imageio/spi/ServiceRegistry.java
+17
-4
src/share/classes/sun/awt/image/ImageWatched.java
src/share/classes/sun/awt/image/ImageWatched.java
+30
-3
src/share/classes/sun/nio/ch/AsynchronousChannelGroupImpl.java
...hare/classes/sun/nio/ch/AsynchronousChannelGroupImpl.java
+11
-8
src/share/classes/sun/security/util/ManifestEntryVerifier.java
...hare/classes/sun/security/util/ManifestEntryVerifier.java
+7
-2
src/share/native/common/check_code.c
src/share/native/common/check_code.c
+39
-1
未找到文件。
.hgtags
浏览文件 @
fbacd3c5
...
@@ -695,3 +695,4 @@ f5d0aadb4d1ca74eda4e98cc0030f1618ef4c870 jdk8u131-b07
...
@@ -695,3 +695,4 @@ f5d0aadb4d1ca74eda4e98cc0030f1618ef4c870 jdk8u131-b07
c0091a673d766ce2e76a945bab6de325fe78dd88 jdk8u131-b10
c0091a673d766ce2e76a945bab6de325fe78dd88 jdk8u131-b10
3ab471c4760a808e39406303ff33a25a542b9c75 jdk8u131-b11
3ab471c4760a808e39406303ff33a25a542b9c75 jdk8u131-b11
a160009bbe1417d85f1c0eec890fdb17391b3637 jdk8u141-b00
a160009bbe1417d85f1c0eec890fdb17391b3637 jdk8u141-b00
e95a13de2d36050302a1af422967f5260fc8eabd jdk8u141-b01
src/share/classes/java/util/concurrent/ThreadPoolExecutor.java
浏览文件 @
fbacd3c5
...
@@ -34,6 +34,10 @@
...
@@ -34,6 +34,10 @@
*/
*/
package
java.util.concurrent
;
package
java.util.concurrent
;
import
java.security.AccessControlContext
;
import
java.security.AccessController
;
import
java.security.PrivilegedAction
;
import
java.util.concurrent.locks.AbstractQueuedSynchronizer
;
import
java.util.concurrent.locks.AbstractQueuedSynchronizer
;
import
java.util.concurrent.locks.Condition
;
import
java.util.concurrent.locks.Condition
;
import
java.util.concurrent.locks.ReentrantLock
;
import
java.util.concurrent.locks.ReentrantLock
;
...
@@ -569,6 +573,9 @@ public class ThreadPoolExecutor extends AbstractExecutorService {
...
@@ -569,6 +573,9 @@ public class ThreadPoolExecutor extends AbstractExecutorService {
private
static
final
RuntimePermission
shutdownPerm
=
private
static
final
RuntimePermission
shutdownPerm
=
new
RuntimePermission
(
"modifyThread"
);
new
RuntimePermission
(
"modifyThread"
);
/* The context to be used when executing the finalizer, or null. */
private
final
AccessControlContext
acc
;
/**
/**
* Class Worker mainly maintains interrupt control state for
* Class Worker mainly maintains interrupt control state for
* threads running tasks, along with other minor bookkeeping.
* threads running tasks, along with other minor bookkeeping.
...
@@ -1307,6 +1314,9 @@ public class ThreadPoolExecutor extends AbstractExecutorService {
...
@@ -1307,6 +1314,9 @@ public class ThreadPoolExecutor extends AbstractExecutorService {
throw
new
IllegalArgumentException
();
throw
new
IllegalArgumentException
();
if
(
workQueue
==
null
||
threadFactory
==
null
||
handler
==
null
)
if
(
workQueue
==
null
||
threadFactory
==
null
||
handler
==
null
)
throw
new
NullPointerException
();
throw
new
NullPointerException
();
this
.
acc
=
System
.
getSecurityManager
()
==
null
?
null
:
AccessController
.
getContext
();
this
.
corePoolSize
=
corePoolSize
;
this
.
corePoolSize
=
corePoolSize
;
this
.
maximumPoolSize
=
maximumPoolSize
;
this
.
maximumPoolSize
=
maximumPoolSize
;
this
.
workQueue
=
workQueue
;
this
.
workQueue
=
workQueue
;
...
@@ -1472,9 +1482,18 @@ public class ThreadPoolExecutor extends AbstractExecutorService {
...
@@ -1472,9 +1482,18 @@ public class ThreadPoolExecutor extends AbstractExecutorService {
/**
/**
* Invokes {@code shutdown} when this executor is no longer
* Invokes {@code shutdown} when this executor is no longer
* referenced and it has no threads.
* referenced and it has no threads.
*
* <p>This method is invoked with privileges that are restricted by
* the security context of the caller that invokes the constructor.
*/
*/
protected
void
finalize
()
{
protected
void
finalize
()
{
shutdown
();
SecurityManager
sm
=
System
.
getSecurityManager
();
if
(
sm
==
null
||
acc
==
null
)
{
shutdown
();
}
else
{
PrivilegedAction
<
Void
>
pa
=
()
->
{
shutdown
();
return
null
;
};
AccessController
.
doPrivileged
(
pa
,
acc
);
}
}
}
/**
/**
...
...
src/share/classes/java/util/jar/JarVerifier.java
浏览文件 @
fbacd3c5
/*
/*
* Copyright (c) 1997, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1997, 201
7
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -180,10 +180,12 @@ class JarVerifier {
...
@@ -180,10 +180,12 @@ class JarVerifier {
// only set the jev object for entries that have a signature
// only set the jev object for entries that have a signature
// (either verified or not)
// (either verified or not)
if
(
sigFileSigners
.
get
(
name
)
!=
null
||
if
(!
name
.
equals
(
JarFile
.
MANIFEST_NAME
))
{
verifiedSigners
.
get
(
name
)
!=
null
)
{
if
(
sigFileSigners
.
get
(
name
)
!=
null
||
mev
.
setEntry
(
name
,
je
);
verifiedSigners
.
get
(
name
)
!=
null
)
{
return
;
mev
.
setEntry
(
name
,
je
);
return
;
}
}
}
// don't compute the digest for this entry
// don't compute the digest for this entry
...
...
src/share/classes/javax/imageio/spi/ServiceRegistry.java
浏览文件 @
fbacd3c5
...
@@ -26,6 +26,9 @@
...
@@ -26,6 +26,9 @@
package
javax.imageio.spi
;
package
javax.imageio.spi
;
import
java.io.File
;
import
java.io.File
;
import
java.security.AccessControlContext
;
import
java.security.AccessController
;
import
java.security.PrivilegedAction
;
import
java.util.ArrayList
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.HashMap
;
import
java.util.Iterator
;
import
java.util.Iterator
;
...
@@ -701,11 +704,12 @@ class SubRegistry {
...
@@ -701,11 +704,12 @@ class SubRegistry {
Class
category
;
Class
category
;
// Provider Objects organized by partial or
i
dering
// Provider Objects organized by partial ordering
PartiallyOrderedSet
poset
=
new
PartiallyOrderedSet
();
final
PartiallyOrderedSet
poset
=
new
PartiallyOrderedSet
();
// Class -> Provider Object of that class
// Class -> Provider Object of that class
Map
<
Class
<?>,
Object
>
map
=
new
HashMap
();
final
Map
<
Class
<?>,
Object
>
map
=
new
HashMap
();
final
Map
<
Class
<?>,
AccessControlContext
>
accMap
=
new
HashMap
<>();
public
SubRegistry
(
ServiceRegistry
registry
,
Class
category
)
{
public
SubRegistry
(
ServiceRegistry
registry
,
Class
category
)
{
this
.
registry
=
registry
;
this
.
registry
=
registry
;
...
@@ -720,6 +724,7 @@ class SubRegistry {
...
@@ -720,6 +724,7 @@ class SubRegistry {
deregisterServiceProvider
(
oprovider
);
deregisterServiceProvider
(
oprovider
);
}
}
map
.
put
(
provider
.
getClass
(),
provider
);
map
.
put
(
provider
.
getClass
(),
provider
);
accMap
.
put
(
provider
.
getClass
(),
AccessController
.
getContext
());
poset
.
add
(
provider
);
poset
.
add
(
provider
);
if
(
provider
instanceof
RegisterableService
)
{
if
(
provider
instanceof
RegisterableService
)
{
RegisterableService
rs
=
(
RegisterableService
)
provider
;
RegisterableService
rs
=
(
RegisterableService
)
provider
;
...
@@ -739,6 +744,7 @@ class SubRegistry {
...
@@ -739,6 +744,7 @@ class SubRegistry {
if
(
provider
==
oprovider
)
{
if
(
provider
==
oprovider
)
{
map
.
remove
(
provider
.
getClass
());
map
.
remove
(
provider
.
getClass
());
accMap
.
remove
(
provider
.
getClass
());
poset
.
remove
(
provider
);
poset
.
remove
(
provider
);
if
(
provider
instanceof
RegisterableService
)
{
if
(
provider
instanceof
RegisterableService
)
{
RegisterableService
rs
=
(
RegisterableService
)
provider
;
RegisterableService
rs
=
(
RegisterableService
)
provider
;
...
@@ -785,10 +791,17 @@ class SubRegistry {
...
@@ -785,10 +791,17 @@ class SubRegistry {
if
(
provider
instanceof
RegisterableService
)
{
if
(
provider
instanceof
RegisterableService
)
{
RegisterableService
rs
=
(
RegisterableService
)
provider
;
RegisterableService
rs
=
(
RegisterableService
)
provider
;
rs
.
onDeregistration
(
registry
,
category
);
AccessControlContext
acc
=
accMap
.
get
(
provider
.
getClass
());
if
(
acc
!=
null
||
System
.
getSecurityManager
()
==
null
)
{
AccessController
.
doPrivileged
((
PrivilegedAction
<
Void
>)
()
->
{
rs
.
onDeregistration
(
registry
,
category
);
return
null
;
},
acc
);
}
}
}
}
}
poset
.
clear
();
poset
.
clear
();
accMap
.
clear
();
}
}
public
void
finalize
()
{
public
void
finalize
()
{
...
...
src/share/classes/sun/awt/image/ImageWatched.java
浏览文件 @
fbacd3c5
...
@@ -29,6 +29,10 @@ import java.lang.ref.WeakReference;
...
@@ -29,6 +29,10 @@ import java.lang.ref.WeakReference;
import
java.awt.Image
;
import
java.awt.Image
;
import
java.awt.image.ImageObserver
;
import
java.awt.image.ImageObserver
;
import
java.security.AccessControlContext
;
import
java.security.AccessController
;
import
java.security.PrivilegedAction
;
public
abstract
class
ImageWatched
{
public
abstract
class
ImageWatched
{
public
static
Link
endlink
=
new
Link
();
public
static
Link
endlink
=
new
Link
();
...
@@ -85,16 +89,26 @@ public abstract class ImageWatched {
...
@@ -85,16 +89,26 @@ public abstract class ImageWatched {
}
}
}
}
static
class
AccWeakReference
<
T
>
extends
WeakReference
<
T
>
{
private
final
AccessControlContext
acc
;
AccWeakReference
(
T
ref
)
{
super
(
ref
);
acc
=
AccessController
.
getContext
();
}
}
/*
/*
* Standard Link implementation to manage a Weak Reference
* Standard Link implementation to manage a Weak Reference
* to an ImageObserver.
* to an ImageObserver.
*/
*/
public
static
class
WeakLink
extends
Link
{
public
static
class
WeakLink
extends
Link
{
private
WeakReference
<
ImageObserver
>
myref
;
private
final
Acc
WeakReference
<
ImageObserver
>
myref
;
private
Link
next
;
private
Link
next
;
public
WeakLink
(
ImageObserver
obs
,
Link
next
)
{
public
WeakLink
(
ImageObserver
obs
,
Link
next
)
{
myref
=
new
WeakReference
<
ImageObserver
>(
obs
);
myref
=
new
Acc
WeakReference
<
ImageObserver
>(
obs
);
this
.
next
=
next
;
this
.
next
=
next
;
}
}
...
@@ -120,6 +134,19 @@ public abstract class ImageWatched {
...
@@ -120,6 +134,19 @@ public abstract class ImageWatched {
return
this
;
return
this
;
}
}
private
static
boolean
update
(
ImageObserver
iw
,
AccessControlContext
acc
,
Image
img
,
int
info
,
int
x
,
int
y
,
int
w
,
int
h
)
{
if
(
acc
!=
null
||
System
.
getSecurityManager
()
!=
null
)
{
return
AccessController
.
doPrivileged
(
(
PrivilegedAction
<
Boolean
>)
()
->
{
return
iw
.
imageUpdate
(
img
,
info
,
x
,
y
,
w
,
h
);
},
acc
);
}
return
false
;
}
public
boolean
newInfo
(
Image
img
,
int
info
,
public
boolean
newInfo
(
Image
img
,
int
info
,
int
x
,
int
y
,
int
w
,
int
h
)
int
x
,
int
y
,
int
w
,
int
h
)
{
{
...
@@ -129,7 +156,7 @@ public abstract class ImageWatched {
...
@@ -129,7 +156,7 @@ public abstract class ImageWatched {
if
(
myiw
==
null
)
{
if
(
myiw
==
null
)
{
// My referent is null so we must prune in a second pass.
// My referent is null so we must prune in a second pass.
ret
=
true
;
ret
=
true
;
}
else
if
(
myiw
.
imageUpdate
(
img
,
info
,
x
,
y
,
w
,
h
)
==
false
)
{
}
else
if
(
update
(
myiw
,
myref
.
acc
,
img
,
info
,
x
,
y
,
w
,
h
)
==
false
)
{
// My referent has lost interest so clear it and ask
// My referent has lost interest so clear it and ask
// for a pruning pass to remove it later.
// for a pruning pass to remove it later.
myref
.
clear
();
myref
.
clear
();
...
...
src/share/classes/sun/nio/ch/AsynchronousChannelGroupImpl.java
浏览文件 @
fbacd3c5
/*
/*
* Copyright (c) 2008, 20
09
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2008, 20
17
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -246,13 +246,16 @@ abstract class AsynchronousChannelGroupImpl
...
@@ -246,13 +246,16 @@ abstract class AsynchronousChannelGroupImpl
abstract
void
shutdownHandlerTasks
();
abstract
void
shutdownHandlerTasks
();
private
void
shutdownExecutors
()
{
private
void
shutdownExecutors
()
{
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
Void
>()
{
AccessController
.
doPrivileged
(
public
Void
run
()
{
new
PrivilegedAction
<
Void
>()
{
pool
.
executor
().
shutdown
();
public
Void
run
()
{
timeoutExecutor
.
shutdown
();
pool
.
executor
().
shutdown
();
return
null
;
timeoutExecutor
.
shutdown
();
}
return
null
;
});
}
},
null
,
new
RuntimePermission
(
"modifyThread"
));
}
}
@Override
@Override
...
...
src/share/classes/sun/security/util/ManifestEntryVerifier.java
浏览文件 @
fbacd3c5
/*
/*
* Copyright (c) 1997, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1997, 201
7
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -107,6 +107,8 @@ public class ManifestEntryVerifier {
...
@@ -107,6 +107,8 @@ public class ManifestEntryVerifier {
/* get the headers from the manifest for this entry */
/* get the headers from the manifest for this entry */
/* if there aren't any, we can't verify any digests for this entry */
/* if there aren't any, we can't verify any digests for this entry */
skip
=
false
;
Attributes
attr
=
man
.
getAttributes
(
name
);
Attributes
attr
=
man
.
getAttributes
(
name
);
if
(
attr
==
null
)
{
if
(
attr
==
null
)
{
// ugh. we should be able to remove this at some point.
// ugh. we should be able to remove this at some point.
...
@@ -141,7 +143,6 @@ public class ManifestEntryVerifier {
...
@@ -141,7 +143,6 @@ public class ManifestEntryVerifier {
}
}
if
(
digest
!=
null
)
{
if
(
digest
!=
null
)
{
skip
=
false
;
digest
.
reset
();
digest
.
reset
();
digests
.
add
(
digest
);
digests
.
add
(
digest
);
manifestHashes
.
add
(
manifestHashes
.
add
(
...
@@ -197,6 +198,10 @@ public class ManifestEntryVerifier {
...
@@ -197,6 +198,10 @@ public class ManifestEntryVerifier {
return
null
;
return
null
;
}
}
if
(
digests
.
isEmpty
())
{
throw
new
SecurityException
(
"digest missing for "
+
name
);
}
if
(
signers
!=
null
)
if
(
signers
!=
null
)
return
signers
;
return
signers
;
...
...
src/share/native/common/check_code.c
浏览文件 @
fbacd3c5
...
@@ -457,6 +457,8 @@ static void *CCalloc(context_type *context, int size, jboolean zero);
...
@@ -457,6 +457,8 @@ static void *CCalloc(context_type *context, int size, jboolean zero);
static
fullinfo_type
cp_index_to_class_fullinfo
(
context_type
*
,
int
,
int
);
static
fullinfo_type
cp_index_to_class_fullinfo
(
context_type
*
,
int
,
int
);
static
const
char
*
get_result_signature
(
const
char
*
signature
);
static
char
signature_to_fieldtype
(
context_type
*
context
,
static
char
signature_to_fieldtype
(
context_type
*
context
,
const
char
**
signature_p
,
fullinfo_type
*
info
);
const
char
**
signature_p
,
fullinfo_type
*
info
);
...
@@ -2775,7 +2777,7 @@ push_stack(context_type *context, unsigned int inumber, stack_info_type *new_sta
...
@@ -2775,7 +2777,7 @@ push_stack(context_type *context, unsigned int inumber, stack_info_type *new_sta
operand
);
operand
);
const
char
*
result_signature
;
const
char
*
result_signature
;
check_and_push
(
context
,
signature
,
VM_STRING_UTF
);
check_and_push
(
context
,
signature
,
VM_STRING_UTF
);
result_signature
=
strchr
(
signature
,
JVM_SIGNATURE_ENDFUNC
);
result_signature
=
get_result_signature
(
signature
);
if
(
result_signature
++
==
NULL
)
{
if
(
result_signature
++
==
NULL
)
{
CCerror
(
context
,
"Illegal signature %s"
,
signature
);
CCerror
(
context
,
"Illegal signature %s"
,
signature
);
}
}
...
@@ -3698,6 +3700,42 @@ CFerror(context_type *context, char *format, ...)
...
@@ -3698,6 +3700,42 @@ CFerror(context_type *context, char *format, ...)
longjmp
(
context
->
jump_buffer
,
1
);
longjmp
(
context
->
jump_buffer
,
1
);
}
}
/*
* Need to scan the entire signature to find the result type because
* types in the arg list and the result type could contain embedded ')'s.
*/
static
const
char
*
get_result_signature
(
const
char
*
signature
)
{
const
char
*
p
;
for
(
p
=
signature
;
*
p
!=
JVM_SIGNATURE_ENDFUNC
;
p
++
)
{
switch
(
*
p
)
{
case
JVM_SIGNATURE_BOOLEAN
:
case
JVM_SIGNATURE_BYTE
:
case
JVM_SIGNATURE_CHAR
:
case
JVM_SIGNATURE_SHORT
:
case
JVM_SIGNATURE_INT
:
case
JVM_SIGNATURE_FLOAT
:
case
JVM_SIGNATURE_DOUBLE
:
case
JVM_SIGNATURE_LONG
:
case
JVM_SIGNATURE_FUNC
:
/* ignore initial (, if given */
break
;
case
JVM_SIGNATURE_CLASS
:
while
(
*
p
!=
JVM_SIGNATURE_ENDCLASS
)
p
++
;
break
;
case
JVM_SIGNATURE_ARRAY
:
while
(
*
p
==
JVM_SIGNATURE_ARRAY
)
p
++
;
/* If an array of classes, skip over class name, too. */
if
(
*
p
==
JVM_SIGNATURE_CLASS
)
{
while
(
*
p
!=
JVM_SIGNATURE_ENDCLASS
)
p
++
;
}
break
;
default:
/* Indicate an error. */
return
NULL
;
}
}
return
p
++
;
/* skip over ')'. */
}
static
char
static
char
signature_to_fieldtype
(
context_type
*
context
,
signature_to_fieldtype
(
context_type
*
context
,
const
char
**
signature_p
,
fullinfo_type
*
full_info_p
)
const
char
**
signature_p
,
fullinfo_type
*
full_info_p
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录