RFR: 8302369: Reduce the stack size of the C1 compiler [v2]
SUN Guoyun
duke at openjdk.org
Thu Feb 16 11:28:43 UTC 2023
On Thu, 16 Feb 2023 11:17:05 GMT, SUN Guoyun <duke at openjdk.org> wrote:
>> The current fact is that C1 uses more stack space than the C2 compiler, taking method `java.lang.Object::<init>`as an example on the x86_64 platform , the stack size used is 48 bytes for C1 compiler, while only 16 bytes is used for C2 compiler.
>>
>> ========== C1-compiled nmethod =====
>> 0x00007f93311cc747: push %rbp
>> 0x00007f93311cc748: sub $0x30,%rsp // stack sizes is 48 bytes
>>
>>
>> ========== C2-compiled nmethod =======
>> pushq rbp # Save rbp
>> subq rsp, #16 # Create frame //stack sizes is 16 bytes
>>
>> After this patch, the C1 compiler will use less stack space. also taking method `java.lang.Object::<init>`as an example on the x86_64 platform , the stack size used is 16 bytes, which is the same as C2 compiler.
>>
>> ========== C1-compiled nmethod =====
>> 0x00007f80491ce647: push %rbp
>> 0x00007f80491ce648: sub $0x10,%rsp //stack sizes is 16 bytes
>
> SUN Guoyun has updated the pull request incrementally with one additional commit since the last revision:
>
> 8302369: Reduce the stack size of the C1 compiler
commit 2 (814cbd4) does the following two things:
1. Update the `reserved_argument_area_size` when stubs with actual store emits are created.
2. The constructors for `RangeCheckStub` and `MonitorEnterStub` are moved to the common layer implementation, not in each
cpu/arch/ directory.
-------------
PR: https://git.openjdk.org/jdk/pull/12548
More information about the hotspot-compiler-dev
mailing list