[kernel][vm] Remove freeing_owned_pages

Existing call sites sometimes have to 'lie' when freeing pages from a
hierarchy and claiming that the pages are not owned by this node. While
true, they are owned by some node, and should logically be freed by
that node. The argument put forward in these locations is that
hierarchies do not need to be correct, since they will never have a
page source handling free.

Instead of having call sites make this argument and pass a false value
for freeing_owned_pages, this change puts it forward as a global
property, that objects that have a page source handling free do not
have children, that can be checked and then generally assumed. Doing
this allows for removal of the flag passed to free and simplifies
call sites where it was otherwise ambiguous what 'ownership' meant.

Change-Id: I8c32c295293ae0d564ff1459adfa09a0c4d5d0c7
Reviewed-on: https://fuchsia-review.googlesource.com/c/fuchsia/+/1236944
Reviewed-by: Rasha Eqbal <rashaeqbal@google.com>
Commit-Queue: Adrian Danis <adanis@google.com>
7 files changed
tree: 3a55736cc92e80065148249e7589ad5501af807e
  1. .fx/
  2. .helix/
  3. boards/
  4. build/
  5. bundles/
  6. docs/
  7. examples/
  8. infra/
  9. products/
  10. scripts/
  11. sdk/
  12. src/
  13. third_party/
  14. tools/
  15. zircon/
  16. .clang-format
  17. .clang-tidy
  18. .editorconfig
  19. .git-blame-ignore-revs
  20. .gitattributes
  21. .gitignore
  22. .gitmodules
  23. .gn
  24. .ignore
  25. analysis_options.yaml
  26. AUTHORS
  27. BUILD.gn
  28. CODE_OF_CONDUCT.md
  29. CONTRIBUTING.md
  30. fuchsia.code-workspace
  31. LICENSE
  32. OWNERS
  33. PATENTS
  34. pyproject.toml
  35. pyrightconfig.json
  36. README.md
  37. rustfmt.toml
  38. shac.star
  39. shac.textproto
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.