普通文本  |  23行  |  878 B

# Multi layer tracing

*** note
**This doc is WIP**, stay tuned.
<!-- TODO(primiano): write multi-layer tracing doc. -->
***

This doc should explain how is possible to compose a hierarchy of tracing
services. The concrete use case is combining multiprocess tracing in Chromium
with Android's tracing daemons (think to hypervisors' nested page tables).

The TL;DR of the trick is:
- ABI stability of the
  [shared_memory_abi.h](/include/perfetto/tracing/core/shared_memory_abi.h)
- ABI stability of the IPC surface.

The tracing service in chromium should proxy Producer connections (adapting Mojo
to our IPC) towards the Android's `traced` service, passing back the shared
memory buffers to the real producers (the Chrome child process).

Conceptually it is simple and straightforward, requires *some* care to implement
correctly ownership of the shared memory buffers though.