Support compiling partial system server jars.
Before this change, odrefresh compiles system server jars atomically.
After this change, odrefresh can compile only the system server jars
whose artifacts are missing. This can benefit users in couple ways:
1. When a previous odrefresh run failed due to low storage space,
subsequent runs can continue from the failure point instead of starting
over.
2. When we update odrefresh to compile more things before a change has
been made to the build system to preopt those things at build-time
(e.g., b/203198541), this change can avoid too much regression on the
first boot time by not compiling things that are already preopted.
3. When some artifacts are missing from the system image for unknown
reasons, this change can avoid too much regression on the first boot
time. (This should rarely happen because artifacts' existence is checked
at built-time.)
This CL also includes some minor changes:
1. Introduce a struct `CompilationOptions` to represent what to compile
in a more structured way.
2. Update the comments about compilation space estimation based on the
latest observation.
3. Improve the boot animation progress reporting to reflect the real
number of compilations.
4. Fix the exit code returned on low storage space. (Was `kOkay`, which
was wrong because odsign does not sign artifacts on `kOkay`)
Bug: 203198541
Test: atest art_standalone_odrefresh_tests
Test: odsign_e2e_tests
Change-Id: Id13fa26fa2327a82daff8d8d6fdefe11cd0928a2
diff --git a/odrefresh/odrefresh_main.cc b/odrefresh/odrefresh_main.cc
index aecabd0..ce7d015 100644
--- a/odrefresh/odrefresh_main.cc
+++ b/odrefresh/odrefresh_main.cc
@@ -35,7 +35,7 @@
namespace {
-using ::art::InstructionSet;
+using ::art::odrefresh::CompilationOptions;
using ::art::odrefresh::Concatenate;
using ::art::odrefresh::ExitCode;
using ::art::odrefresh::OdrCompilationLog;
@@ -301,15 +301,12 @@
OnDeviceRefresh odr(config);
for (int i = 0; i < argc; ++i) {
std::string_view action(argv[i]);
- std::vector<InstructionSet> compile_boot_extensions;
- bool compile_system_server;
+ CompilationOptions compilation_options;
if (action == "--check") {
// Fast determination of whether artifacts are up to date.
- return odr.CheckArtifactsAreUpToDate(
- metrics, &compile_boot_extensions, &compile_system_server);
+ return odr.CheckArtifactsAreUpToDate(metrics, &compilation_options);
} else if (action == "--compile") {
- const ExitCode exit_code =
- odr.CheckArtifactsAreUpToDate(metrics, &compile_boot_extensions, &compile_system_server);
+ const ExitCode exit_code = odr.CheckArtifactsAreUpToDate(metrics, &compilation_options);
if (exit_code != ExitCode::kCompilationRequired) {
return exit_code;
}
@@ -319,8 +316,7 @@
// Artifacts refreshed. Return `kCompilationFailed` so that odsign will sign them again.
return ExitCode::kCompilationFailed;
}
- ExitCode compile_result =
- odr.Compile(metrics, compile_boot_extensions, compile_system_server);
+ ExitCode compile_result = odr.Compile(metrics, compilation_options);
compilation_log.Log(metrics.GetArtApexVersion(),
metrics.GetArtApexLastUpdateMillis(),
metrics.GetTrigger(),
@@ -333,8 +329,10 @@
return ExitCode::kCleanupFailed;
}
return odr.Compile(metrics,
- /*compile_boot_extensions=*/config.GetBootExtensionIsas(),
- /*compile_system_server=*/true);
+ CompilationOptions{
+ .compile_boot_extensions_for_isas = config.GetBootExtensionIsas(),
+ .system_server_jars_to_compile = odr.AllSystemServerJars(),
+ });
} else if (action == "--help") {
UsageHelp(argv[0]);
} else {