1.. SPDX-License-Identifier: GPL-2.0 2 3.. _netdev-FAQ: 4 5============================= 6Networking subsystem (netdev) 7============================= 8 9tl;dr 10----- 11 12 - designate your patch to a tree - ``[PATCH net]`` or ``[PATCH net-next]`` 13 - for fixes the ``Fixes:`` tag is required, regardless of the tree 14 - don't post large series (> 15 patches), break them up 15 - don't repost your patches within one 24h period 16 - reverse xmas tree 17 18netdev 19------ 20 21netdev is a mailing list for all network-related Linux stuff. This 22includes anything found under net/ (i.e. core code like IPv6) and 23drivers/net (i.e. hardware specific drivers) in the Linux source tree. 24 25Note that some subsystems (e.g. wireless drivers) which have a high 26volume of traffic have their own specific mailing lists and trees. 27 28Like many other Linux mailing lists, the netdev list is hosted at 29kernel.org with archives available at https://lore.kernel.org/netdev/. 30 31Aside from subsystems like those mentioned above, all network-related 32Linux development (i.e. RFC, review, comments, etc.) takes place on 33netdev. 34 35Development cycle 36----------------- 37 38Here is a bit of background information on 39the cadence of Linux development. Each new release starts off with a 40two week "merge window" where the main maintainers feed their new stuff 41to Linus for merging into the mainline tree. After the two weeks, the 42merge window is closed, and it is called/tagged ``-rc1``. No new 43features get mainlined after this -- only fixes to the rc1 content are 44expected. After roughly a week of collecting fixes to the rc1 content, 45rc2 is released. This repeats on a roughly weekly basis until rc7 46(typically; sometimes rc6 if things are quiet, or rc8 if things are in a 47state of churn), and a week after the last vX.Y-rcN was done, the 48official vX.Y is released. 49 50To find out where we are now in the cycle - load the mainline (Linus) 51page here: 52 53 https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git 54 55and note the top of the "tags" section. If it is rc1, it is early in 56the dev cycle. If it was tagged rc7 a week ago, then a release is 57probably imminent. If the most recent tag is a final release tag 58(without an ``-rcN`` suffix) - we are most likely in a merge window 59and ``net-next`` is closed. 60 61git trees and patch flow 62------------------------ 63 64There are two networking trees (git repositories) in play. Both are 65driven by David Miller, the main network maintainer. There is the 66``net`` tree, and the ``net-next`` tree. As you can probably guess from 67the names, the ``net`` tree is for fixes to existing code already in the 68mainline tree from Linus, and ``net-next`` is where the new code goes 69for the future release. You can find the trees here: 70 71- https://git.kernel.org/pub/scm/linux/kernel/git/netdev/net.git 72- https://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next.git 73 74Relating that to kernel development: At the beginning of the 2-week 75merge window, the ``net-next`` tree will be closed - no new changes/features. 76The accumulated new content of the past ~10 weeks will be passed onto 77mainline/Linus via a pull request for vX.Y -- at the same time, the 78``net`` tree will start accumulating fixes for this pulled content 79relating to vX.Y 80 81An announcement indicating when ``net-next`` has been closed is usually 82sent to netdev, but knowing the above, you can predict that in advance. 83 84.. warning:: 85 Do not send new ``net-next`` content to netdev during the 86 period during which ``net-next`` tree is closed. 87 88RFC patches sent for review only are obviously welcome at any time 89(use ``--subject-prefix='RFC net-next'`` with ``git format-patch``). 90 91Shortly after the two weeks have passed (and vX.Y-rc1 is released), the 92tree for ``net-next`` reopens to collect content for the next (vX.Y+1) 93release. 94 95If you aren't subscribed to netdev and/or are simply unsure if 96``net-next`` has re-opened yet, simply check the ``net-next`` git 97repository link above for any new networking-related commits. You may 98also check the following website for the current status: 99 100 https://netdev.bots.linux.dev/net-next.html 101 102The ``net`` tree continues to collect fixes for the vX.Y content, and is 103fed back to Linus at regular (~weekly) intervals. Meaning that the 104focus for ``net`` is on stabilization and bug fixes. 105 106Finally, the vX.Y gets released, and the whole cycle starts over. 107 108netdev patch review 109------------------- 110 111.. _patch_status: 112 113Patch status 114~~~~~~~~~~~~ 115 116Status of a patch can be checked by looking at the main patchwork 117queue for netdev: 118 119 https://patchwork.kernel.org/project/netdevbpf/list/ 120 121The "State" field will tell you exactly where things are at with your 122patch: 123 124================== ============================================================= 125Patch state Description 126================== ============================================================= 127New, Under review pending review, patch is in the maintainer’s queue for 128 review; the two states are used interchangeably (depending on 129 the exact co-maintainer handling patchwork at the time) 130Accepted patch was applied to the appropriate networking tree, this is 131 usually set automatically by the pw-bot 132Needs ACK waiting for an ack from an area expert or testing 133Changes requested patch has not passed the review, new revision is expected 134 with appropriate code and commit message changes 135Rejected patch has been rejected and new revision is not expected 136Not applicable patch is expected to be applied outside of the networking 137 subsystem 138Awaiting upstream patch should be reviewed and handled by appropriate 139 sub-maintainer, who will send it on to the networking trees; 140 patches set to ``Awaiting upstream`` in netdev's patchwork 141 will usually remain in this state, whether the sub-maintainer 142 requested changes, accepted or rejected the patch 143Deferred patch needs to be reposted later, usually due to dependency 144 or because it was posted for a closed tree 145Superseded new version of the patch was posted, usually set by the 146 pw-bot 147RFC not to be applied, usually not in maintainer’s review queue, 148 pw-bot can automatically set patches to this state based 149 on subject tags 150================== ============================================================= 151 152Patches are indexed by the ``Message-ID`` header of the emails 153which carried them so if you have trouble finding your patch append 154the value of ``Message-ID`` to the URL above. 155 156Updating patch status 157~~~~~~~~~~~~~~~~~~~~~ 158 159Contributors and reviewers do not have the permissions to update patch 160state directly in patchwork. Patchwork doesn't expose much information 161about the history of the state of patches, therefore having multiple 162people update the state leads to confusion. 163 164Instead of delegating patchwork permissions netdev uses a simple mail 165bot which looks for special commands/lines within the emails sent to 166the mailing list. For example to mark a series as Changes Requested 167one needs to send the following line anywhere in the email thread:: 168 169 pw-bot: changes-requested 170 171As a result the bot will set the entire series to Changes Requested. 172This may be useful when author discovers a bug in their own series 173and wants to prevent it from getting applied. 174 175The use of the bot is entirely optional, if in doubt ignore its existence 176completely. Maintainers will classify and update the state of the patches 177themselves. No email should ever be sent to the list with the main purpose 178of communicating with the bot, the bot commands should be seen as metadata. 179 180The use of the bot is restricted to authors of the patches (the ``From:`` 181header on patch submission and command must match!), maintainers of 182the modified code according to the MAINTAINERS file (again, ``From:`` 183must match the MAINTAINERS entry) and a handful of senior reviewers. 184 185Bot records its activity here: 186 187 https://netdev.bots.linux.dev/pw-bot.html 188 189Review timelines 190~~~~~~~~~~~~~~~~ 191 192Generally speaking, the patches get triaged quickly (in less than 19348h). But be patient, if your patch is active in patchwork (i.e. it's 194listed on the project's patch list) the chances it was missed are close to zero. 195 196The high volume of development on netdev makes reviewers move on 197from discussions relatively quickly. New comments and replies 198are very unlikely to arrive after a week of silence. If a patch 199is no longer active in patchwork and the thread went idle for more 200than a week - clarify the next steps and/or post the next version. 201 202For RFC postings specifically, if nobody responded in a week - reviewers 203either missed the posting or have no strong opinions. If the code is ready, 204repost as a PATCH. 205 206Emails saying just "ping" or "bump" are considered rude. If you can't figure 207out the status of the patch from patchwork or where the discussion has 208landed - describe your best guess and ask if it's correct. For example:: 209 210 I don't understand what the next steps are. Person X seems to be unhappy 211 with A, should I do B and repost the patches? 212 213.. _Changes requested: 214 215Changes requested 216~~~~~~~~~~~~~~~~~ 217 218Patches :ref:`marked<patch_status>` as ``Changes Requested`` need 219to be revised. The new version should come with a change log, 220preferably including links to previous postings, for example:: 221 222 [PATCH net-next v3] net: make cows go moo 223 224 Even users who don't drink milk appreciate hearing the cows go "moo". 225 226 The amount of mooing will depend on packet rate so should match 227 the diurnal cycle quite well. 228 229 Signed-off-by: Joe Defarmer <joe@barn.org> 230 --- 231 v3: 232 - add a note about time-of-day mooing fluctuation to the commit message 233 v2: https://lore.kernel.org/netdev/123themessageid@barn.org/ 234 - fix missing argument in kernel doc for netif_is_bovine() 235 - fix memory leak in netdev_register_cow() 236 v1: https://lore.kernel.org/netdev/456getstheclicks@barn.org/ 237 238The commit message should be revised to answer any questions reviewers 239had to ask in previous discussions. Occasionally the update of 240the commit message will be the only change in the new version. 241 242Partial resends 243~~~~~~~~~~~~~~~ 244 245Please always resend the entire patch series and make sure you do number your 246patches such that it is clear this is the latest and greatest set of patches 247that can be applied. Do not try to resend just the patches which changed. 248 249Handling misapplied patches 250~~~~~~~~~~~~~~~~~~~~~~~~~~~ 251 252Occasionally a patch series gets applied before receiving critical feedback, 253or the wrong version of a series gets applied. 254 255Making the patch disappear once it is pushed out is not possible, the commit 256history in netdev trees is immutable. 257Please send incremental versions on top of what has been merged in order to fix 258the patches the way they would look like if your latest patch series was to be 259merged. 260 261In cases where full revert is needed the revert has to be submitted 262as a patch to the list with a commit message explaining the technical 263problems with the reverted commit. Reverts should be used as a last resort, 264when original change is completely wrong; incremental fixes are preferred. 265 266Stable tree 267~~~~~~~~~~~ 268 269While it used to be the case that netdev submissions were not supposed 270to carry explicit ``CC: stable@vger.kernel.org`` tags that is no longer 271the case today. Please follow the standard stable rules in 272:ref:`Documentation/process/stable-kernel-rules.rst <stable_kernel_rules>`, 273and make sure you include appropriate Fixes tags! 274 275Security fixes 276~~~~~~~~~~~~~~ 277 278Do not email netdev maintainers directly if you think you discovered 279a bug that might have possible security implications. 280The current netdev maintainer has consistently requested that 281people use the mailing lists and not reach out directly. If you aren't 282OK with that, then perhaps consider mailing security@kernel.org or 283reading about http://oss-security.openwall.org/wiki/mailing-lists/distros 284as possible alternative mechanisms. 285 286 287Co-posting changes to user space components 288~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 289 290User space code exercising kernel features should be posted 291alongside kernel patches. This gives reviewers a chance to see 292how any new interface is used and how well it works. 293 294When user space tools reside in the kernel repo itself all changes 295should generally come as one series. If series becomes too large 296or the user space project is not reviewed on netdev include a link 297to a public repo where user space patches can be seen. 298 299In case user space tooling lives in a separate repository but is 300reviewed on netdev (e.g. patches to ``iproute2`` tools) kernel and 301user space patches should form separate series (threads) when posted 302to the mailing list, e.g.:: 303 304 [PATCH net-next 0/3] net: some feature cover letter 305 └─ [PATCH net-next 1/3] net: some feature prep 306 └─ [PATCH net-next 2/3] net: some feature do it 307 └─ [PATCH net-next 3/3] selftest: net: some feature 308 309 [PATCH iproute2-next] ip: add support for some feature 310 311Posting as one thread is discouraged because it confuses patchwork 312(as of patchwork 2.2.2). 313 314Co-posting selftests 315-------------------- 316 317Selftests should be part of the same series as the code changes. 318Specifically for fixes both code change and related test should go into 319the same tree (the tests may lack a Fixes tag, which is expected). 320Mixing code changes and test changes in a single commit is discouraged. 321 322Preparing changes 323----------------- 324 325Attention to detail is important. Re-read your own work as if you were the 326reviewer. You can start with using ``checkpatch.pl``, perhaps even with 327the ``--strict`` flag. But do not be mindlessly robotic in doing so. 328If your change is a bug fix, make sure your commit log indicates the 329end-user visible symptom, the underlying reason as to why it happens, 330and then if necessary, explain why the fix proposed is the best way to 331get things done. Don't mangle whitespace, and as is common, don't 332mis-indent function arguments that span multiple lines. If it is your 333first patch, mail it to yourself so you can test apply it to an 334unpatched tree to confirm infrastructure didn't mangle it. 335 336Finally, go back and read 337:ref:`Documentation/process/submitting-patches.rst <submittingpatches>` 338to be sure you are not repeating some common mistake documented there. 339 340Indicating target tree 341~~~~~~~~~~~~~~~~~~~~~~ 342 343To help maintainers and CI bots you should explicitly mark which tree 344your patch is targeting. Assuming that you use git, use the prefix 345flag:: 346 347 git format-patch --subject-prefix='PATCH net-next' start..finish 348 349Use ``net`` instead of ``net-next`` (always lower case) in the above for 350bug-fix ``net`` content. 351 352Dividing work into patches 353~~~~~~~~~~~~~~~~~~~~~~~~~~ 354 355Put yourself in the shoes of the reviewer. Each patch is read separately 356and therefore should constitute a comprehensible step towards your stated 357goal. 358 359Avoid sending series longer than 15 patches. Larger series takes longer 360to review as reviewers will defer looking at it until they find a large 361chunk of time. A small series can be reviewed in a short time, so Maintainers 362just do it. As a result, a sequence of smaller series gets merged quicker and 363with better review coverage. Re-posting large series also increases the mailing 364list traffic. 365 366.. _rcs: 367 368Local variable ordering ("reverse xmas tree", "RCS") 369~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 370 371Netdev has a convention for ordering local variables in functions. 372Order the variable declaration lines longest to shortest, e.g.:: 373 374 struct scatterlist *sg; 375 struct sk_buff *skb; 376 int err, i; 377 378If there are dependencies between the variables preventing the ordering 379move the initialization out of line. 380 381Format precedence 382~~~~~~~~~~~~~~~~~ 383 384When working in existing code which uses nonstandard formatting make 385your code follow the most recent guidelines, so that eventually all code 386in the domain of netdev is in the preferred format. 387 388Using device-managed and cleanup.h constructs 389~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 390 391Netdev remains skeptical about promises of all "auto-cleanup" APIs, 392including even ``devm_`` helpers, historically. They are not the preferred 393style of implementation, merely an acceptable one. 394 395Use of ``guard()`` is discouraged within any function longer than 20 lines, 396``scoped_guard()`` is considered more readable. Using normal lock/unlock is 397still (weakly) preferred. 398 399Low level cleanup constructs (such as ``__free()``) can be used when building 400APIs and helpers, especially scoped iterators. However, direct use of 401``__free()`` within networking core and drivers is discouraged. 402Similar guidance applies to declaring variables mid-function. 403 404Clean-up patches 405~~~~~~~~~~~~~~~~ 406 407Netdev discourages patches which perform simple clean-ups, which are not in 408the context of other work. For example: 409 410* Addressing ``checkpatch.pl`` warnings 411* Addressing :ref:`Local variable ordering<rcs>` issues 412* Conversions to device-managed APIs (``devm_`` helpers) 413 414This is because it is felt that the churn that such changes produce comes 415at a greater cost than the value of such clean-ups. 416 417Conversely, spelling and grammar fixes are not discouraged. 418 419Resending after review 420~~~~~~~~~~~~~~~~~~~~~~ 421 422Allow at least 24 hours to pass between postings. This will ensure reviewers 423from all geographical locations have a chance to chime in. Do not wait 424too long (weeks) between postings either as it will make it harder for reviewers 425to recall all the context. 426 427Make sure you address all the feedback in your new posting. Do not post a new 428version of the code if the discussion about the previous version is still 429ongoing, unless directly instructed by a reviewer. 430 431The new version of patches should be posted as a separate thread, 432not as a reply to the previous posting. Change log should include a link 433to the previous posting (see :ref:`Changes requested`). 434 435Testing 436------- 437 438Expected level of testing 439~~~~~~~~~~~~~~~~~~~~~~~~~ 440 441At the very minimum your changes must survive an ``allyesconfig`` and an 442``allmodconfig`` build with ``W=1`` set without new warnings or failures. 443 444Ideally you will have done run-time testing specific to your change, 445and the patch series contains a set of kernel selftest for 446``tools/testing/selftests/net`` or using the KUnit framework. 447 448You are expected to test your changes on top of the relevant networking 449tree (``net`` or ``net-next``) and not e.g. a stable tree or ``linux-next``. 450 451patchwork checks 452~~~~~~~~~~~~~~~~ 453 454Checks in patchwork are mostly simple wrappers around existing kernel 455scripts, the sources are available at: 456 457https://github.com/linux-netdev/nipa/tree/master/tests 458 459**Do not** post your patches just to run them through the checks. 460You must ensure that your patches are ready by testing them locally 461before posting to the mailing list. The patchwork build bot instance 462gets overloaded very easily and netdev@vger really doesn't need more 463traffic if we can help it. 464 465netdevsim 466~~~~~~~~~ 467 468``netdevsim`` is a test driver which can be used to exercise driver 469configuration APIs without requiring capable hardware. 470Mock-ups and tests based on ``netdevsim`` are strongly encouraged when 471adding new APIs, but ``netdevsim`` in itself is **not** considered 472a use case/user. You must also implement the new APIs in a real driver. 473 474We give no guarantees that ``netdevsim`` won't change in the future 475in a way which would break what would normally be considered uAPI. 476 477``netdevsim`` is reserved for use by upstream tests only, so any 478new ``netdevsim`` features must be accompanied by selftests under 479``tools/testing/selftests/``. 480 481Supported status for drivers 482---------------------------- 483 484.. note: The following requirements apply only to Ethernet NIC drivers. 485 486Netdev defines additional requirements for drivers which want to acquire 487the ``Supported`` status in the MAINTAINERS file. ``Supported`` drivers must 488be running all upstream driver tests and reporting the results twice a day. 489Drivers which do not comply with this requirement should use the ``Maintained`` 490status. There is currently no difference in how ``Supported`` and ``Maintained`` 491drivers are treated upstream. 492 493The exact rules a driver must follow to acquire the ``Supported`` status: 494 4951. Must run all tests under ``drivers/net`` and ``drivers/net/hw`` targets 496 of Linux selftests. Running and reporting private / internal tests is 497 also welcome, but upstream tests are a must. 498 4992. The minimum run frequency is once every 12 hours. Must test the 500 designated branch from the selected branch feed. Note that branches 501 are auto-constructed and exposed to intentional malicious patch posting, 502 so the test systems must be isolated. 503 5043. Drivers supporting multiple generations of devices must test at 505 least one device from each generation. A testbed manifest (exact 506 format TBD) should describe the device models tested. 507 5084. The tests must run reliably, if multiple branches are skipped or tests 509 are failing due to execution environment problems the ``Supported`` 510 status will be withdrawn. 511 5125. Test failures due to bugs either in the driver or the test itself, 513 or lack of support for the feature the test is targgeting are 514 *not* a basis for losing the ``Supported`` status. 515 516netdev CI will maintain an official page of supported devices, listing their 517recent test results. 518 519The driver maintainer may arrange for someone else to run the test, 520there is no requirement for the person listed as maintainer (or their 521employer) to be responsible for running the tests. Collaboration between 522vendors, hosting GH CI, other repos under linux-netdev, etc. is most welcome. 523 524See https://github.com/linux-netdev/nipa/wiki for more information about 525netdev CI. Feel free to reach out to maintainers or the list with any questions. 526 527Reviewer guidance 528----------------- 529 530Reviewing other people's patches on the list is highly encouraged, 531regardless of the level of expertise. For general guidance and 532helpful tips please see :ref:`development_advancedtopics_reviews`. 533 534It's safe to assume that netdev maintainers know the community and the level 535of expertise of the reviewers. The reviewers should not be concerned about 536their comments impeding or derailing the patch flow. 537 538Less experienced reviewers are highly encouraged to do more in-depth 539review of submissions and not focus exclusively on trivial or subjective 540matters like code formatting, tags etc. 541 542Testimonials / feedback 543----------------------- 544 545Some companies use peer feedback in employee performance reviews. 546Please feel free to request feedback from netdev maintainers, 547especially if you spend significant amount of time reviewing code 548and go out of your way to improve shared infrastructure. 549 550The feedback must be requested by you, the contributor, and will always 551be shared with you (even if you request for it to be submitted to your 552manager). 553