[Trusty] Enable verified boot for Trusty VM on top of pvmfw

This cl enables verified boot of the Trusty VM on top of pvmfw. It
involves the following steps:

1. Extract the loadable sections from the Trusty VM ELF image.
2. Sign the extracted binary with AVB and append an AVB footer.
3. Repackage the signed binary into a new ELF file with a single
loadable segment.

crosvm loads this new ELF image and exposes the loadable section
containing the signed image 2. to pvmfw.

Bug: 379646659
Bug: 389914683
Test: m lk_trusty.elf and run the resulting image in pVM on Pixel

Change-Id: I3b865e2f9378d3fc28dfddb4e7d4e5c752878373
2 files changed
tree: 0402b75cf90ec3997f0c1941950c7753291d8e19
  1. android/
  2. build/
  3. docs/
  4. guest/
  5. libs/
  6. microfuchsia/
  7. tests/
  8. .clang-format
  9. .gitignore
  10. Android.bp
  11. dice_for_avf_guest.cddl
  12. OWNERS
  13. PREUPLOAD.cfg
  14. README.md
  15. rustfmt.toml
  16. 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: