The Fuchsia device interfaces are expressed as FIDL protocols. These FIDL definitions should conform to the FIDL Style Rubric and FIDL API Rubric.
Prefer descriptive identifiers. If you are using domain-specific abbreviations, document the expansion or provide a reference for further information.
Every identifier that is defined as part of a protocol must be documented with a comment explaining its interpretation (in the case of fields, types, and parameters) or behavior (in the case of methods).
All device interface protocols must use the [Layout = "Simple"] attribute.  This restriction exists to allow ease of implementing protocols in any of our supported languages for driver development.
Use a zx.status return to represent success and failure.  If a method should not be able to fail, do not provide a zx.status return.  If the method returns multiple values, the zx.status should come first.
All arrays, strings, and vectors must be of bounded length.  For arbitrarily selected bounds, prefer to use a const identifier as the length so that protocol consumers can programmatically inspect the length.
Prefer enums with explicit sizes (e.g. enum Foo : uint32 { ... }) to plain integer types when a field has a constrained set of non-arithmetic values.
If your protocol has a bitfield, represent its values using bits values. For details, see the “bits” topic in the readability rubric.
Some interface protocols may negotiate a non-channel protocol as a performance optimization (e.g. the zircon.ethernet.Device's GetFifos/SetIOBuffer methods). FIDL does not currently support expressing these protocols.  For now, represent any shared data structures with struct definitions and provide detailed documentation about participation in the protocol.  Packed structures are not currently supported.