> This pull request implements the first [preview](https://openjdk.org/jeps/12) 
> of [JEP 401: Value Classes and Objects](https://openjdk.org/jeps/401):
> 
> - [JDK-8317277](https://bugs.openjdk.org/browse/JDK-8317277): Java language 
> implementation of value classes and objects
>   - https://github.com/openjdk/jdk/pull/31121
> - [JDK-8317278](https://bugs.openjdk.org/browse/JDK-8317278): JVM 
> implementation of value classes and objects
>   - https://github.com/openjdk/jdk/pull/31122
> - [JDK-8317279](https://bugs.openjdk.org/browse/JDK-8317279): Standard 
> library implementation of value classes and objects
>   - https://github.com/openjdk/jdk/pull/31123
> 
> This pull request also includes the implementation of [Strict Field 
> Initialization in the JVM (Preview)](https://openjdk.org/jeps/8350458) (yet 
> to have been assigned a JEP number). That work was implemented in the same 
> code base because JEP 401 depends on strict field initialization.
> 
> This is the "*master pull request*" for the initial preview of [JEP 
> 401](https://openjdk.org/jeps/401). Comments and review for a change this 
> large will not scale well in a single pull request. This pull request serves 
> as the vehicle for sign-off and integration into 
> [`jdk/master`](https://github.com/openjdk/jdk). **Review comments should be 
> directed to the appropriate "*sub-review pull request*" listed above.**
> 
>> [!NOTE]
>> The "*sub-review pull requests*" contain the same full set of code changes 
>> as this "*master pull request*" to preserve the full implementation context; 
>> the language compiler, JVM, and standard library changes are intertwined. 
>> The separate pull requests exist only to subdivide the review and related 
>> discussion by area.
> 
> Any resulting code changes should be made in 
> [`valhalla/lworld`](https://github.com/openjdk/valhalla/).
> 
> `valhalla/lworld` is currently updated from `jdk/master` whenever a weekly 
> [`jdk` tag](https://github.com/openjdk/jdk/tags) is created. At that time, 
> code changes from `valhalla/lworld` will be propagated to this pull request 
> and to all sub-review pull requests.
> 
> Ultimately, review sign-off will be recorded on this "*master pull request*", 
> and the "*sub-review pull requests*" will be closed without integration.
> 
> This pull request has a large surface area and frequently conflicts with 
> `jdk/master`. Refer to 
> [`valhalla/lworld`](https://github.com/openjdk/valhalla/) for the latest 
> state of the project code, keeping in mind that it may lag several days 
> behind `jdk/master`. Both repositories may be needed as refe...

David Simms has updated the pull request with a new target base due to a merge 
or a rebase. The pull request now contains 2843 commits:

 - Merge remote-tracking branch 'valhalla/lworld' into 8317277
 - 8387024: [lworld] Remove the mention of mutexes from the specification text 
of value classes
   
   Reviewed-by: alanb, dholmes, liach
 - 8387054: [lworld] BACKOUT JDK-8375694 C2: Dead loop constructed with CastPP 
in late inlining
   
   Reviewed-by: dholmes
 - 8386904: [lworld] ProblemList tests that fail due to JDK-8375645 on all 
platforms
   8387050: [lworld] ProblemList two 
compiler/valhalla/inlinetypes/TestValueClasses.java sub-tests in Xcomp mode
   
   Reviewed-by: dholmes
 - 8386638: [lworld] Port JEP 401 to PPC64
   
   Co-authored-by: Richard Reingruber <[email protected]>
   Reviewed-by: dbriemann, rrich, lfoltan
 - Merge
   
   Merge jdk-28+3
 - 8386815: [lworld] Reduce the number of constructors in IdentityException
   
   Reviewed-by: liach, alanb
 - 8386626: [lworld] Only enable valhalla IR tests in 
ScalarReplacementWithGCBarrierTests.java for aarch64 and x86
   
   Reviewed-by: mhaessig, mchevalier
 - 8386718: [lworld] C2: Integer overflow in arraycopy scaling for flat arrays
   
   Reviewed-by: qamai
 - 8386677: [lworld] VarHandle does not implement strict static checks
   
   Reviewed-by: jvernee, vromero
 - ... and 2833 more: https://git.openjdk.org/jdk/compare/915efc50...84422ff0

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

Changes: https://git.openjdk.org/jdk/pull/31120/files
  Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=31120&range=05
  Stats: 207494 lines in 1861 files changed: 194306 ins; 3864 del; 9324 mod
  Patch: https://git.openjdk.org/jdk/pull/31120.diff
  Fetch: git fetch https://git.openjdk.org/jdk.git pull/31120/head:pull/31120

PR: https://git.openjdk.org/jdk/pull/31120

Reply via email to