Based on kernel version 6.15
. Page generated on 2025-05-29 09:09 EST
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | .. 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. |