RFR: 8294003: Don't handle si_addr == 0 && si_code == SI_KERNEL SIGSEGVs [v2]

Stefan Karlsson stefank at openjdk.org
Thu Sep 22 06:51:05 UTC 2022


> We have this code code in our signal handler:
> 
> 
> #ifndef AMD64
>     // Halt if SI_KERNEL before more crashes get misdiagnosed as Java bugs
>     // This can happen in any running code (currently more frequently in
>     // interpreter code but has been seen in compiled code)
>     if (sig == SIGSEGV && info->si_addr == 0 && info->si_code == SI_KERNEL) {
>       fatal("An irrecoverable SI_KERNEL SIGSEGV has occurred due "
>             "to unstable signal handling in this distribution.");
>     }
> #endif // AMD64
> 
> 
> This bug added that change:
> https://bugs.openjdk.java.net/browse/JDK-8004124
> 
> In the Generational ZGC we hit the exact same condition whenever we try to (incorrectly) dereference one of our colored pointers. From the bug above:
> 
> "A segmentation violation that occurs as a result of userspace process accessing virtual memory above the TASK_SIZE limit will cause a segmentation violation with an si_code of SI_KERNEL"
> 
> That is, if we have set high-order bits (past the TASK_SIZE limit), we get these kind of SIGSEGVs.
> 
> As the signal handle code is written today, we don't "stop" this signal, and instead try to handle it as an implicit null check. This causes hard-to-debug error messages and crashes in code that incorrectly try to deoptimize the faulty code.
> 
> I propose that we short-cut the signal handling code, and let this problematic SIGSEGV get passed to VMError::report_and_die.
> 
> We've been running with this patch in the Generational ZGC repository for over a year, without any problems.

Stefan Karlsson has updated the pull request incrementally with one additional commit since the last revision:

  Remove 32-bit error handling

-------------

Changes:
  - all: https://git.openjdk.org/jdk/pull/10340/files
  - new: https://git.openjdk.org/jdk/pull/10340/files/f31550e4..d0d1bf73

Webrevs:
 - full: https://webrevs.openjdk.org/?repo=jdk&pr=10340&range=01
 - incr: https://webrevs.openjdk.org/?repo=jdk&pr=10340&range=00-01

  Stats: 8 lines in 1 file changed: 0 ins; 8 del; 0 mod
  Patch: https://git.openjdk.org/jdk/pull/10340.diff
  Fetch: git fetch https://git.openjdk.org/jdk pull/10340/head:pull/10340

PR: https://git.openjdk.org/jdk/pull/10340


More information about the hotspot-dev mailing list