RFR: JDK-8319307: DCmds should not assert on truncation and should report truncation [v2]
Kevin Walls
kevinw at openjdk.org
Mon Nov 27 11:52:07 UTC 2023
On Sat, 4 Nov 2023 06:30:29 GMT, Thomas Stuefe <stuefe at openjdk.org> wrote:
>> `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
Thanks, JDK-8319055 does indeed need more investigation.
While nobody would want to _continually_ raise the buffer size, raising it is the easy one-liner with no side-effects on multiple diagnostic commands... Would it be 200MB? 500MB? 8-)
-------------
PR Comment: https://git.openjdk.org/jdk/pull/16474#issuecomment-1827680263
More information about the hotspot-runtime-dev
mailing list