Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell11
提交
f87fba97
D
dragonwell11
项目概览
openanolis
/
dragonwell11
通知
7
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell11
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
f87fba97
编写于
2月 05, 2020
作者:
E
erikj
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8238225: Issues reported after replacing symlink at Contents/MacOS/libjli.dylib with binary
Reviewed-by: clanger, alanb, ihse
上级
06811cfa
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
169 addition
and
2 deletion
+169
-2
make/test/JtregNativeJdk.gmk
make/test/JtregNativeJdk.gmk
+11
-0
src/java.base/macosx/native/libjli/java_md_macosx.c
src/java.base/macosx/native/libjli/java_md_macosx.c
+18
-2
test/jdk/tools/launcher/JliLaunchTest.java
test/jdk/tools/launcher/JliLaunchTest.java
+81
-0
test/jdk/tools/launcher/exeJliLaunchTest.c
test/jdk/tools/launcher/exeJliLaunchTest.c
+44
-0
test/lib/jdk/test/lib/Platform.java
test/lib/jdk/test/lib/Platform.java
+15
-0
未找到文件。
make/test/JtregNativeJdk.gmk
浏览文件 @
f87fba97
...
...
@@ -48,12 +48,20 @@ BUILD_JDK_JTREG_OUTPUT_DIR := $(OUTPUTDIR)/support/test/jdk/jtreg/native
BUILD_JDK_JTREG_IMAGE_DIR := $(TEST_IMAGE_DIR)/jdk/jtreg
BUILD_JDK_JTREG_EXECUTABLES_CFLAGS_exeJliLaunchTest := \
-I$(TOPDIR)/src/java.base/share/native/libjli \
-I$(TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS_TYPE)/native/libjli \
-I$(TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS)/native/libjli \
-DPACKAGE_PATH=\"$(PACKAGE_PATH)\"
# Platform specific setup
ifeq ($(OPENJDK_TARGET_OS), windows)
BUILD_JDK_JTREG_EXCLUDE += libDirectIO.c libInheritedChannel.c
WIN_LIB_JAVA := $(SUPPORT_OUTPUTDIR)/native/java.base/libjava/java.lib
BUILD_JDK_JTREG_LIBRARIES_LIBS_libstringPlatformChars := $(WIN_LIB_JAVA)
WIN_LIB_JLI := $(SUPPORT_OUTPUTDIR)/native/java.base/libjli/jli.lib
BUILD_JDK_JTREG_EXECUTABLES_LIBS_exeJliLaunchTest := $(WIN_LIB_JLI)
else
BUILD_JDK_JTREG_LIBRARIES_LIBS_libstringPlatformChars := -ljava
BUILD_JDK_JTREG_LIBRARIES_LIBS_libDirectIO := -ljava
...
...
@@ -62,6 +70,9 @@ else
else ifeq ($(OPENJDK_TARGET_OS), solaris)
BUILD_JDK_JTREG_LIBRARIES_LIBS_libInheritedChannel := -ljava
endif
UNIX_LDFLAGS_JLI := -L$(SUPPORT_OUTPUTDIR)/modules_libs/java.base/jli
BUILD_JDK_JTREG_EXECUTABLES_LDFLAGS_exeJliLaunchTest := $(UNIX_LDFLAGS_JLI)
BUILD_JDK_JTREG_EXECUTABLES_LIBS_exeJliLaunchTest := -ljli
endif
ifeq ($(OPENJDK_TARGET_OS), macosx)
...
...
src/java.base/macosx/native/libjli/java_md_macosx.c
浏览文件 @
f87fba97
/*
* Copyright (c) 2012, 20
17
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2012, 20
20
, 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
...
...
@@ -515,11 +515,27 @@ GetJREPath(char *path, jint pathsize, jboolean speculative)
}
size_t
indexOfLastPathComponent
=
pathLen
-
sizeOfLastPathComponent
;
if
(
0
==
strncmp
(
realPathToSelf
+
indexOfLastPathComponent
,
lastPathComponent
,
sizeOfLastPathComponent
-
1
))
{
if
(
0
==
strncmp
(
realPathToSelf
+
indexOfLastPathComponent
,
lastPathComponent
,
sizeOfLastPathComponent
))
{
realPathToSelf
[
indexOfLastPathComponent
+
1
]
=
'\0'
;
return
JNI_TRUE
;
}
// If libjli.dylib is loaded from a macos bundle MacOS dir, find the JRE dir
// in ../Home.
const
char
altLastPathComponent
[]
=
"/MacOS/libjli.dylib"
;
size_t
sizeOfAltLastPathComponent
=
sizeof
(
altLastPathComponent
)
-
1
;
if
(
pathLen
<
sizeOfLastPathComponent
)
{
return
JNI_FALSE
;
}
size_t
indexOfAltLastPathComponent
=
pathLen
-
sizeOfAltLastPathComponent
;
if
(
0
==
strncmp
(
realPathToSelf
+
indexOfAltLastPathComponent
,
altLastPathComponent
,
sizeOfAltLastPathComponent
))
{
JLI_Snprintf
(
realPathToSelf
+
indexOfAltLastPathComponent
,
sizeOfAltLastPathComponent
,
"%s"
,
"/Home"
);
if
(
access
(
realPathToSelf
,
F_OK
)
==
0
)
{
return
JNI_TRUE
;
}
}
if
(
!
speculative
)
JLI_ReportErrorMessage
(
JRE_ERROR8
JAVA_DLL
);
return
JNI_FALSE
;
...
...
test/jdk/tools/launcher/JliLaunchTest.java
0 → 100644
浏览文件 @
f87fba97
/*
* Copyright (c) 2016, 2020, 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
* @bug 8213362 8238225
* @comment Test JLI_Launch for tools distributed outside JDK
* @library /test/lib
* @run main/native JliLaunchTest
*/
import
java.util.Map
;
import
jdk.test.lib.Utils
;
import
jdk.test.lib.Platform
;
import
jdk.test.lib.process.OutputAnalyzer
;
import
java.io.File
;
import
java.io.IOException
;
import
java.nio.file.Files
;
import
java.nio.file.Path
;
import
java.nio.file.Paths
;
public
class
JliLaunchTest
{
public
static
void
main
(
String
[]
args
)
throws
IOException
{
Path
launcher
=
Paths
.
get
(
System
.
getProperty
(
"test.nativepath"
),
"JliLaunchTest"
+
(
Platform
.
isWindows
()
?
".exe"
:
""
));
System
.
out
.
println
(
"Launcher = "
+
launcher
+
(
Files
.
exists
(
launcher
)
?
" (exists)"
:
" (not exists)"
));
ProcessBuilder
pb
=
new
ProcessBuilder
(
launcher
.
toString
(),
"--version"
);
Map
<
String
,
String
>
env
=
pb
.
environment
();
// On windows, the DLL should be in JDK/bin, else in JDK/lib.
String
libdir
=
Paths
.
get
(
Utils
.
TEST_JDK
).
resolve
(
Platform
.
isWindows
()
?
"bin"
:
"lib/jli"
)
.
toAbsolutePath
().
toString
();
String
pathEnvVar
=
Platform
.
sharedLibraryPathVariableName
();
env
.
compute
(
pathEnvVar
,
(
k
,
v
)
->
(
v
==
null
)
?
libdir
:
libdir
+
File
.
pathSeparator
+
v
);
OutputAnalyzer
outputf
=
new
OutputAnalyzer
(
pb
.
start
());
outputf
.
shouldHaveExitValue
(
0
);
if
(
Platform
.
isOSX
())
{
Path
javaHome
=
Paths
.
get
(
Utils
.
TEST_JDK
);
if
(
javaHome
.
getFileName
().
toString
().
equals
(
"Home"
))
{
// To exercise this test path you need to make sure the JDK under test is
// the MacOS bundle and not the simple jdk image. This can currently be
// achieved by running something like this (from the build output dir):
// $ make test-only TEST=test/jdk/tools/launcher/JliLaunchTest.java \
// JDK_IMAGE_DIR=$PWD/images/jdk-bundle/jdk-15.jdk/Contents/Home
System
.
out
.
println
(
"MacOS bundle distribution detected, also testing Contents/MacOS/libjli.dylib"
);
String
macosDir
=
javaHome
.
getParent
().
resolve
(
"MacOS"
).
toString
();
ProcessBuilder
pb2
=
new
ProcessBuilder
(
launcher
.
toString
(),
"--version"
);
env
=
pb2
.
environment
();
env
.
compute
(
pathEnvVar
,
(
k
,
v
)
->
(
v
==
null
)
?
macosDir
:
macosDir
+
File
.
pathSeparator
+
v
);
OutputAnalyzer
output2
=
new
OutputAnalyzer
(
pb2
.
start
());
output2
.
shouldHaveExitValue
(
0
);
}
else
{
System
.
out
.
println
(
"Not a MacOS bundle distribution, not testing Contents/MacOS/libjli.dylib"
);
}
}
}
}
test/jdk/tools/launcher/exeJliLaunchTest.c
0 → 100644
浏览文件 @
f87fba97
/*
* Copyright (c) 2018, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
/*
* This file contains the main entry point into the launcher code
* this is the only file which will be repeatedly compiled by other
* tools. The rest of the files will be linked in.
*/
#include "java.h"
int
main
(
int
argc
,
char
**
argv
)
{
return
JLI_Launch
(
argc
,
argv
,
0
,
NULL
,
0
,
NULL
,
"1"
,
"0"
,
*
argv
,
*
argv
,
0
,
0
,
0
,
0
);
}
test/lib/jdk/test/lib/Platform.java
浏览文件 @
f87fba97
...
...
@@ -350,6 +350,21 @@ public class Platform {
}
}
/*
* Returns name of system variable containing paths to shared native libraries.
*/
public
static
String
sharedLibraryPathVariableName
()
{
if
(
isWindows
())
{
return
"PATH"
;
}
else
if
(
isOSX
())
{
return
"DYLD_LIBRARY_PATH"
;
}
else
if
(
isAix
())
{
return
"LIBPATH"
;
}
else
{
return
"LD_LIBRARY_PATH"
;
}
}
/*
* This should match the #if condition in ClassListParser::load_class_from_source().
*/
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录