Skip to content

Commit

Permalink
[GR-25960] Unify source caches oracle#2828.
Browse files Browse the repository at this point in the history
PullRequest: graal/7077
  • Loading branch information
olpaw committed Sep 4, 2020
2 parents 49d041c + 5ff8e45 commit 1cc9e71
Show file tree
Hide file tree
Showing 7 changed files with 297 additions and 640 deletions.
57 changes: 24 additions & 33 deletions substratevm/DebugInfo.md
Original file line number Diff line number Diff line change
Expand Up @@ -102,36 +102,31 @@ compiled method.
One goal of the implementation is to make it simple to configure your
debugger so that it can identify the relevant source file when it
stops during program execution. The native image generator tries to
achieve this by accumulating the relevant sources in a suitably
structured file cache.
achieve this by accumulating the relevant sources in a file cache.

The native image generator uses different strategies to locate source
files for JDK runtime classes, GraalVM classes and application source
classes for inclusion in the local sources cache. It identifies which
strategy to use based on the package name of the class. So, for
example, packages starting with `java.*` or `jdk.*` are JDK classes;
packages starting with `org.graal.*` or `com.oracle.svm.*` are GraalVM
classes; any other packages are regarded as application classes.
classes for inclusion in the local sources cache.

Sources for JDK runtime classes are retrieved from the _src.zip_ found
in the JDK release used to run the native image generation process.
Retrieved files are cached under subdirectory _sources/jdk_, using the
module name (for JDK11) and package name of the associated class to
Retrieved files are cached under subdirectory _sources_, using the
package name of the associated class to
define the directory hierarchy in which the source is located.

So, for example, on Linux the source for class java.util.HashMap will
be cached in file _sources/jdk/java.base/java/util/HashMap.java_. Debug
be cached in file _sources/java/util/HashMap.java_. Debug
info records for this class and its methods will identify this source
file using the relative directory path _java.base/java/util_ and file
file using the relative directory path _java/util_ and file
name _HashMap.java_. On Windows things will be the same modulo use of
'\' rather than '/' as the file separator.

Sources for GraalVM classes are retrieved from zip files or source
directories derived from entries in the classpath. Retrieved files are
cached under subdirectory _sources/graal_, using the package name of the
cached under subdirectory _sources_, using the package name of the
associated class to define the directory hierarchy in which the source
is located (e.g. class `com.oracle.svm.core.VM` has its source file
cached at `sources/graal/com/oracle/svm/core/VM.java`).
cached at `sources/com/oracle/svm/core/VM.java`).

The lookup scheme for cached GraalVM sources varies depending upon
what is found in each classpath entry. Given a jar file entry like
Expand All @@ -141,15 +136,15 @@ be extracted. When the entry specifies a dir like _/path/to/bar_ then
directories _/path/to/bar/src_ and _/path/to/bar/src_gen_ are considered
as candidates. Candidates are skipped when i) the zip file or source
directory does not exist or ii) it does not contain at least one
subdirectory hierarchy that matches one of the the expected GraalVM
subdirectory hierarchy that matches one of the expected GraalVM
package hierarchies.

Sources for application classes are retrieved from source jar files or
source directories derived from entries in the classpath. Retrieved
files are cached under subdirectory _sources/src_, using the package
files are cached under subdirectory _sources_, using the package
name of the associated class to define the directory hierarchy in
which the source is located (e.g., class `org.my.foo.Foo` has its
source file cached as `sources/src/org/my/foo/Foo.java`).
source file cached as `sources/org/my/foo/Foo.java`).

The lookup scheme for cached Application sources varies depending upon
what is found in each classpath entry. Given a jar file entry like
Expand All @@ -170,30 +165,26 @@ configure extra source search paths.

### Configuring Source Paths in GNU Debugger

By default gdb will employ the three local directory roots
`sources/{jdk,graal,src}` to locate the source files for your app classes, Graal
By default gdb will employ the `sources` directory
to locate the source files for your app classes, Graal
classes and JDK runtime classes. If the sources cache is not located in the
directory in which you run gdb you can configure the required paths using the
directory in which you run gdb you can configure the required path using the
following command:
```
(gdb) set directories /path/to/sources/jdk:/path/to/sources/graal:/path/to/sources/src
```
Directory `/path/to/sources/jdk` should contain source files for all JDK runtime
classes referenced from debug records.

Directory `/path/to/sources/graal` should contain source files for all GraalVM
classes referenced from debug records. Note that the current
implementation does not yet find some sources for the GraalVM JIT
compiler in the _org.graalvm.compiler*_ package subspace.
(gdb) set directories /path/to/sources

Directory `/path/to/sources/src` should contain source files for all
application classes referenced from debug records, assuming they can
be located using the lookup strategy described above.
where directory `/path/to/sources` should contain source files for:
1. all JDK runtime classes referenced from debug records.
2. all GraalVM classes referenced from debug records. Note that the current
implementation does not yet find some sources for the GraalVM JIT
compiler in the org.graalvm.compiler* package subspace.
3. all application classes referenced from debug records, assuming they can
be located using the lookup strategy described above.

You can supplement the files cached in `sources/src` by unzipping
You can supplement the files cached in `sources` by unzipping
application source jars or copying application source trees into the
cache. You need to ensure that any new subdirectory you add to
`sources/src` corresponds to the top level package for the classes whose
`sources` corresponds to the top level package for the classes whose
sources are being included.

You can also add extra directories to the search path using the `set
Expand Down

This file was deleted.

This file was deleted.

Loading

0 comments on commit 1cc9e71

Please sign in to comment.