It might be helpful to provide a java API like the following to specify entry point (static field) for archiving a sub-graph in Java code:
In VM class:
public static native void archive(Class<?> c, String fieldName);
Suggested by Ioi and Karen.
The new API will make adding new sub-graph archiving an easier task. No new CDS/VM code change will be required for registering the entry fields (currently several VM files need to be modified in order to add a new entry) with the java API.
In addition to the API, we need a mechanism to validate that the new sub-graph for archiving is 'preservable'. There are following starter approaches:
Approach 1)
Author driven approach. The author who's adding a new sub-graph archiving need to specify all classes included in the graph are 'preservable'. Method for how to specify 'preservable' state is not determined yet currently.
Approach 2)
Add guards to the archived sub-graph during dump time. When archiving a sub-graph, checks can be done for the objects within the sub-graph to make sure they are not the ones with known issues (such as Thread, etc).
Approach 3)
This is suggested by Ioi. Dump time can consult a list of classes maintained internally by the sub-graph archiving mechanism. Only instances of classes on the list can be included in the archived sub-graph. When new sub-graphs are archived, new classes may be added to the list. Only classes with no runtime dependencies should be added to the list.
In VM class:
public static native void archive(Class<?> c, String fieldName);
Suggested by Ioi and Karen.
The new API will make adding new sub-graph archiving an easier task. No new CDS/VM code change will be required for registering the entry fields (currently several VM files need to be modified in order to add a new entry) with the java API.
In addition to the API, we need a mechanism to validate that the new sub-graph for archiving is 'preservable'. There are following starter approaches:
Approach 1)
Author driven approach. The author who's adding a new sub-graph archiving need to specify all classes included in the graph are 'preservable'. Method for how to specify 'preservable' state is not determined yet currently.
Approach 2)
Add guards to the archived sub-graph during dump time. When archiving a sub-graph, checks can be done for the objects within the sub-graph to make sure they are not the ones with known issues (such as Thread, etc).
Approach 3)
This is suggested by Ioi. Dump time can consult a list of classes maintained internally by the sub-graph archiving mechanism. Only instances of classes on the list can be included in the archived sub-graph. When new sub-graphs are archived, new classes may be added to the list. Only classes with no runtime dependencies should be added to the list.
- relates to
-
JDK-8202035 Archive the set of ModuleDescriptor and ModuleReference objects for observable system modules with unnamed initial module
- Resolved
-
JDK-8194759 Support caching class mirror objects
- Closed
-
JDK-8207795 Change VM.initializeFromArchive() to return a boolean
- Closed
-
JDK-8214932 Implement more checks for archiving object subgraphs
- Closed