Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 1 | .. SPDX-License-Identifier: GPL-2.0+: |
| 2 | |
| 3 | U-Boot Development Process |
| 4 | ========================== |
| 5 | |
| 6 | Management Summary |
| 7 | ------------------ |
| 8 | |
| 9 | * Development happens in Release Cycles of 3 months. |
| 10 | |
Tom Rini | 105bccb | 2022-07-12 17:34:15 -0400 | [diff] [blame] | 11 | * The first 3 weeks of the cycle are referred to as the Merge Window, which is |
| 12 | followed by a Stabilization Period. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 13 | |
| 14 | * Patches with new code get only accepted while the Merge Window is open. |
| 15 | |
| 16 | * A patch that is generally in good shape and that was submitted while the |
| 17 | Merge Window was open is eligible to go into the upcoming release, even if |
| 18 | changes and resubmits are needed. |
| 19 | |
| 20 | * During the Stabilization Period, only patches that contain bug fixes get |
| 21 | applied. |
| 22 | |
| 23 | Phases of the Development Process |
| 24 | --------------------------------- |
| 25 | |
| 26 | U-Boot development takes place in `Release Cycles |
| 27 | <https://www.denx.de/wiki/U-Boot/ReleaseCycle>`_. A Release Cycle lasts |
| 28 | normally for three months. |
| 29 | |
Tom Rini | 105bccb | 2022-07-12 17:34:15 -0400 | [diff] [blame] | 30 | The first three weeks of each Release Cycle are called *Merge Window*. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 31 | |
| 32 | It is followed by a *Stabilization Period*. |
| 33 | |
| 34 | The end of a Release Cycle is marked by the release of a new U-Boot version. |
| 35 | |
| 36 | Merge Window |
Tom Rini | b439b99 | 2024-05-17 11:49:29 -0600 | [diff] [blame] | 37 | ^^^^^^^^^^^^ |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 38 | |
Tom Rini | 105bccb | 2022-07-12 17:34:15 -0400 | [diff] [blame] | 39 | The Merge Window is the period when new patches get submitted (and hopefully |
| 40 | accepted) for inclusion into U-Boot mainline. This period lasts for 21 days (3 |
| 41 | weeks) and ends with the release of ``"-rc1"``. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 42 | |
| 43 | This is the only time when new code (like support for new processors or new |
| 44 | boards, or other new features or reorganization of code) is accepted. |
| 45 | |
| 46 | Twilight Time |
Tom Rini | b439b99 | 2024-05-17 11:49:29 -0600 | [diff] [blame] | 47 | ^^^^^^^^^^^^^ |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 48 | |
| 49 | Usually patches do not get accepted as they are - the peer review that takes |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 50 | place will usually require changes and resubmissions of the patches before they |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 51 | are considered to be ripe for inclusion into mainline. |
| 52 | |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 53 | Also the review often happens not immediately after a patch was submitted, |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 54 | but only when somebody (usually the responsible custodian) finds time to do |
| 55 | this. |
| 56 | |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 57 | The result is that the final version of such patches gets submitted after the |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 58 | merge window has been closed. |
| 59 | |
| 60 | It is current practice in U-Boot that such patches are eligible to go into the |
| 61 | upcoming release. |
| 62 | |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 63 | The result is that the release of the ``"-rc1"`` version and formal closing of |
| 64 | the Merge Window does not preclude patches that were already posted from being |
| 65 | merged for the upcoming release. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 66 | |
| 67 | Stabilization Period |
Tom Rini | b439b99 | 2024-05-17 11:49:29 -0600 | [diff] [blame] | 68 | ^^^^^^^^^^^^^^^^^^^^ |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 69 | |
| 70 | During the Stabilization Period only patches containing bug fixes get |
| 71 | applied. |
| 72 | |
| 73 | Corner Cases |
Tom Rini | b439b99 | 2024-05-17 11:49:29 -0600 | [diff] [blame] | 74 | ^^^^^^^^^^^^ |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 75 | |
| 76 | Sometimes it is not clear if a patch contains a bug fix or not. |
| 77 | For example, changes that remove dead code, unused macros etc. or |
| 78 | that contain Coding Style fixes are not strict bug fixes. |
| 79 | |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 80 | In such situations it is up to the responsible custodian to decide if they |
| 81 | apply such patches even when the Merge Window is closed. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 82 | |
| 83 | Exception: at the end of the Stabilization Period only strict bug |
| 84 | fixes my be applied. |
| 85 | |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 86 | Sometimes patches miss the Merge Window slightly - say by a few |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 87 | hours or even a day. Patch acceptance is not as critical as a |
| 88 | financial transaction, or such. So if there is such a slight delay, |
| 89 | the custodian is free to turn a blind eye and accept it anyway. The |
| 90 | idea of the development process is to make it foreseeable, |
| 91 | but not to slow down development. |
| 92 | |
| 93 | It makes more sense if an engineer spends another day on testing and |
| 94 | cleanup and submits the patch a couple of hours late, instead of |
| 95 | submitting a green patch which will waste efforts from several people |
| 96 | during several rounds of review and reposts. |
| 97 | |
| 98 | Differences to the Linux Development Process |
| 99 | -------------------------------------------- |
| 100 | |
| 101 | * In Linux, top-level maintainers will collect patches in their trees and send |
| 102 | pull requests to Linus as soon as the merge window opens. |
| 103 | So far, most U-Boot custodians do not work like that; they send pull requests |
| 104 | only at (or even after) the end of the merge window. |
| 105 | |
| 106 | * In Linux, the closing of the merge window is marked by the release of the |
| 107 | next ``"-rc1"`` |
| 108 | In U-Boot, ``"-rc1"`` will only be released after all (or at least most of |
| 109 | the) patches that were submitted during the merge window have been applied. |
| 110 | |
Tom Rini | 0efc5a9 | 2024-05-17 11:49:30 -0600 | [diff] [blame] | 111 | Resyncing of the device tree subtree |
| 112 | ------------------------------------ |
| 113 | |
| 114 | As explained in :doc:`devicetree/control` some platforms make use of device tree |
| 115 | files which come from a git subtree that mirrors the Linux Kernel sources |
| 116 | itself. For our purposes, we only track releases and not release candidates for |
| 117 | merging in our tree. These merges follow the normal merge window rules. |
| 118 | |
| 119 | In the case of specific changes, such as bug fixes or new platform support, |
| 120 | these can be "cherry-picked" and are subject to the normal merge rules. For |
| 121 | example, a bug fix can come in later in the window but a full re-sync only |
| 122 | happens within the merge window itself. |
| 123 | |
Tom Rini | 6349b18 | 2022-08-29 12:59:33 -0400 | [diff] [blame] | 124 | .. _custodians: |
| 125 | |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 126 | Custodians |
| 127 | ---------- |
| 128 | |
| 129 | The Custodians take responsibility for some area of the U-Boot code. The |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 130 | in-tree ``MAINTAINERS`` files list who is responsible for which areas. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 131 | |
| 132 | It is their responsibility to pick up patches from the mailing list |
| 133 | that fall into their responsibility, and to process these. |
| 134 | |
| 135 | A very important responsibility of each custodian is to provide |
| 136 | feedback to the submitter of a patch about what is going on: if the |
| 137 | patch was accepted, or if it was rejected (which exact list of |
| 138 | reasons), if it needs to be reworked (with respective review |
| 139 | comments). Even a "I have no time now, will look into it later" |
| 140 | message is better than nothing. Also, if there are remarks to a |
| 141 | patch, these should leave no doubt if they were just comments and the |
| 142 | patch will be accepted anyway, or if the patch should be |
| 143 | reworked/resubmitted, or if it was rejected. |
| 144 | |
Tom Rini | 286ed78 | 2022-08-29 12:59:34 -0400 | [diff] [blame] | 145 | Review Process, Git Tags |
| 146 | ------------------------ |
| 147 | |
| 148 | There are a number of *git tags* that are used to document the origin and the |
| 149 | processing of patches on their way into the mainline U-Boot code. The following |
| 150 | is an attempt to document how these are usually handled in the U-Boot project. |
| 151 | |
| 152 | In general, we try to follow the established procedures from other projects, |
| 153 | especially the Linux kernel, but there may be smaller differences. For |
| 154 | reference, see the Linux kernel's `Submitting patches |
| 155 | <https://www.kernel.org/doc/html/latest/process/submitting-patches.html>`_ |
| 156 | document. |
| 157 | |
| 158 | .. _dco: |
| 159 | |
| 160 | * Signed-off-by: the *Signed-off-by:* is a line at the end of the commit |
| 161 | message by which the signer certifies that they were involved in the development |
| 162 | of the patch and that they accept the `Developer Certificate of Origin |
| 163 | <https://developercertificate.org/>`_. Following this and adding a |
| 164 | ``Signed-off-by:`` line that contains the developer's name and email address |
| 165 | is required. |
| 166 | |
| 167 | * Please note that in U-Boot, we do not add a ``Signed-off-by`` tag if we |
| 168 | just pass on a patch without any changes. |
| 169 | |
| 170 | * Please note that when importing code from other projects you must say |
| 171 | where it comes from, and what revision you are importing. You must not |
| 172 | however copy ``Signed-off-by`` or other tags. |
| 173 | |
| 174 | * Everybody who can is invited to review and test the changes. Typically, we |
| 175 | follow the same guidelines as the Linux kernel for `Acked-by |
| 176 | <https://www.kernel.org/doc/html/latest/process/submitting-patches.html#when-to-use-acked-by-cc-and-co-developed-by>`_ |
| 177 | as well as `Reviewed-by |
| 178 | <https://www.kernel.org/doc/html/latest/process/submitting-patches.html#using-reported-by-tested-by-reviewed-by-suggested-by-and-fixes>`_ |
| 179 | and similar additional tags. |
| 180 | |
Maxim Cournoyer | e7d962b | 2022-12-16 21:09:40 -0500 | [diff] [blame] | 181 | * Reviewed-by: The patch has been reviewed and found acceptable according to |
| 182 | the `Reviewer's statement of oversight |
Tom Rini | 286ed78 | 2022-08-29 12:59:34 -0400 | [diff] [blame] | 183 | <https://www.kernel.org/doc/html/latest/process/submitting-patches.html#reviewer-s-statement-of-oversight>`_. |
| 184 | A *Reviewed-by:* tag is a statement of opinion that the patch is an |
| 185 | appropriate modification of the code without any remaining serious technical |
| 186 | issues. Any interested reviewer (who has done the work) can offer a |
| 187 | *Reviewed-by:* tag for a patch. |
| 188 | |
| 189 | * Acked-by: If a person was not directly involved in the preparation or |
| 190 | handling of a patch but wishes to signify and record their approval of it |
| 191 | then they can arrange to have an *Acked-by:* line added to the patch's |
| 192 | changelog. |
| 193 | |
| 194 | * Tested-by: A *Tested-by:* tag indicates that the patch has been successfully |
| 195 | tested (in some environment) by the person named. Andrew Morton: "I think |
| 196 | it's very useful information to have. For a start, it tells you who has the |
| 197 | hardware and knows how to build a kernel. So if you're making a change to a |
| 198 | driver and want it tested, you can troll the file's changelog looking for |
| 199 | people who might be able to help." |
| 200 | |
| 201 | * Reported-by: If this patch fixes a problem reported by somebody else, |
| 202 | consider adding a *Reported-by:* tag to credit the reporter for their |
| 203 | contribution. Please note that this tag should not be added without the |
| 204 | reporter's permission, especially if the problem was not reported in a public |
| 205 | forum. |
| 206 | |
| 207 | * Cc: If a person should have the opportunity to comment on a patch, you may |
| 208 | optionally add a *Cc:* tag to the patch. Git tools (git send-email) will then |
Maxim Cournoyer | e7d962b | 2022-12-16 21:09:40 -0500 | [diff] [blame] | 209 | automatically arrange that they receives a copy of the patch when you submit |
| 210 | it to the mailing list. This is the only tag which might be added without an |
Tom Rini | 286ed78 | 2022-08-29 12:59:34 -0400 | [diff] [blame] | 211 | explicit action by the person it names. This tag documents that potentially |
| 212 | interested parties have been included in the discussion. |
| 213 | For example, when your change affects a specific board or driver, then makes |
| 214 | a lot of sense to put the respective maintainer of this code on Cc: |
| 215 | |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 216 | Work flow of a Custodian |
| 217 | ------------------------ |
| 218 | |
| 219 | The normal flow of work in the U-Boot development process will look |
| 220 | like this: |
| 221 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 222 | #. The responsible custodian inspects this patch, especially for: |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 223 | |
Tom Rini | 286ed78 | 2022-08-29 12:59:34 -0400 | [diff] [blame] | 224 | #. The commit message is useful, descriptive and makes correct and |
Maxim Cournoyer | e7d962b | 2022-12-16 21:09:40 -0500 | [diff] [blame] | 225 | appropriate usage of required *git tags*. |
Tom Rini | 286ed78 | 2022-08-29 12:59:34 -0400 | [diff] [blame] | 226 | |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 227 | #. :doc:`codingstyle` |
| 228 | |
| 229 | #. Basic logic: |
| 230 | |
| 231 | * The patch fixes a real problem. |
| 232 | |
| 233 | * The patch does not introduce new problems, especially it does not break |
| 234 | other boards or architectures |
| 235 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 236 | #. U-Boot Philosophy, as documented in :doc:`designprinciples`. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 237 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 238 | #. Applies cleanly to the source tree. The custodian is expected to put in |
| 239 | a "best effort" if a patch does not apply cleanly, but can be made to apply |
| 240 | still. It is up to the custodian to decide how recent of a commit the |
| 241 | patch must be against. It is acceptable to request patches against the |
| 242 | last officially released version of U-Boot or newer. Of course a |
| 243 | custodian can also accept patches against older code. It can be |
| 244 | difficult to find the correct balance between putting too much work on |
| 245 | the custodian or too much work on an individual submitting a patch when |
| 246 | something does not apply cleanly. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 247 | |
Tom Rini | 50a7adc | 2022-07-14 08:07:45 -0400 | [diff] [blame] | 248 | #. Passes :doc:`ci_testing` as this checks for new warnings and other issues. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 249 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 250 | #. Note that in some cases more than one custodian may feel responsible for a |
| 251 | particular change. To avoid duplicated efforts, the custodian who starts |
| 252 | processing the patch should follow up to the email saying they intend to |
| 253 | pick it up. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 254 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 255 | #. Commits must show original author in the ``author`` field and include all of |
| 256 | the ``Signed-off-by``, ``Reviewed-by``, etc, tags that have been submitted. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 257 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 258 | #. The final decision to accept or reject a patch comes down to the custodian |
| 259 | in question. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 260 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 261 | #. If accepted, the custodian adds the patch to their public git repository. |
| 262 | Ideally, they will also follow up on the mailing list with some notification |
| 263 | that it has been applied. This is not always easy given different custodian |
| 264 | workflows and environments however. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 265 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 266 | #. Although a custodian is supposed to perform their own tests it is a |
Maxim Cournoyer | e7d962b | 2022-12-16 21:09:40 -0500 | [diff] [blame] | 267 | well-known and accepted fact that they need help from other developers who |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 268 | - for example - have access to the required hardware or other relevant |
| 269 | environments. Custodians are expected to ask for assistance with testing |
| 270 | when required. |
Tom Rini | dc1ad47 | 2022-07-14 08:07:43 -0400 | [diff] [blame] | 271 | |
Tom Rini | 6155073 | 2022-07-14 08:07:46 -0400 | [diff] [blame] | 272 | #. Custodians are expected to submit a timely pull request of their git |
| 273 | repository to the main repository. It is strongly encouraged that a CI run |
| 274 | has been completed prior to submission, but not required. |