Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
1333b155
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看板
提交
1333b155
编写于
2月 12, 2016
作者:
R
robm
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
f23a11d9
906a8055
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
68 addition
and
22 deletion
+68
-22
src/share/classes/org/jcp/xml/dsig/internal/dom/DOMURIDereferencer.java
...ses/org/jcp/xml/dsig/internal/dom/DOMURIDereferencer.java
+3
-2
src/share/classes/sun/rmi/transport/DGCAckHandler.java
src/share/classes/sun/rmi/transport/DGCAckHandler.java
+4
-1
src/solaris/classes/sun/awt/X11/XBaseWindow.java
src/solaris/classes/sun/awt/X11/XBaseWindow.java
+1
-1
test/java/lang/management/ThreadMXBean/Locks.java
test/java/lang/management/ThreadMXBean/Locks.java
+29
-12
test/java/rmi/dgc/dgcAckFailure/DGCAckFailure.java
test/java/rmi/dgc/dgcAckFailure/DGCAckFailure.java
+31
-6
未找到文件。
src/share/classes/org/jcp/xml/dsig/internal/dom/DOMURIDereferencer.java
浏览文件 @
1333b155
...
...
@@ -21,7 +21,7 @@
* under the License.
*/
/*
* Copyright (c) 2005, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2005, 201
6
, Oracle and/or its affiliates. All rights reserved.
*/
/*
* $Id: DOMURIDereferencer.java 1231033 2012-01-13 12:12:12Z coheigea $
...
...
@@ -111,7 +111,8 @@ public class DOMURIDereferencer implements URIDereferencer {
try
{
ResourceResolver
apacheResolver
=
ResourceResolver
.
getInstance
(
uriAttr
,
baseURI
,
secVal
);
XMLSignatureInput
in
=
apacheResolver
.
resolve
(
uriAttr
,
baseURI
);
XMLSignatureInput
in
=
apacheResolver
.
resolve
(
uriAttr
,
baseURI
,
secVal
);
if
(
in
.
isOctetStream
())
{
return
new
ApacheOctetStreamData
(
in
);
}
else
{
...
...
src/share/classes/sun/rmi/transport/DGCAckHandler.java
浏览文件 @
1333b155
/*
* Copyright (c) 1996, 201
2
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1996, 201
6
, 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
...
...
@@ -118,6 +118,9 @@ public class DGCAckHandler {
if
(
objList
!=
null
&&
task
==
null
)
{
task
=
scheduler
.
schedule
(
new
Runnable
()
{
public
void
run
()
{
if
(
id
!=
null
)
{
idTable
.
remove
(
id
);
}
release
();
}
},
dgcAckTimeout
,
TimeUnit
.
MILLISECONDS
);
...
...
src/solaris/classes/sun/awt/X11/XBaseWindow.java
浏览文件 @
1333b155
...
...
@@ -669,7 +669,7 @@ public class XBaseWindow {
XToolkit
.
awtLock
();
try
{
XAtom
xa
=
XAtom
.
get
(
XAtom
.
XA_WM_CLASS
);
xa
.
setProperty8
(
getWindow
(),
cl
[
0
]
+
'\0'
+
cl
[
1
]);
xa
.
setProperty8
(
getWindow
(),
cl
[
0
]
+
'\0'
+
cl
[
1
]
+
'\0'
);
}
finally
{
XToolkit
.
awtUnlock
();
}
...
...
test/java/lang/management/ThreadMXBean/Locks.java
浏览文件 @
1333b155
...
...
@@ -170,6 +170,9 @@ public class Locks {
private
static
CheckerThread
checker
;
static
class
WaitingThread
extends
Thread
{
private
final
Phaser
p
;
volatile
boolean
waiting
=
false
;
public
WaitingThread
(
Phaser
p
)
{
super
(
"WaitingThread"
);
this
.
p
=
p
;
...
...
@@ -180,7 +183,9 @@ public class Locks {
log
(
"WaitingThread about to wait on objC"
);
try
{
// Signal checker thread, about to wait on objC.
waiting
=
false
;
p
.
arriveAndAwaitAdvance
();
// Phase 1 (waiting)
waiting
=
true
;
objC
.
wait
();
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
...
...
@@ -199,7 +204,9 @@ public class Locks {
synchronized
(
objC
)
{
try
{
// signal checker thread, about to wait on objC
waiting
=
false
;
p
.
arriveAndAwaitAdvance
();
// Phase 3 (waiting)
waiting
=
true
;
objC
.
wait
();
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
...
...
@@ -208,25 +215,35 @@ public class Locks {
}
log
(
"WaitingThread about to exit waiting on objC 2"
);
}
}
static
class
CheckerThread
extends
Thread
{
private
final
Phaser
p
;
public
CheckerThread
(
Phaser
p
)
{
super
(
"CheckerThread"
);
this
.
p
=
p
;
public
void
waitForWaiting
()
{
p
.
arriveAndAwaitAdvance
();
while
(!
waiting
)
{
goSleep
(
10
);
}
waitForState
(
State
.
WAITING
);
}
p
rivate
void
waitForState
(
Thread
.
State
state
)
{
p
ublic
void
waitForBlocked
(
)
{
p
.
arriveAndAwaitAdvance
();
waitForState
(
State
.
BLOCKED
);
}
private
void
waitForState
(
Thread
.
State
state
)
{
while
(!
waiter
.
isInterrupted
()
&&
waiter
.
getState
()
!=
state
)
{
goSleep
(
10
);
Thread
.
yield
(
);
}
}
}
static
class
CheckerThread
extends
Thread
{
public
CheckerThread
()
{
super
(
"CheckerThread"
);
}
public
void
run
()
{
synchronized
(
ready
)
{
// wait until WaitingThread about to wait for objC
wait
ForState
(
Thread
.
State
.
WAITING
);
// Phase 1 (waiting)
wait
er
.
waitForWaiting
(
);
// Phase 1 (waiting)
checkBlockedObject
(
waiter
,
objC
,
null
,
Thread
.
State
.
WAITING
);
synchronized
(
objC
)
{
...
...
@@ -235,13 +252,13 @@ public class Locks {
// wait for waiter thread to about to enter
// synchronized object ready.
wait
ForState
(
Thread
.
State
.
BLOCKED
);
// Phase 2 (waiting)
wait
er
.
waitForBlocked
(
);
// Phase 2 (waiting)
checkBlockedObject
(
waiter
,
ready
,
this
,
Thread
.
State
.
BLOCKED
);
}
// wait for signal from waiting thread that it is about
// wait for objC.
wait
ForState
(
Thread
.
State
.
WAITING
);
// Phase 3 (waiting)
wait
er
.
waitForWaiting
(
);
// Phase 3 (waiting)
synchronized
(
objC
)
{
checkBlockedObject
(
waiter
,
objC
,
Thread
.
currentThread
(),
Thread
.
State
.
WAITING
);
objC
.
notify
();
...
...
@@ -289,7 +306,7 @@ public class Locks {
waiter
=
new
WaitingThread
(
p
);
waiter
.
start
();
checker
=
new
CheckerThread
(
p
);
checker
=
new
CheckerThread
();
checker
.
start
();
try
{
...
...
test/java/rmi/dgc/dgcAckFailure/DGCAckFailure.java
浏览文件 @
1333b155
/*
* Copyright (c) 2001, 201
2
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2001, 201
6
, 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
...
...
@@ -22,7 +22,7 @@
*/
/* @test
* @bug 4017232
* @bug 4017232
8046339
* @summary If, after returning a reference to a remote object in the current
* VM (which gets implicitly converted to a remote stub), the client fails to
* both send a DGC dirty call and to send a "DGC acknowledgment", the RMI
...
...
@@ -36,10 +36,14 @@
import
java.io.*
;
import
java.net.*
;
import
java.lang.reflect.Field
;
import
java.lang.ref.*
;
import
java.rmi.*
;
import
java.rmi.server.*
;
import
java.util.Map
;
import
sun.rmi.transport.DGCAckHandler
;
interface
ReturnRemote
extends
Remote
{
Object
returnRemote
()
throws
RemoteException
;
...
...
@@ -48,6 +52,7 @@ interface ReturnRemote extends Remote {
public
class
DGCAckFailure
implements
ReturnRemote
{
private
static
final
long
TIMEOUT
=
20000
;
private
static
final
long
ACK_TIMEOUT
=
TIMEOUT
/
2
;
public
Object
returnRemote
()
{
return
new
Wrapper
(
this
);
...
...
@@ -55,7 +60,8 @@ public class DGCAckFailure implements ReturnRemote {
public
static
void
main
(
String
[]
args
)
throws
Exception
{
System
.
setProperty
(
"sun.rmi.dgc.ackTimeout"
,
"10000"
);
System
.
setProperty
(
"sun.rmi.dgc.ackTimeout"
,
Long
.
toString
(
ACK_TIMEOUT
));
/*
* Set a socket factory that has a hook for shutting down all client
...
...
@@ -93,12 +99,31 @@ public class DGCAckFailure implements ReturnRemote {
break
;
}
}
if
(
ref
==
weakRef
)
{
System
.
err
.
println
(
"TEST PASSED"
);
}
else
{
if
(
ref
!=
weakRef
)
{
throw
new
RuntimeException
(
"TEST FAILED: "
+
"timed out, remote object not garbage collected"
);
}
// 8046339
// All DGCAckHandlers must be properly released after timeout
Thread
.
sleep
(
ACK_TIMEOUT
+
100
);
try
{
Field
field
=
DGCAckHandler
.
class
.
getDeclaredField
(
"idTable"
);
field
.
setAccessible
(
true
);
Object
obj
=
field
.
get
(
null
);
Map
<?,?>
idTable
=
(
Map
<?,?>)
obj
;
if
(!
idTable
.
isEmpty
())
{
throw
new
RuntimeException
(
"TEST FAILED: "
+
"DGCAckHandler.idTable isn't empty"
);
}
}
catch
(
ReflectiveOperationException
roe
)
{
throw
new
RuntimeException
(
roe
);
}
System
.
err
.
println
(
"TEST PASSED"
);
}
finally
{
try
{
UnicastRemoteObject
.
unexportObject
((
Remote
)
weakRef
.
get
(),
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录