Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
0d30385e
D
dragonwell8_hotspot
项目概览
openanolis
/
dragonwell8_hotspot
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_hotspot
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
0d30385e
编写于
4月 29, 2015
作者:
D
dholmes
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8078470: [Linux] Replace syscall use in os::fork_and_exec with glibc fork() and execve()
Reviewed-by: stuefe, dsamersoff, dcubed
上级
b8343a24
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
145 addition
and
27 deletion
+145
-27
src/os/linux/vm/os_linux.cpp
src/os/linux/vm/os_linux.cpp
+2
-24
src/share/vm/utilities/vmError.cpp
src/share/vm/utilities/vmError.cpp
+7
-3
test/runtime/ErrorHandling/TestOnError.java
test/runtime/ErrorHandling/TestOnError.java
+66
-0
test/runtime/ErrorHandling/TestOnOutOfMemoryError.java
test/runtime/ErrorHandling/TestOnOutOfMemoryError.java
+70
-0
未找到文件。
src/os/linux/vm/os_linux.cpp
浏览文件 @
0d30385e
...
@@ -5929,14 +5929,6 @@ void Parker::unpark() {
...
@@ -5929,14 +5929,6 @@ void Parker::unpark() {
extern
char
**
environ
;
extern
char
**
environ
;
#ifndef __NR_fork
#define __NR_fork IA32_ONLY(2) IA64_ONLY(not defined) AMD64_ONLY(57)
#endif
#ifndef __NR_execve
#define __NR_execve IA32_ONLY(11) IA64_ONLY(1033) AMD64_ONLY(59)
#endif
// Run the specified command in a separate process. Return its exit value,
// Run the specified command in a separate process. Return its exit value,
// or -1 on failure (e.g. can't fork a new process).
// or -1 on failure (e.g. can't fork a new process).
// Unlike system(), this function can be called from signal handler. It
// Unlike system(), this function can be called from signal handler. It
...
@@ -5944,13 +5936,7 @@ extern char** environ;
...
@@ -5944,13 +5936,7 @@ extern char** environ;
int
os
::
fork_and_exec
(
char
*
cmd
)
{
int
os
::
fork_and_exec
(
char
*
cmd
)
{
const
char
*
argv
[
4
]
=
{
"sh"
,
"-c"
,
cmd
,
NULL
};
const
char
*
argv
[
4
]
=
{
"sh"
,
"-c"
,
cmd
,
NULL
};
// fork() in LinuxThreads/NPTL is not async-safe. It needs to run
pid_t
pid
=
fork
();
// pthread_atfork handlers and reset pthread library. All we need is a
// separate process to execve. Make a direct syscall to fork process.
// On IA64 there's no fork syscall, we have to use fork() and hope for
// the best...
pid_t
pid
=
NOT_IA64
(
syscall
(
__NR_fork
);)
IA64_ONLY
(
fork
();)
if
(
pid
<
0
)
{
if
(
pid
<
0
)
{
// fork failed
// fork failed
...
@@ -5959,15 +5945,7 @@ int os::fork_and_exec(char* cmd) {
...
@@ -5959,15 +5945,7 @@ int os::fork_and_exec(char* cmd) {
}
else
if
(
pid
==
0
)
{
}
else
if
(
pid
==
0
)
{
// child process
// child process
// execve() in LinuxThreads will call pthread_kill_other_threads_np()
execve
(
"/bin/sh"
,
(
char
*
const
*
)
argv
,
environ
);
// first to kill every thread on the thread list. Because this list is
// not reset by fork() (see notes above), execve() will instead kill
// every thread in the parent process. We know this is the only thread
// in the new process, so make a system call directly.
// IA64 should use normal execve() from glibc to match the glibc fork()
// above.
NOT_IA64
(
syscall
(
__NR_execve
,
"/bin/sh"
,
argv
,
environ
);)
IA64_ONLY
(
execve
(
"/bin/sh"
,
(
char
*
const
*
)
argv
,
environ
);)
// execve failed
// execve failed
_exit
(
-
1
);
_exit
(
-
1
);
...
...
src/share/vm/utilities/vmError.cpp
浏览文件 @
0d30385e
/*
/*
* Copyright (c) 2003, 201
4
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2003, 201
5
, 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
...
@@ -1013,7 +1013,9 @@ void VMError::report_and_die() {
...
@@ -1013,7 +1013,9 @@ void VMError::report_and_die() {
out
.
print_raw
(
cmd
);
out
.
print_raw
(
cmd
);
out
.
print_raw_cr
(
"
\"
..."
);
out
.
print_raw_cr
(
"
\"
..."
);
os
::
fork_and_exec
(
cmd
);
if
(
os
::
fork_and_exec
(
cmd
)
<
0
)
{
out
.
print_cr
(
"os::fork_and_exec failed: %s (%d)"
,
strerror
(
errno
),
errno
);
}
}
}
// done with OnError
// done with OnError
...
@@ -1098,7 +1100,9 @@ void VM_ReportJavaOutOfMemory::doit() {
...
@@ -1098,7 +1100,9 @@ void VM_ReportJavaOutOfMemory::doit() {
#endif
#endif
tty
->
print_cr
(
"
\"
%s
\"
..."
,
cmd
);
tty
->
print_cr
(
"
\"
%s
\"
..."
,
cmd
);
os
::
fork_and_exec
(
cmd
);
if
(
os
::
fork_and_exec
(
cmd
)
<
0
)
{
tty
->
print_cr
(
"os::fork_and_exec failed: %s (%d)"
,
strerror
(
errno
),
errno
);
}
}
}
}
}
...
...
test/runtime/ErrorHandling/TestOnError.java
0 → 100644
浏览文件 @
0d30385e
/*
* Copyright (c) 2015, 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.
*/
/*
* @test TestOnError
* @summary Test using -XX:OnError=<cmd>
* @library /testlibrary
* @build TestOnError com.oracle.java.testlibrary.*
* @run main TestOnError
* @bug 8078470
*/
import
com.oracle.java.testlibrary.*
;
public
class
TestOnError
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
if
(!
Platform
.
isDebugBuild
())
{
System
.
out
.
println
(
"Test requires a non-product build - skipping"
);
return
;
}
String
msg
=
"Test Succeeded"
;
// Execute the VM so that a
ProcessBuilder
pb
=
ProcessTools
.
createJavaProcessBuilder
(
"-XX:-TransmitErrorReport"
,
"-XX:ErrorHandlerTest=12"
,
// trigger potential SEGV
"-XX:OnError=echo "
+
msg
,
TestOnError
.
class
.
getName
());
OutputAnalyzer
output
=
new
OutputAnalyzer
(
pb
.
start
());
/* Actual output will include:
#
# -XX:OnError="echo Test Succeeded"
# Executing /bin/sh -c "echo Test Succeeded"...
Test Succeeded
So we don't want to match on the "# Executing ..." line, and they
both get written to stdout.
*/
output
.
stdoutShouldMatch
(
"^"
+
msg
);
// match start of line only
System
.
out
.
println
(
"PASSED"
);
}
}
test/runtime/ErrorHandling/TestOnOutOfMemoryError.java
0 → 100644
浏览文件 @
0d30385e
/*
* Copyright (c) 2015, 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.
*/
/*
* @test TestOnOutOfMemoryError
* @summary Test using -XX:OnOutOfMemoryError=<cmd>
* @library /testlibrary
* @build TestOnOutOfMemoryError com.oracle.java.testlibrary.*
* @run main TestOnOutOfMemoryError
* @bug 8078470
*/
import
com.oracle.java.testlibrary.*
;
public
class
TestOnOutOfMemoryError
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
if
(
args
.
length
==
1
)
{
// This should guarantee to throw:
// java.lang.OutOfMemoryError: Requested array size exceeds VM limit
Object
[]
oa
=
new
Object
[
Integer
.
MAX_VALUE
];
return
;
}
// else this is the main test
String
msg
=
"Test Succeeded"
;
ProcessBuilder
pb
=
ProcessTools
.
createJavaProcessBuilder
(
"-XX:OnOutOfMemoryError=echo "
+
msg
,
TestOnOutOfMemoryError
.
class
.
getName
(),
"throwOOME"
);
OutputAnalyzer
output
=
new
OutputAnalyzer
(
pb
.
start
());
/* Actual output should look like this:
#
# java.lang.OutOfMemoryError: Requested array size exceeds VM limit
# -XX:OnOutOfMemoryError="echo Test Succeeded"
# Executing /bin/sh -c "echo Test Succeeded"...
Test Succeeded
Exception in thread "main" java.lang.OutOfMemoryError: Requested array size exceeds VM limit
at OOME.main(OOME.java:3)
So we don't want to match on the "# Executing ..." line, and they
both get written to stdout.
*/
output
.
shouldContain
(
"Requested array size exceeds VM limit"
);
output
.
stdoutShouldMatch
(
"^"
+
msg
);
// match start of line only
System
.
out
.
println
(
"PASSED"
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录