[fatfs] Fix bug in determine_fs_geometry

The estimated FatType passed to determine_fs_geometry didn't match up
with the actual FatType used, which resulted in certain values failing
to find any valid geometries.

This change also makes determine_fs_geometry more strict about
respecting the requested FatType, which means that we have to change the
ffx efi plugin to *not* specify FatType since FAT32 has a minimum volume
size of 32MB.  In practice, images smaller than this would have been
created in FAT12 or FAT16 format anyawys, so we might as well make this
explicit.

Tested: Added a regression test, and also tested all values in a large
        range manually.
Change-Id: I4dd9c6d50d3d3af4938995104c6d3e0676d4bedf
Reviewed-on: https://fuchsia-review.googlesource.com/c/fuchsia/+/819208
Reviewed-by: Stephen Demos <sdemos@google.com>
Commit-Queue: James Sullivan <jfsulliv@google.com>
Reviewed-by: Megan Batty <mgnb@google.com>
4 files changed
tree: 0ebef3843d99926782601513487ca222716395ea
  1. boards/
  2. build/
  3. bundles/
  4. docs/
  5. examples/
  6. products/
  7. scripts/
  8. sdk/
  9. src/
  10. third_party/
  11. tools/
  12. zircon/
  13. .clang-format
  14. .clang-tidy
  15. .editorconfig
  16. .git-blame-ignore-revs
  17. .gitattributes
  18. .gitignore
  19. .gitmodules
  20. .gn
  21. .ignore
  22. .style.yapf
  23. analysis_options.yaml
  24. AUTHORS
  25. BUILD.gn
  26. CODE_OF_CONDUCT.md
  27. CONTRIBUTING.md
  28. fuchsia.code-workspace
  29. LICENSE
  30. OWNERS
  31. PATENTS
  32. pyrightconfig.json
  33. README.md
  34. rustfmt.toml
README.md

Fuchsia

What is Fuchsia?

Fuchsia is an open source, general purpose operating system supporting modern 64-bit Intel and ARM processors.

We expect everyone interacting with our project to respect our code of conduct.

Read more about Fuchsia's principles.

How can I build and run Fuchsia?

See Getting Started.

Where can I learn more about Fuchsia?

See fuchsia.dev.