RFR: 8287373: remove unnecessary paddings in generated code
Boris Ulasevich
bulasevich at openjdk.java.net
Tue Jun 7 15:49:23 UTC 2022
The goal is to remove unnecessary paddings in generated code. The alignment of the [Stub Code] section is determined by the same value as the alignment of the [Entry Point] section: the CodeEntryAlignment parameter with default values 64B on AARCH, and 32B on AMD.
Large entry alignment values are questionable for entry section. For example, Arm Neoverse N1 Software Optimization Guide recommends to align subroutines to 32B, while static compilers uses an even smaller value of 16B. However, with this change, I suggest to apply different (and smaller) values for [Constants] and [Stub Code] section alignments. This makes overall code 2% smaller on AARCH.
The correctness of the changes is checked by jtreg. Performance tested by Renaissance and SpecJBB benchmarkds on AARCH and AMD.
Example. Dummy method disassembly on AARCH, before vs after:
[Verified Entry Point] | [Verified Entry Point]
78c63b80: nop | 7437e480: nop
78c63b84: sub x9, sp, #0x20, lsl #12 | 7437e484: sub x9, sp, #0x20, lsl #12
78c63b88: str xzr, [x9] | 7437e488: str xzr, [x9]
78c63b8c: sub sp, sp, #0x20 | 7437e48c: sub sp, sp, #0x20
78c63b90: stp x29, x30, [sp, #16] | 7437e490: stp x29, x30, [sp, #16]
78c63b94: orr w1, wzr, #0x10 | 7437e494: orr w1, wzr, #0x10
78c63b98: bl 78343e00 | 7437e498: bl 73a61980
78c63b9c: .inst 0x00000000 ; undefined | 7437e49c: .inst 0x00000000 ; undefined
78c63ba0: .inst 0x00000000 ; undefined |
78c63ba4: .inst 0x00000000 ; undefined |
78c63ba8: .inst 0x00000000 ; undefined |
78c63bac: .inst 0x00000000 ; undefined |
78c63bb0: .inst 0x00000000 ; undefined |
78c63bb4: .inst 0x00000000 ; undefined |
78c63bb8: .inst 0x00000000 ; undefined |
78c63bbc: .inst 0x00000000 ; undefined |
[Stub Code] | [Stub Code]
78c63bc0: ldr x8, 78c63bc8 | 7437e4a0: ldr x8, 7437e4a8
78c63bc4: br x8 | 7437e4a4: br x8
78c63bc8: .inst 0x78343e00 ; undefined | 7437e4a8: .inst 0x73a61980 ; undefined
78c63bcc: .inst ; undefined | 7437e4ac: .inst ; undefined
[Exception Handler] | [Exception Handler]
78c63bd0: b 783ee080 | 7437e4b0: b 73b0c100
[Deopt Handler Code] | [Deopt Handler Code]
78c63bd4: adr x30, 78c63bd4 | 7437e4b4: adr x30, 7437e4b4
78c63bd8: b 78343ac0 | 7437e4b8: b 73a61620
78c63bdc: .inst 0x00000000 ; undefined | 7437e4bc: .inst 0x00000000 ; undefined
-------------
Commit messages:
- fixing the CodeBuffer overflow assert on x86 build: SharedRuntime::generate_handler_blob asks a 1KB buffer,
- rollback InteriorEntryAlignment change
- jtreg/compiler tests update
- Undo CodeEntryAlignment modification. Each code section (constants,code,stubs) have got its own alignment
- use InteriorEntryAlignment for code sections
Changes: https://git.openjdk.java.net/jdk/pull/8453/files
Webrev: https://webrevs.openjdk.java.net/?repo=jdk&pr=8453&range=00
Issue: https://bugs.openjdk.org/browse/JDK-8287373
Stats: 60 lines in 9 files changed: 28 ins; 3 del; 29 mod
Patch: https://git.openjdk.java.net/jdk/pull/8453.diff
Fetch: git fetch https://git.openjdk.java.net/jdk pull/8453/head:pull/8453
PR: https://git.openjdk.java.net/jdk/pull/8453
More information about the hotspot-dev
mailing list