[code-reflection] RFR: OpBuilder optimizations - part 1. [v5]
Adam Sotona
asotona at openjdk.org
Tue Nov 18 10:09:23 UTC 2025
> This PR include following changes:
>
> - op-building methods isolated from the original code and moved to a synthetic inner class
> - fixed boxing in `OpBuilder`
> - op-building methods are generated by `BytecodeGenerator` and support wide range of ops
> - `CodeModelTranslator` is deleted
> - synthetic op-building method overrides significantly reduce overhead (by 60% on `TestBytecode`)
>
> Remaining tasks:
>
> - implement part 2. type-building helper method(s) to reduce the overhead even more
> - refactor `OpBuilder` to build `ModuleOp` instead of individual `FuncOp`s (and re-enable `TestCodeBuilder`)
> - cleanup `BytecodeGenerator` API
Adam Sotona has updated the pull request incrementally with two additional commits since the last revision:
- Op reverted to the original
- builder methods delegating to the synth. inner class
-------------
Changes:
- all: https://git.openjdk.org/babylon/pull/679/files
- new: https://git.openjdk.org/babylon/pull/679/files/e0499280..768c6028
Webrevs:
- full: https://webrevs.openjdk.org/?repo=babylon&pr=679&range=04
- incr: https://webrevs.openjdk.org/?repo=babylon&pr=679&range=03-04
Stats: 25 lines in 2 files changed: 21 ins; 3 del; 1 mod
Patch: https://git.openjdk.org/babylon/pull/679.diff
Fetch: git fetch https://git.openjdk.org/babylon.git pull/679/head:pull/679
PR: https://git.openjdk.org/babylon/pull/679
More information about the babylon-dev
mailing list