RFR: 8220095: Assertion failure when symlink (with different name) is used for lib/modules file
Calvin Cheung
calvin.cheung at oracle.com
Thu Mar 7 17:00:58 UTC 2019
Hi Jiangli,
Thanks for filing and fixing the bug.
Just couple of suggestions:
classLoader.cpp
Currently, os::file_separator() contains only 1 character. Consider
using strrchr instead of a while loop?
You can keep the while loop in case in the len of os::file_separator is > 1.
Something like the following:
void ClassLoader::init_modules_image_name(const char* modules_path) {
// skip directory names
const char *p1, *p2;
p1 = modules_path;
int len = (int)strlen(os::file_separator());
if (len == 1) {
p2 = strrchr(modules_path, os::file_separator()[0]);
if (p2 != NULL) {
p1 = p2 + len;
}
} else {
while ((p2 = strstr(p1, os::file_separator())) != NULL) {
p1 = p2 + len;
}
}
_modules_image_name = os::strdup(p1);
}
ModulesSymLink.java
29 * @requires (os.family == "linux")
I think the test should be applicable to the Macosx and the Solaris
platforms too.
So perhaps just excluding windows:
@requires (os.family != "windows")
72 String modules_prefix ...
This variable is unused.
thanks,
Calvin
On 3/6/19, 3:20 PM, Jiangli Zhou wrote:
> Please review the following fix for 8220095.
>
> webrev: http://cr.openjdk.java.net/~jiangli/8220095/webrev.00/
> bug: https://bugs.openjdk.java.net/browse/JDK-8220095
>
> Symbolic links may be used commonly in some cloud environments. The target
> files might have different names than the linked names. The VM crashes when
> 'lib/modules' links to a target file with a different name, for example,
> lib/modules -> lib/0.
>
> The usage of the hard-coded MODULES_IMAGE_NAME (used by
> ClassLoader::is_modules_image(const char*)) can become problematic in this
> case and leads to assertion failures and crashes in this case. The
> is_modules_image()
> checks always fail even the actual file is the runtime image because the
> canonical paths (which might not end with 'modules') are passed in for the
> check. The fix is to obtain the real name from the canonical path early
> during initialization and use that for the is_modules_image() check.
>
> Tested with submit repo testing, tier1, tier2, and hotspot runtime tests
> locally.
>
> Thanks!
> Jiangli
More information about the hotspot-runtime-dev
mailing list