RFR: 8287071: Loom: Cleanup x86_64 gen_continuation_enter [v5]

Aleksey Shipilev shade at openjdk.java.net
Mon Jun 6 14:30:42 UTC 2022


> During x86_32 porting, I ended up rewriting the copy of x86_64 gen_continuation_enter significantly to make it more streamlined. The original x86_64 gen_continuation_enter should enjoy the similar streamlining, since it would likely to be the template for many other architectures.
> 
> There might be more things to do, I would not know until x86_32 fully works. I am pretty sure current thing is self-sufficient.
> 
> Brief tour of changes:
>  - Check the incoming registers explicitly
>  - Pass explicit argument registers to `fill_continuation_entry`
>  - Use the usual `NativeCall` alignment code to produce a patchable call
>  - Check that static stub is emitted, fail hard otherwise
>  - Handle register shuffling for `exception_handler_for_return_address` the similar way we do it in `StubGenerator`
> 
> Additional testing:
>  - [x] Linux x86_64 fastdebug, prospective `jdk_loom hotspot_loom`

Aleksey Shipilev has updated the pull request incrementally with one additional commit since the last revision:

  Review feedback

-------------

Changes:
  - all: https://git.openjdk.java.net/jdk/pull/8802/files
  - new: https://git.openjdk.java.net/jdk/pull/8802/files/3c721970..80960e2a

Webrevs:
 - full: https://webrevs.openjdk.java.net/?repo=jdk&pr=8802&range=04
 - incr: https://webrevs.openjdk.java.net/?repo=jdk&pr=8802&range=03-04

  Stats: 6 lines in 1 file changed: 2 ins; 4 del; 0 mod
  Patch: https://git.openjdk.java.net/jdk/pull/8802.diff
  Fetch: git fetch https://git.openjdk.java.net/jdk pull/8802/head:pull/8802

PR: https://git.openjdk.java.net/jdk/pull/8802


More information about the hotspot-dev mailing list