[zircon] Fix XHCI, PHY tuning, and CDC Ethernet issues

This patch fixes various XHCI issues that caused problems
with CDC-Ethernet on certain boards with high-latency interrupts.

The following changes have been made in this patch:

* Add a direct mode for USB URBs to bypass re-assembly
and buffering throughout the pipeline and take the
most "direct" path from an interrupt handler to driver code.

* Enable direct mode for CDC Ethernet TX and RX paths.
* Increase the buffer size used for CDC Ethernet.
* Implement multi-page TRB support in XHCI.
* Increase the size of the transfer and event ring buffers.
* Revert workaround in pack-images.py

CONN-50
ZX-3957

Test: Validate no software-related packet loss in XHCI and
CDC Ethernet drivers on affected boards. Ran additional tests described
in CONN-50.

Change-Id: Ice7429ee63109db67b254488d7127a8bd95394ab
19 files changed
tree: d4a5ba87f7bc323f291af40132c8ac645922ea0a
  1. boards/
  2. build/
  3. buildtools/
  4. bundles/
  5. docs/
  6. examples/
  7. garnet/
  8. infra/
  9. peridot/
  10. products/
  11. scripts/
  12. sdk/
  13. src/
  14. third_party/
  15. tools/
  16. zircon/
  17. .clang-format
  18. .clang-tidy
  19. .dir-locals.el
  20. .gitattributes
  21. .gitignore
  22. .gn
  23. AUTHORS
  24. BUILD.gn
  25. CODE_OF_CONDUCT.md
  26. CONTRIBUTING.md
  27. LICENSE
  28. OWNERS
  29. PATENTS
  30. README.md
  31. 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.

How can I build and run Fuchsia?

See Getting Started.

Where can I learn more about Fuchsia?

See the documentation.