RFR: 8368124: Show useful thread names in ASAN reports [v7]

Thomas Stuefe stuefe at openjdk.org
Thu Sep 25 05:59:59 UTC 2025


> On Linux, ASAN only shows some internal thread designation on reports, e.g. `T49`, which is useless.
> 
> This patch adds the ability to see the real internal JVM thread names or user-supplied Java thread names in ASAN. This makes it possible to correlate ASAN reports with hs-err file reports (if ASAN is run with `halt_on_error=0` to give us a chance to get an hs-err file) or with a thread dump done beforehand.
> 
> Note that it can only show up to 15 characters, though. Therefore, the patch tries to be smart about names that end in digits: such numbers are preserved such that the truncation happens in the middle of the name, e.g.:
> 
> `"MyAllocationWorkerThread#4411"` -> `"MyAllocat..4411"`
> 
> This latter improvement now also applies to thread names in gdb, since they are subject to the same limitation.
> 
> For a detailed analysis of why the old version, using libpthread's `pthread_setname_np`, is not sufficient for thread names in ASAN, please see the issue description.
> 
> -----
> 
> Some examples from ASAN report: 
> 
> Before:
> 
> WRITE of size 8 at 0x7b749d2d9190 thread T49
> 
> 
> Now:
> 
> WRITE of size 8 at 0x7bfc2f0d8380 thread T49 (MyThread#0)
> 
> 
> 
> ==593899==ERROR: AddressSanitizer: attempting free .. in thread T76 (MyAllocati..29)

Thomas Stuefe has updated the pull request incrementally with two additional commits since the last revision:

 - reorder includes
 - remove redundant pthread_setname call

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

Changes:
  - all: https://git.openjdk.org/jdk/pull/27395/files
  - new: https://git.openjdk.org/jdk/pull/27395/files/7c033ad7..e3e84970

Webrevs:
 - full: https://webrevs.openjdk.org/?repo=jdk&pr=27395&range=06
 - incr: https://webrevs.openjdk.org/?repo=jdk&pr=27395&range=05-06

  Stats: 18 lines in 3 files changed: 4 ins; 13 del; 1 mod
  Patch: https://git.openjdk.org/jdk/pull/27395.diff
  Fetch: git fetch https://git.openjdk.org/jdk.git pull/27395/head:pull/27395

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


More information about the hotspot-dev mailing list