pvmfw: Print RebootReason on secondary UART

When rebooting due to a business logic error, print the reason as a
formatted string to a dedicated UART, in the same way Microdroid does it
on its /dev/tty1, to provide the host with extra information about the
reason for the pVM rebooting.

Since aosp/2646391, all the pvmfw code runs with the UART properly
initialized, which greatly simplifies printing of the reboot reason as
start() can now assume that the secondary UART is also ready to be used.

This CL was verified through the logs of virtualizationmanager e.g. in
MicrodroidHostTests#protectedVmWithImageSignedWithDifferentKeyRunsPvmfw:

    virtmgr : virtualizationmanager::crosvm: VM returned failure reason 'PVM_FIRMWARE_PAYLOAD_VERIFICATION_FAILED'

Note that the host still has to be taught about the new PVM_FIRMWARE_*.

Bug: 300636104
Test: atest MicrodroidHostTestCases
Change-Id: I5d382be9dae02da7e463193400dfa0474ca5e378
2 files changed
tree: 3bcdf50d3103b76be67c99eed3949f5a73c46e68
  1. apex/
  2. apkdmverity/
  3. authfs/
  4. compos/
  5. demo/
  6. demo_native/
  7. docs/
  8. encryptedstore/
  9. ferrochrome_app/
  10. flags/
  11. java/
  12. launcher/
  13. libs/
  14. microdroid/
  15. microdroid_manager/
  16. pvmfw/
  17. rialto/
  18. service_vm/
  19. tests/
  20. virtualizationmanager/
  21. virtualizationservice/
  22. vm/
  23. vm_payload/
  24. vmbase/
  25. vmclient/
  26. vmlauncher_app/
  27. zipfuse/
  28. .clang-format
  29. .gitignore
  30. Android.bp
  31. avf_flags.aconfig
  32. OWNERS
  33. PREUPLOAD.cfg
  34. README.md
  35. rustfmt.toml
  36. TEST_MAPPING
README.md

Android Virtualization Framework (AVF)

Android Virtualization Framework (AVF) provides secure and private execution environments for executing code. AVF is ideal for security-oriented use cases that require stronger isolation assurances over those offered by Android’s app sandbox.

Visit our public doc site to learn more about what AVF is, what it is for, and how it is structured. This repository contains source code for userspace components of AVF.

If you want a quick start, see the getting started guideline and follow the steps there.

For in-depth explanations about individual topics and components, visit the following links.

AVF components:

AVF APIs:

How-Tos: