RFR: 8201616: Hotspot crashes on linux-sparc after 8189941

Thomas Stüfe thomas.stuefe at gmail.com
Tue Apr 17 20:17:08 UTC 2018


Good catch! Proposed fix is fine.

You earned that beer :)

..Thomas

On Tue, Apr 17, 2018 at 9:48 PM, John Paul Adrian Glaubitz
<glaubitz at physik.fu-berlin.de> wrote:
> Hi!
>
> After having rebuilt OpenJDK several dozen times over several days and bisecting
> for several hours today, I finally found the culprit for the segfault I am seeing
> on linux-sparc which is JDK-8189941 [1].
>
> Looking at the SPARC-specific changes [2], I noticed the change in os_solaris_sparc.cpp
> to use os::is_poll_address() instead of os::get_polling_page() when a SIGSEGV is caught
> which was missing in os_linux_sparc.cpp.
>
> Thus, I made that change to os_linux_sparc.cpp as well:
>
> diff --git a/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp b/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp
> --- a/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp
> +++ b/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp
> @@ -374,7 +374,7 @@
>  }
>
>  inline static bool checkPollingPage(address pc, address fault, address* stub) {
> -  if (fault == os::get_polling_page()) {
> +  if (os::is_poll_address(fault)) {
>      *stub = SharedRuntime::get_poll_stub(pc);
>      return true;
>    }
>
> And voila, the crash is gone \o/.
>
> Please review the change in [3] and invite me over a cold one at next FOSDEM :-).
>
> Cheers,
> Adrian
>
>> [1] http://hg.openjdk.java.net/jdk/jdk/rev/0ce0ac68ace7
>> [2] http://hg.openjdk.java.net/jdk/jdk/rev/0ce0ac68ace7#l39.1
>> [3] http://cr.openjdk.java.net/~glaubitz/8201616/webrev.00/
>
> --
>  .''`.  John Paul Adrian Glaubitz
> : :' :  Debian Developer - glaubitz at debian.org
> `. `'   Freie Universitaet Berlin - glaubitz at physik.fu-berlin.de
>   `-    GPG: 62FF 8A75 84E0 2956 9546  0006 7426 3B37 F5B5 F913


More information about the hotspot-dev mailing list