RFR: JDK-8319307: DCmds should not assert on truncation and should report truncation [v2]
Thomas Stuefe
stuefe at openjdk.org
Sat Nov 4 06:30:29 UTC 2023
> `bufferedStream` was originally intended to provide intermediate output buffering; the buffer was supposed to drain upon flushing. However, in many cases, `flush()` is a no-op, so the buffer never gets drained.
>
> To prevent infinitely raising buffer sizes for non-flushing `bufferedStream`, [JDK-8220394](https://bugs.openjdk.org/browse/JDK-8220394) introduced the notion of a "maximum reasonable cap". Upon reaching this threshold, we assert in debug VMs since we assumed this to be a condition worth analyzing. In release VMs, we silently truncate.
>
> But DCmds - one of the primary users of `bufferedStream` - can reach the maximum cap under normal conditions; one example would be printing the list of dynamic libraries on Linux (just prints the process memory map) - this can get very large. Similarly, NMT detail reports and VM.info output can get just as large.
>
> Therefore, neither asserting nor silent truncation is optimal. Instead, we should truncate the output, print a visible truncation marker, and - if possible - interrupt the printing.
>
> ---
>
> The patch is minimally invasive to simplify review. Like most stream classes, `bufferedStream` would benefit from an overhaul, but I'd like to leave that to a future RFE.
>
> Testing: Tested manually with a number of commands with artificially increased output size. GHAs (Windows test errors unrelated).
Thomas Stuefe has updated the pull request with a new target base due to a merge or a rebase. The incremental webrev excludes the unrelated changes brought in by the merge/rebase. The pull request contains three additional commits since the last revision:
- Merge branch 'openjdk:master' into JDK-8319307-DCmds-should-not-assert-on-truncation-and-should-report-truncation
- fix mac builds
- JDK-8319307-DCmds-should-not-assert-on-truncation-and-should-report-truncation
-------------
Changes:
- all: https://git.openjdk.org/jdk/pull/16474/files
- new: https://git.openjdk.org/jdk/pull/16474/files/996deab9..51a005ac
Webrevs:
- full: https://webrevs.openjdk.org/?repo=jdk&pr=16474&range=01
- incr: https://webrevs.openjdk.org/?repo=jdk&pr=16474&range=00-01
Stats: 7830 lines in 195 files changed: 2815 ins; 2471 del; 2544 mod
Patch: https://git.openjdk.org/jdk/pull/16474.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/16474/head:pull/16474
PR: https://git.openjdk.org/jdk/pull/16474
More information about the hotspot-runtime-dev
mailing list