RFR: 8326135: Enhance adlc to report unused operands
kuaiwei
duke at openjdk.org
Mon Feb 19 08:53:00 UTC 2024
Some operands are defined in adfile but no one used them. But it's hard to find them manually. So I try to enhance adlc to report them after parsing the whole adfile.
I added a helper Form::forms_do to recursively visit child forms. After parsing, adlc will start from all instructions to mark all used forms. And report unvisited operands as unused. By this way, I can find 44 unused operands for aarch64, 12 for x86_64 and 4 for riscv64. The report is like
...
Warning: unused operand (vRegD_V28)
Warning: unused operand (vRegD_V29)
Warning: unused operand (vRegD_V30)
Warning: unused operand (vRegD_V31)
Warning: unused operand (lr_RegP)
Warning: unused operand (indOffI)
Warning: unused operand (indOffL)
Warning: unused operand (thread_anchor_pc)
-------Warning: total 44 unused operands
I tested and find they can be safely removed.
-------------
Commit messages:
- 8326135: Enhance adlc to report unused operands
Changes: https://git.openjdk.org/jdk/pull/17910/files
Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=17910&range=00
Issue: https://bugs.openjdk.org/browse/JDK-8326135
Stats: 287 lines in 9 files changed: 287 ins; 0 del; 0 mod
Patch: https://git.openjdk.org/jdk/pull/17910.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/17910/head:pull/17910
PR: https://git.openjdk.org/jdk/pull/17910
More information about the hotspot-compiler-dev
mailing list