mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-03 20:34:58 +08:00
b104dbedbe
Palmer suggested at some point, not sure if it was in one of the weekly linux-riscv syncs, or a conversation at FOSDEM, that we should document the role of the automation running on our patchwork instance plays in patch acceptance. Add a short note to the patch-acceptance document to that end. Signed-off-by: Conor Dooley <conor.dooley@microchip.com> Reviewed-by: Björn Töpel <bjorn@rivosinc.com> Link: https://lore.kernel.org/r/20230606-rehab-monsoon-12c17bbe08e3@wendy Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
60 lines
2.7 KiB
ReStructuredText
60 lines
2.7 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0
|
|
|
|
arch/riscv maintenance guidelines for developers
|
|
================================================
|
|
|
|
Overview
|
|
--------
|
|
The RISC-V instruction set architecture is developed in the open:
|
|
in-progress drafts are available for all to review and to experiment
|
|
with implementations. New module or extension drafts can change
|
|
during the development process - sometimes in ways that are
|
|
incompatible with previous drafts. This flexibility can present a
|
|
challenge for RISC-V Linux maintenance. Linux maintainers disapprove
|
|
of churn, and the Linux development process prefers well-reviewed and
|
|
tested code over experimental code. We wish to extend these same
|
|
principles to the RISC-V-related code that will be accepted for
|
|
inclusion in the kernel.
|
|
|
|
Patchwork
|
|
---------
|
|
|
|
RISC-V has a patchwork instance, where the status of patches can be checked:
|
|
|
|
https://patchwork.kernel.org/project/linux-riscv/list/
|
|
|
|
If your patch does not appear in the default view, the RISC-V maintainers have
|
|
likely either requested changes, or expect it to be applied to another tree.
|
|
|
|
Automation runs against this patchwork instance, building/testing patches as
|
|
they arrive. The automation applies patches against the current HEAD of the
|
|
RISC-V `for-next` and `fixes` branches, depending on whether the patch has been
|
|
detected as a fix. Failing those, it will use the RISC-V `master` branch.
|
|
The exact commit to which a series has been applied will be noted on patchwork.
|
|
Patches for which any of the checks fail are unlikely to be applied and in most
|
|
cases will need to be resubmitted.
|
|
|
|
Submit Checklist Addendum
|
|
-------------------------
|
|
We'll only accept patches for new modules or extensions if the
|
|
specifications for those modules or extensions are listed as being
|
|
unlikely to be incompatibly changed in the future. For
|
|
specifications from the RISC-V foundation this means "Frozen" or
|
|
"Ratified", for the UEFI forum specifications this means a published
|
|
ECR. (Developers may, of course, maintain their own Linux kernel trees
|
|
that contain code for any draft extensions that they wish.)
|
|
|
|
Additionally, the RISC-V specification allows implementers to create
|
|
their own custom extensions. These custom extensions aren't required
|
|
to go through any review or ratification process by the RISC-V
|
|
Foundation. To avoid the maintenance complexity and potential
|
|
performance impact of adding kernel code for implementor-specific
|
|
RISC-V extensions, we'll only consider patches for extensions that either:
|
|
|
|
- Have been officially frozen or ratified by the RISC-V Foundation, or
|
|
- Have been implemented in hardware that is widely available, per standard
|
|
Linux practice.
|
|
|
|
(Implementers, may, of course, maintain their own Linux kernel trees containing
|
|
code for any custom extensions that they wish.)
|