diff options
author | 2025-03-21 09:28:56 -0700 | |
---|---|---|
committer | 2025-03-21 09:28:56 -0700 | |
commit | d706aef736e03487a96b22be6f7524406a5161d7 (patch) | |
tree | f3de2744fa09fdf34a1a4f1752dd0c07fa57f252 | |
parent | 4f5fa2777a72f91723dd68ff49f157eed989b698 (diff) | |
parent | 0e235bd9b79c82e3962792eecb17ceb4bbc24089 (diff) |
Add documentation about persistent states of the <SDM, SDC> file pair. am: 0e235bd9b7
Original change: https://android-review.googlesource.com/c/platform/art/+/3556507
Change-Id: I063d1e48a1c3ce3af5a66f942460ec8a249494f8
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
-rw-r--r-- | runtime/oat/sdc_file.h | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/runtime/oat/sdc_file.h b/runtime/oat/sdc_file.h index e2c9b43ba7..f4d7a5d116 100644 --- a/runtime/oat/sdc_file.h +++ b/runtime/oat/sdc_file.h @@ -43,6 +43,20 @@ namespace art HIDDEN { // key2=value2\n // ... // Repeated keys are not allowed. This is an extensible format, so versioning is not needed. +// +// In principle, ART Service generates an SDC file for an SDM file during installation. +// Specifically, during dexopt, which typically takes place during installation, if there is an SDM +// file while the corresponding SDC file is missing (meaning the SDM file is newly installed) or +// stale (meaning the SDM file is newly replaced), ART Service will generate a new SDC file. This +// means an SDM file without a corresponding SDC file is a transient state and is valid from ART +// Service's perspective. +// +// From the runtime's perspective, an SDM file without a corresponding SDC file is incomplete. That +// means: +// - At app execution time, the runtime ignores an SDM file without a corresponding SDC. +// - ART Service's file GC, which uses the runtime's judgement, considers an SDM file without a +// corresponding SDC invalid and may clean it up. This may race with a package installation before +// the SDC is created, but it's rare and the effect is recoverable, so it's considered acceptable. class EXPORT SdcReader { public: static std::unique_ptr<SdcReader> Load(const std::string& filename, std::string* error_msg); |