pvmfw: config: Treat v1.x as latest version known

Currently, pvmfw rejects config data of versions it doesn't support,
which leads to the pVM boot being aborted. Instead, as the config header
format was designed to be forward compatible[*], if a version v1.x
higher than the latest known version is encountered, treat it as the
highest supported version i.e. read the entries that were supported in
that latest version and ignore any new (unknown) entries.

For the same reason, stop rejecting unknown config data flags being set.

Rename body_offset() to body_lowest_bound() to make it clear that it is
a best-effort value.

[*]: its first fields (magic, version, size, flags) are fixed and its
     array of entries (of version-dependent size) contains offsets from
     the base (not end) of the header.

Bug: 296207806
Test: atest DebugPolicyHostTests
Change-Id: I7969d0189be48a6d54c85965d0092495b43e1982
1 file changed
tree: 0426e9011b40ea426ae7f01c71415f3a5c64d304
  1. apex/
  2. apkdmverity/
  3. authfs/
  4. compos/
  5. demo/
  6. demo_native/
  7. docs/
  8. encryptedstore/
  9. javalib/
  10. launcher/
  11. libs/
  12. microdroid/
  13. microdroid_manager/
  14. pvmfw/
  15. rialto/
  16. service_vm/
  17. tests/
  18. virtualizationmanager/
  19. virtualizationservice/
  20. vm/
  21. vm_payload/
  22. vmbase/
  23. vmclient/
  24. zipfuse/
  25. .clang-format
  26. .gitignore
  27. Android.bp
  28. OWNERS
  29. PREUPLOAD.cfg
  30. README.md
  31. 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:

How-Tos: