[docs][fidl] LLCPP threading guide

This is a more accessible guide explaining how to use LLCPP bindings in
non-trivial threading setups. Since we'll be deprecating all uses of
fidl::Client and replacing them with two new client types with subtle
semantics, it's worthwhile to explain how to use them correctly in a
public doc.

Added a new LLCPP client example using WireSharedClient.
Tweaked the existing client example to use WireClient.
Tweaked the existing server example to demonstrate two-phase shutdown.

Tested by staging the docs on devsite and checking everything renders
correctly.

Change-Id: Icaf950dd3def3cc4302d39875701d565da44d498
Reviewed-on: https://fuchsia-review.googlesource.com/c/fuchsia/+/552742
Fuchsia-Auto-Submit: Yifei Teng <yifeit@google.com>
Commit-Queue: Yifei Teng <yifeit@google.com>
Reviewed-by: Bruno Dal Bo <brunodalbo@google.com>
Reviewed-by: Ian McKellar <ianloic@google.com>
Reviewed-by: Tamir Duberstein <tamird@google.com>
Reviewed-by: Mitchell Kember <mkember@google.com>
18 files changed
tree: 7d222179675238227a5742bd884406985f0f6e7d
  1. boards/
  2. build/
  3. buildtools/
  4. bundles/
  5. docs/
  6. examples/
  7. garnet/
  8. products/
  9. scripts/
  10. sdk/
  11. src/
  12. third_party/
  13. tools/
  14. zircon/
  15. .clang-format
  16. .clang-tidy
  17. .git-blame-ignore-revs
  18. .gitattributes
  19. .gitignore
  20. .gn
  21. .style.yapf
  22. AUTHORS
  23. BUILD.gn
  24. CODE_OF_CONDUCT.md
  25. CONTRIBUTING.md
  26. LICENSE
  27. OWNERS
  28. PATENTS
  29. README.md
  30. rustfmt.toml
README.md

Fuchsia

Pink + Purple == Fuchsia (a new operating system)

What is Fuchsia?

Fuchsia is a modular, capability-based operating system. Fuchsia runs on modern 64-bit Intel and ARM processors.

Fuchsia is an open source project with a code of conduct that we expect everyone who interacts with the project to respect.

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.