Valhalla EG 20200129

Frederic Parain frederic.parain at oracle.com
Wed Jan 29 17:57:36 UTC 2020


# Valhalla EG Meeting 20200129

Dan S., Remi, Brian, Dan (IBM), Tobi (IBM) 

  Brian:
	language side implementation:
	compiler support to inject InlineObject/IdentityObject super-types at compilation time
	some issues with reflection code assuming type hierarchy


  Remi:
	Annotation of j.l.Object


  Brian:
	j.l.Object is not annotated by either  InlineObject or IdentityObject


  Remi:
	new Object()?

  Brian:
	new Object() will be the instanciation of an abtract class subclass of j.l.Object
	push people to move away from this construct with new way to get an Object.

  Remi:
	could be in the IdentityObject interface

  Brian:
	working on reference projection as an interface or an abstract class
	possible update next week, working on simplification
	would lead to rewrite of "State of Valhalla"

  Remi:
	did analysis of static fields set at VM startup but not read (bytecode level analysis)

  Brian:
	Lazy static: push people to initalize at time of declaration
	but issue with checked exception => reasons why people at initializing fields
	in big static initializers
	we need a construct in the language to declare a lazy static with shared throw
	clause for all lazy static fields

  Remi:
	Foreign Memory Access API: issue with VarHandles and checked exceptions
	Talk at Brest JUG:
	     no questions about Records, but a lot of questions about instanceof
	     lot of confusion between inline types and records

  Brian:
	arithmetic benchmarks being developped
	mixed results
	      HashMap:
		optimized for many years
		lot of corner cases

  Remi:
	did some experiments with HashMap
	saw benefits only if both key and values are in-lined

  Brian:
	issue with big flattened values => lot of data to be moved
	need to educate people about algorithms/designs that work or don't work with inline types

  Remi:
	references Google's fluent API to re-work abstractions

  Brian:
	hope that using inline types for lambdas would help escape analysis getting it right

  Dan (IBM):
      is there a JDK release targeted for Valhalla?

  Brian:
	too early to say
	VM work is consolidating
	language work still needs significant work before having a road-map
	
  	first release won't have all the features but have to have further additions in mind

	next Valhalla off-site probably during spring

  Remi:
	John wants to move to a specialized generics prototype


  Fred:
	start with a simpler specialized generics model so language and VM teams can work in parallel:
	VM team extending VM data structures (constant pool patching)
	language team working on full specialization model

  Brian:
	retrofitting of Integer: seemed impossible, but now seems more feasible
	


More information about the valhalla-spec-observers mailing list