| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- .. SPDX-License-Identifier: (GPL-2.0+ OR MIT)
- ==========
- Guidelines
- ==========
- This document describes the general project guidelines that apply to nova-core
- and nova-drm.
- Language
- ========
- The Nova project uses the Rust programming language. In this context, all rules
- of the Rust for Linux project as documented in
- :doc:`../../rust/general-information` apply. Additionally, the following rules
- apply.
- - Unless technically necessary otherwise (e.g. uAPI), any driver code is written
- in Rust.
- - Unless technically necessary, unsafe Rust code must be avoided. In case of
- technical necessity, unsafe code should be isolated in a separate component
- providing a safe API for other driver code to use.
- Style
- -----
- All rules of the Rust for Linux project as documented in
- :doc:`../../rust/coding-guidelines` apply.
- For a submit checklist, please also see the `Rust for Linux Submit checklist
- addendum <https://rust-for-linux.com/contributing#submit-checklist-addendum>`_.
- Documentation
- =============
- The availability of proper documentation is essential in terms of scalability,
- accessibility for new contributors and maintainability of a project in general,
- but especially for a driver running as complex hardware as Nova is targeting.
- Hence, adding documentation of any kind is very much encouraged by the project.
- Besides that, there are some minimum requirements.
- - Every non-private structure needs at least a brief doc comment explaining the
- semantical sense of the structure, as well as potential locking and lifetime
- requirements. It is encouraged to have the same minimum documentation for
- non-trivial private structures.
- - uAPIs must be fully documented with kernel-doc comments; additionally, the
- semantical behavior must be explained including potential special or corner
- cases.
- - The APIs connecting the 1st level driver (nova-core) with 2nd level drivers
- must be fully documented. This includes doc comments, potential locking and
- lifetime requirements, as well as example code if applicable.
- - Abbreviations must be explained when introduced; terminology must be uniquely
- defined.
- - Register addresses, layouts, shift values and masks must be defined properly;
- unless obvious, the semantical sense must be documented. This only applies if
- the author is able to obtain the corresponding information.
- Acceptance Criteria
- ===================
- - Patches must only be applied if reviewed by at least one other person on the
- mailing list; this also applies for maintainers.
|