Commit 5c050fb9 authored by Jonathan Corbet's avatar Jonathan Corbet

docs: update the development process document

Here's a set of changes updating Documentation/development-process.  I have
update kernel releases and relevant statistics, added information for a
couple of tools, zapped some trailing white space, and generally tried to
make it more closely match the current state of affairs.

[Typo fixes from Joe Perches and Nicolas Kaiser incorporated]
Signed-off-by: default avatarJonathan Corbet <corbet@lwn.net>
Acked-by: default avatarGreg KH <greg@kroah.com>
Cc: Randy Dunlap <rdunlap@xenotime.net>
parent 9cad7962
...@@ -56,13 +56,13 @@ information on kernel development. ...@@ -56,13 +56,13 @@ information on kernel development.
1.2: WHAT THIS DOCUMENT IS ABOUT 1.2: WHAT THIS DOCUMENT IS ABOUT
The Linux kernel, at over 6 million lines of code and well over 1000 active The Linux kernel, at over 8 million lines of code and well over 1000
contributors, is one of the largest and most active free software projects contributors to each release, is one of the largest and most active free
in existence. Since its humble beginning in 1991, this kernel has evolved software projects in existence. Since its humble beginning in 1991, this
into a best-of-breed operating system component which runs on pocket-sized kernel has evolved into a best-of-breed operating system component which
digital music players, desktop PCs, the largest supercomputers in runs on pocket-sized digital music players, desktop PCs, the largest
existence, and all types of systems in between. It is a robust, efficient, supercomputers in existence, and all types of systems in between. It is a
and scalable solution for almost any situation. robust, efficient, and scalable solution for almost any situation.
With the growth of Linux has come an increase in the number of developers With the growth of Linux has come an increase in the number of developers
(and companies) wishing to participate in its development. Hardware (and companies) wishing to participate in its development. Hardware
...@@ -115,7 +115,7 @@ This document was written by Jonathan Corbet, corbet@lwn.net. It has been ...@@ -115,7 +115,7 @@ This document was written by Jonathan Corbet, corbet@lwn.net. It has been
improved by comments from Johannes Berg, James Berry, Alex Chiang, Roland improved by comments from Johannes Berg, James Berry, Alex Chiang, Roland
Dreier, Randy Dunlap, Jake Edge, Jiri Kosina, Matt Mackall, Arthur Marsh, Dreier, Randy Dunlap, Jake Edge, Jiri Kosina, Matt Mackall, Arthur Marsh,
Amanda McPherson, Andrew Morton, Andrew Price, Tsugikazu Shibata, and Amanda McPherson, Andrew Morton, Andrew Price, Tsugikazu Shibata, and
Jochen Voß. Jochen Voß.
This work was supported by the Linux Foundation; thanks especially to This work was supported by the Linux Foundation; thanks especially to
Amanda McPherson, who saw the value of this effort and made it all happen. Amanda McPherson, who saw the value of this effort and made it all happen.
...@@ -221,7 +221,7 @@ include: ...@@ -221,7 +221,7 @@ include:
- Everything that was said above about code review applies doubly to - Everything that was said above about code review applies doubly to
closed-source code. Since this code is not available at all, it cannot closed-source code. Since this code is not available at all, it cannot
have been reviewed by the community and will, beyond doubt, have serious have been reviewed by the community and will, beyond doubt, have serious
problems. problems.
Makers of embedded systems, in particular, may be tempted to disregard much Makers of embedded systems, in particular, may be tempted to disregard much
of what has been said in this section in the belief that they are shipping of what has been said in this section in the belief that they are shipping
......
...@@ -14,16 +14,15 @@ The kernel developers use a loosely time-based release process, with a new ...@@ -14,16 +14,15 @@ The kernel developers use a loosely time-based release process, with a new
major kernel release happening every two or three months. The recent major kernel release happening every two or three months. The recent
release history looks like this: release history looks like this:
2.6.26 July 13, 2008 2.6.38 March 14, 2011
2.6.25 April 16, 2008 2.6.37 January 4, 2011
2.6.24 January 24, 2008 2.6.36 October 20, 2010
2.6.23 October 9, 2007 2.6.35 August 1, 2010
2.6.22 July 8, 2007 2.6.34 May 15, 2010
2.6.21 April 25, 2007 2.6.33 February 24, 2010
2.6.20 February 4, 2007
Every 2.6.x release is a major kernel release with new features, internal Every 2.6.x release is a major kernel release with new features, internal
API changes, and more. A typical 2.6 release can contain over 10,000 API changes, and more. A typical 2.6 release can contain nearly 10,000
changesets with changes to several hundred thousand lines of code. 2.6 is changesets with changes to several hundred thousand lines of code. 2.6 is
thus the leading edge of Linux kernel development; the kernel uses a thus the leading edge of Linux kernel development; the kernel uses a
rolling development model which is continually integrating major changes. rolling development model which is continually integrating major changes.
...@@ -42,13 +41,13 @@ merge window do not come out of thin air; they have been collected, tested, ...@@ -42,13 +41,13 @@ merge window do not come out of thin air; they have been collected, tested,
and staged ahead of time. How that process works will be described in and staged ahead of time. How that process works will be described in
detail later on). detail later on).
The merge window lasts for two weeks. At the end of this time, Linus The merge window lasts for approximately two weeks. At the end of this
Torvalds will declare that the window is closed and release the first of time, Linus Torvalds will declare that the window is closed and release the
the "rc" kernels. For the kernel which is destined to be 2.6.26, for first of the "rc" kernels. For the kernel which is destined to be 2.6.40,
example, the release which happens at the end of the merge window will be for example, the release which happens at the end of the merge window will
called 2.6.26-rc1. The -rc1 release is the signal that the time to merge be called 2.6.40-rc1. The -rc1 release is the signal that the time to
new features has passed, and that the time to stabilize the next kernel has merge new features has passed, and that the time to stabilize the next
begun. kernel has begun.
Over the next six to ten weeks, only patches which fix problems should be Over the next six to ten weeks, only patches which fix problems should be
submitted to the mainline. On occasion a more significant change will be submitted to the mainline. On occasion a more significant change will be
...@@ -66,20 +65,19 @@ will get up to somewhere between -rc6 and -rc9 before the kernel is ...@@ -66,20 +65,19 @@ will get up to somewhere between -rc6 and -rc9 before the kernel is
considered to be sufficiently stable and the final 2.6.x release is made. considered to be sufficiently stable and the final 2.6.x release is made.
At that point the whole process starts over again. At that point the whole process starts over again.
As an example, here is how the 2.6.25 development cycle went (all dates in As an example, here is how the 2.6.38 development cycle went (all dates in
2008): 2011):
January 24 2.6.24 stable release January 4 2.6.37 stable release
February 10 2.6.25-rc1, merge window closes January 18 2.6.38-rc1, merge window closes
February 15 2.6.25-rc2 January 21 2.6.38-rc2
February 24 2.6.25-rc3 February 1 2.6.38-rc3
March 4 2.6.25-rc4 February 7 2.6.38-rc4
March 9 2.6.25-rc5 February 15 2.6.38-rc5
March 16 2.6.25-rc6 February 21 2.6.38-rc6
March 25 2.6.25-rc7 March 1 2.6.38-rc7
April 1 2.6.25-rc8 March 7 2.6.38-rc8
April 11 2.6.25-rc9 March 14 2.6.38 stable release
April 16 2.6.25 stable release
How do the developers decide when to close the development cycle and create How do the developers decide when to close the development cycle and create
the stable release? The most significant metric used is the list of the stable release? The most significant metric used is the list of
...@@ -87,7 +85,7 @@ regressions from previous releases. No bugs are welcome, but those which ...@@ -87,7 +85,7 @@ regressions from previous releases. No bugs are welcome, but those which
break systems which worked in the past are considered to be especially break systems which worked in the past are considered to be especially
serious. For this reason, patches which cause regressions are looked upon serious. For this reason, patches which cause regressions are looked upon
unfavorably and are quite likely to be reverted during the stabilization unfavorably and are quite likely to be reverted during the stabilization
period. period.
The developers' goal is to fix all known regressions before the stable The developers' goal is to fix all known regressions before the stable
release is made. In the real world, this kind of perfection is hard to release is made. In the real world, this kind of perfection is hard to
...@@ -99,26 +97,34 @@ kernels go out with a handful of known regressions though, hopefully, none ...@@ -99,26 +97,34 @@ kernels go out with a handful of known regressions though, hopefully, none
of them are serious. of them are serious.
Once a stable release is made, its ongoing maintenance is passed off to the Once a stable release is made, its ongoing maintenance is passed off to the
"stable team," currently comprised of Greg Kroah-Hartman and Chris Wright. "stable team," currently consisting of Greg Kroah-Hartman. The stable team
The stable team will release occasional updates to the stable release using will release occasional updates to the stable release using the 2.6.x.y
the 2.6.x.y numbering scheme. To be considered for an update release, a numbering scheme. To be considered for an update release, a patch must (1)
patch must (1) fix a significant bug, and (2) already be merged into the fix a significant bug, and (2) already be merged into the mainline for the
mainline for the next development kernel. Continuing our 2.6.25 example, next development kernel. Kernels will typically receive stable updates for
the history (as of this writing) is: a little more than one development cycle past their initial release. So,
for example, the 2.6.36 kernel's history looked like:
May 1 2.6.25.1
May 6 2.6.25.2 October 10 2.6.36 stable release
May 9 2.6.25.3 November 22 2.6.36.1
May 15 2.6.25.4 December 9 2.6.36.2
June 7 2.6.25.5 January 7 2.6.36.3
June 9 2.6.25.6 February 17 2.6.36.4
June 16 2.6.25.7
June 21 2.6.25.8 2.6.36.4 was the final stable update for the 2.6.36 release.
June 24 2.6.25.9
Some kernels are designated "long term" kernels; they will receive support
Stable updates for a given kernel are made for approximately six months; for a longer period. As of this writing, the current long term kernels
after that, the maintenance of stable releases is solely the responsibility and their maintainers are:
of the distributors which have shipped that particular kernel.
2.6.27 Willy Tarreau (Deep-frozen stable kernel)
2.6.32 Greg Kroah-Hartman
2.6.35 Andi Kleen (Embedded flag kernel)
The selection of a kernel for long-term support is purely a matter of a
maintainer having the need and the time to maintain that release. There
are no known plans for long-term support for any specific upcoming
release.
2.2: THE LIFECYCLE OF A PATCH 2.2: THE LIFECYCLE OF A PATCH
...@@ -130,7 +136,7 @@ each patch implements a change which is desirable to have in the mainline. ...@@ -130,7 +136,7 @@ each patch implements a change which is desirable to have in the mainline.
This process can happen quickly for minor fixes, or, in the case of large This process can happen quickly for minor fixes, or, in the case of large
and controversial changes, go on for years. Much developer frustration and controversial changes, go on for years. Much developer frustration
comes from a lack of understanding of this process or from attempts to comes from a lack of understanding of this process or from attempts to
circumvent it. circumvent it.
In the hopes of reducing that frustration, this document will describe how In the hopes of reducing that frustration, this document will describe how
a patch gets into the kernel. What follows below is an introduction which a patch gets into the kernel. What follows below is an introduction which
...@@ -193,8 +199,8 @@ involved. ...@@ -193,8 +199,8 @@ involved.
2.3: HOW PATCHES GET INTO THE KERNEL 2.3: HOW PATCHES GET INTO THE KERNEL
There is exactly one person who can merge patches into the mainline kernel There is exactly one person who can merge patches into the mainline kernel
repository: Linus Torvalds. But, of the over 12,000 patches which went repository: Linus Torvalds. But, of the over 9,500 patches which went
into the 2.6.25 kernel, only 250 (around 2%) were directly chosen by Linus into the 2.6.38 kernel, only 112 (around 1.3%) were directly chosen by Linus
himself. The kernel project has long since grown to a size where no single himself. The kernel project has long since grown to a size where no single
developer could possibly inspect and select every patch unassisted. The developer could possibly inspect and select every patch unassisted. The
way the kernel developers have addressed this growth is through the use of way the kernel developers have addressed this growth is through the use of
...@@ -229,7 +235,7 @@ first in trees dedicated to network device drivers, wireless networking, ...@@ -229,7 +235,7 @@ first in trees dedicated to network device drivers, wireless networking,
etc. This chain of repositories can be arbitrarily long, though it rarely etc. This chain of repositories can be arbitrarily long, though it rarely
exceeds two or three links. Since each maintainer in the chain trusts exceeds two or three links. Since each maintainer in the chain trusts
those managing lower-level trees, this process is known as the "chain of those managing lower-level trees, this process is known as the "chain of
trust." trust."
Clearly, in a system like this, getting patches into the kernel depends on Clearly, in a system like this, getting patches into the kernel depends on
finding the right maintainer. Sending patches directly to Linus is not finding the right maintainer. Sending patches directly to Linus is not
...@@ -254,7 +260,7 @@ The answer comes in the form of -next trees, where subsystem trees are ...@@ -254,7 +260,7 @@ The answer comes in the form of -next trees, where subsystem trees are
collected for testing and review. The older of these trees, maintained by collected for testing and review. The older of these trees, maintained by
Andrew Morton, is called "-mm" (for memory management, which is how it got Andrew Morton, is called "-mm" (for memory management, which is how it got
started). The -mm tree integrates patches from a long list of subsystem started). The -mm tree integrates patches from a long list of subsystem
trees; it also has some patches aimed at helping with debugging. trees; it also has some patches aimed at helping with debugging.
Beyond that, -mm contains a significant collection of patches which have Beyond that, -mm contains a significant collection of patches which have
been selected by Andrew directly. These patches may have been posted on a been selected by Andrew directly. These patches may have been posted on a
...@@ -264,8 +270,8 @@ subsystem tree of last resort; if there is no other obvious path for a ...@@ -264,8 +270,8 @@ subsystem tree of last resort; if there is no other obvious path for a
patch into the mainline, it is likely to end up in -mm. Miscellaneous patch into the mainline, it is likely to end up in -mm. Miscellaneous
patches which accumulate in -mm will eventually either be forwarded on to patches which accumulate in -mm will eventually either be forwarded on to
an appropriate subsystem tree or be sent directly to Linus. In a typical an appropriate subsystem tree or be sent directly to Linus. In a typical
development cycle, approximately 10% of the patches going into the mainline development cycle, approximately 5-10% of the patches going into the
get there via -mm. mainline get there via -mm.
The current -mm patch is available in the "mmotm" (-mm of the moment) The current -mm patch is available in the "mmotm" (-mm of the moment)
directory at: directory at:
...@@ -275,7 +281,7 @@ directory at: ...@@ -275,7 +281,7 @@ directory at:
Use of the MMOTM tree is likely to be a frustrating experience, though; Use of the MMOTM tree is likely to be a frustrating experience, though;
there is a definite chance that it will not even compile. there is a definite chance that it will not even compile.
The other -next tree, started more recently, is linux-next, maintained by The primary tree for next-cycle patch merging is linux-next, maintained by
Stephen Rothwell. The linux-next tree is, by design, a snapshot of what Stephen Rothwell. The linux-next tree is, by design, a snapshot of what
the mainline is expected to look like after the next merge window closes. the mainline is expected to look like after the next merge window closes.
Linux-next trees are announced on the linux-kernel and linux-next mailing Linux-next trees are announced on the linux-kernel and linux-next mailing
...@@ -287,25 +293,14 @@ Some information about linux-next has been gathered at: ...@@ -287,25 +293,14 @@ Some information about linux-next has been gathered at:
http://linux.f-seidel.de/linux-next/pmwiki/ http://linux.f-seidel.de/linux-next/pmwiki/
How the linux-next tree will fit into the development process is still Linux-next has become an integral part of the kernel development process;
changing. As of this writing, the first full development cycle involving all patches merged during a given merge window should really have found
linux-next (2.6.26) is coming to an end; thus far, it has proved to be a their way into linux-next some time before the merge window opens.
valuable resource for finding and fixing integration problems before the
beginning of the merge window. See http://lwn.net/Articles/287155/ for
more information on how linux-next has worked to set up the 2.6.27 merge
window.
Some developers have begun to suggest that linux-next should be used as the
target for future development as well. The linux-next tree does tend to be
far ahead of the mainline and is more representative of the tree into which
any new work will be merged. The downside to this idea is that the
volatility of linux-next tends to make it a difficult development target.
See http://lwn.net/Articles/289013/ for more information on this topic, and
stay tuned; much is still in flux where linux-next is involved.
2.4.1: STAGING TREES 2.4.1: STAGING TREES
The kernel source tree now contains the drivers/staging/ directory, where The kernel source tree contains the drivers/staging/ directory, where
many sub-directories for drivers or filesystems that are on their way to many sub-directories for drivers or filesystems that are on their way to
being added to the kernel tree live. They remain in drivers/staging while being added to the kernel tree live. They remain in drivers/staging while
they still need more work; once complete, they can be moved into the they still need more work; once complete, they can be moved into the
...@@ -313,15 +308,23 @@ kernel proper. This is a way to keep track of drivers that aren't ...@@ -313,15 +308,23 @@ kernel proper. This is a way to keep track of drivers that aren't
up to Linux kernel coding or quality standards, but people may want to use up to Linux kernel coding or quality standards, but people may want to use
them and track development. them and track development.
Greg Kroah-Hartman currently (as of 2.6.36) maintains the staging tree. Greg Kroah-Hartman currently maintains the staging tree. Drivers that
Drivers that still need work are sent to him, with each driver having still need work are sent to him, with each driver having its own
its own subdirectory in drivers/staging/. Along with the driver source subdirectory in drivers/staging/. Along with the driver source files, a
files, a TODO file should be present in the directory as well. The TODO TODO file should be present in the directory as well. The TODO file lists
file lists the pending work that the driver needs for acceptance into the pending work that the driver needs for acceptance into the kernel
the kernel proper, as well as a list of people that should be Cc'd for any proper, as well as a list of people that should be Cc'd for any patches to
patches to the driver. Staging drivers that don't currently build should the driver. Current rules require that drivers contributed to staging
have their config entries depend upon CONFIG_BROKEN. Once they can must, at a minimum, compile properly.
be successfully built without outside patches, CONFIG_BROKEN can be removed.
Staging can be a relatively easy way to get new drivers into the mainline
where, with luck, they will come to the attention of other developers and
improve quickly. Entry into staging is not the end of the story, though;
code in staging which is not seeing regular progress will eventually be
removed. Distributors also tend to be relatively reluctant to enable
staging drivers. So staging is, at best, a stop on the way toward becoming
a proper mainline driver.
2.5: TOOLS 2.5: TOOLS
...@@ -347,11 +350,7 @@ page at: ...@@ -347,11 +350,7 @@ page at:
http://git-scm.com/ http://git-scm.com/
That page has pointers to documentation and tutorials. One should be That page has pointers to documentation and tutorials.
aware, in particular, of the Kernel Hacker's Guide to git, which has
information specific to kernel development:
http://linux.yyz.us/git-howto.html
Among the kernel developers who do not use git, the most popular choice is Among the kernel developers who do not use git, the most popular choice is
almost certainly Mercurial: almost certainly Mercurial:
...@@ -408,7 +407,7 @@ There are a few hints which can help with linux-kernel survival: ...@@ -408,7 +407,7 @@ There are a few hints which can help with linux-kernel survival:
important to filter on both the topic of interest (though note that important to filter on both the topic of interest (though note that
long-running conversations can drift away from the original subject long-running conversations can drift away from the original subject
without changing the email subject line) and the people who are without changing the email subject line) and the people who are
participating. participating.
- Do not feed the trolls. If somebody is trying to stir up an angry - Do not feed the trolls. If somebody is trying to stir up an angry
response, ignore them. response, ignore them.
......
...@@ -110,8 +110,8 @@ the kernel community's standards. Some examples include: ...@@ -110,8 +110,8 @@ the kernel community's standards. Some examples include:
- The AppArmor security module made use of internal virtual filesystem - The AppArmor security module made use of internal virtual filesystem
data structures in ways which were considered to be unsafe and data structures in ways which were considered to be unsafe and
unreliable. This code has since been significantly reworked, but unreliable. This concern (among others) kept AppArmor out of the
remains outside of the mainline. mainline for years.
In each of these cases, a great deal of pain and extra work could have been In each of these cases, a great deal of pain and extra work could have been
avoided with some early discussion with the kernel developers. avoided with some early discussion with the kernel developers.
...@@ -138,6 +138,19 @@ patches, and who, if anybody, is attaching Signed-off-by lines to those ...@@ -138,6 +138,19 @@ patches, and who, if anybody, is attaching Signed-off-by lines to those
patches. Those are the people who will be best placed to help with a new patches. Those are the people who will be best placed to help with a new
development project. development project.
The task of finding the right maintainer is sometimes challenging enough
that the kernel developers have added a script to ease the process:
.../scripts/get_maintainer.pl
This script will return the current maintainer(s) for a given file or
directory when given the "-f" option. If passed a patch on the
command line, it will list the maintainers who should probably receive
copies of the patch. There are a number of options regulating how hard
get_maintainer.pl will search for maintainers; please be careful about
using the more aggressive options as you may end up including developers
who have no real interest in the code you are modifying.
If all else fails, talking to Andrew Morton can be an effective way to If all else fails, talking to Andrew Morton can be an effective way to
track down a maintainer for a specific piece of code. track down a maintainer for a specific piece of code.
...@@ -155,11 +168,15 @@ reaction, but, instead, little or no reaction at all. The sad truth of the ...@@ -155,11 +168,15 @@ reaction, but, instead, little or no reaction at all. The sad truth of the
matter is (1) kernel developers tend to be busy, (2) there is no shortage matter is (1) kernel developers tend to be busy, (2) there is no shortage
of people with grand plans and little code (or even prospect of code) to of people with grand plans and little code (or even prospect of code) to
back them up, and (3) nobody is obligated to review or comment on ideas back them up, and (3) nobody is obligated to review or comment on ideas
posted by others. If a request-for-comments posting yields little in the posted by others. Beyond that, high-level designs often hide problems
way of comments, do not assume that it means there is no interest in the which are only reviewed when somebody actually tries to implement those
project. Unfortunately, you also cannot assume that there are no problems designs; for that reason, kernel developers would rather see the code.
with your idea. The best thing to do in this situation is to proceed,
keeping the community informed as you go. If a request-for-comments posting yields little in the way of comments, do
not assume that it means there is no interest in the project.
Unfortunately, you also cannot assume that there are no problems with your
idea. The best thing to do in this situation is to proceed, keeping the
community informed as you go.
3.5: GETTING OFFICIAL BUY-IN 3.5: GETTING OFFICIAL BUY-IN
......
...@@ -131,6 +131,11 @@ classic time/space tradeoff taught in beginning data structures classes ...@@ -131,6 +131,11 @@ classic time/space tradeoff taught in beginning data structures classes
often does not apply to contemporary hardware. Space *is* time, in that a often does not apply to contemporary hardware. Space *is* time, in that a
larger program will run slower than one which is more compact. larger program will run slower than one which is more compact.
More recent compilers take an increasingly active role in deciding whether
a given function should actually be inlined or not. So the liberal
placement of "inline" keywords may not just be excessive; it could also be
irrelevant.
* Locking * Locking
...@@ -285,6 +290,13 @@ be found at https://sparse.wiki.kernel.org/index.php/Main_Page if your ...@@ -285,6 +290,13 @@ be found at https://sparse.wiki.kernel.org/index.php/Main_Page if your
distributor does not package it); it can then be run on the code by adding distributor does not package it); it can then be run on the code by adding
"C=1" to your make command. "C=1" to your make command.
The "Coccinelle" tool (http://coccinelle.lip6.fr/) is able to find a wide
variety of potential coding problems; it can also propose fixes for those
problems. Quite a few "semantic patches" for the kernel have been packaged
under the scripts/coccinelle directory; running "make coccicheck" will run
through those semantic patches and report on any problems found. See
Documentation/coccinelle.txt for more information.
Other kinds of portability errors are best found by compiling your code for Other kinds of portability errors are best found by compiling your code for
other architectures. If you do not happen to have an S/390 system or a other architectures. If you do not happen to have an S/390 system or a
Blackfin development board handy, you can still perform the compilation Blackfin development board handy, you can still perform the compilation
...@@ -308,7 +320,9 @@ The first piece of documentation for any patch is its associated ...@@ -308,7 +320,9 @@ The first piece of documentation for any patch is its associated
changelog. Log entries should describe the problem being solved, the form changelog. Log entries should describe the problem being solved, the form
of the solution, the people who worked on the patch, any relevant of the solution, the people who worked on the patch, any relevant
effects on performance, and anything else that might be needed to effects on performance, and anything else that might be needed to
understand the patch. understand the patch. Be sure that the changelog says *why* the patch is
worth applying; a surprising number of developers fail to provide that
information.
Any code which adds a new user-space interface - including new sysfs or Any code which adds a new user-space interface - including new sysfs or
/proc files - should include documentation of that interface which enables /proc files - should include documentation of that interface which enables
...@@ -321,7 +335,7 @@ boot-time parameters. Any patch which adds new parameters should add the ...@@ -321,7 +335,7 @@ boot-time parameters. Any patch which adds new parameters should add the
appropriate entries to this file. appropriate entries to this file.
Any new configuration options must be accompanied by help text which Any new configuration options must be accompanied by help text which
clearly explains the options and when the user might want to select them. clearly explains the options and when the user might want to select them.
Internal API information for many subsystems is documented by way of Internal API information for many subsystems is documented by way of
specially-formatted comments; these comments can be extracted and formatted specially-formatted comments; these comments can be extracted and formatted
...@@ -372,7 +386,8 @@ which is broken by the change. For a widely-used function, this duty can ...@@ -372,7 +386,8 @@ which is broken by the change. For a widely-used function, this duty can
lead to literally hundreds or thousands of changes - many of which are lead to literally hundreds or thousands of changes - many of which are
likely to conflict with work being done by other developers. Needless to likely to conflict with work being done by other developers. Needless to
say, this can be a large job, so it is best to be sure that the say, this can be a large job, so it is best to be sure that the
justification is solid. justification is solid. Note that the Coccinelle tool can help with
wide-ranging API changes.
When making an incompatible API change, one should, whenever possible, When making an incompatible API change, one should, whenever possible,
ensure that code which has not been updated is caught by the compiler. ensure that code which has not been updated is caught by the compiler.
......
...@@ -60,12 +60,15 @@ even in the short term. ...@@ -60,12 +60,15 @@ even in the short term.
Patches must be prepared against a specific version of the kernel. As a Patches must be prepared against a specific version of the kernel. As a
general rule, a patch should be based on the current mainline as found in general rule, a patch should be based on the current mainline as found in
Linus's git tree. It may become necessary to make versions against -mm, Linus's git tree. When basing on mainline, start with a well-known release
linux-next, or a subsystem tree, though, to facilitate wider testing and point - a stable or -rc release - rather than branching off the mainline at
review. Depending on the area of your patch and what is going on an arbitrary spot.
elsewhere, basing a patch against these other trees can require a
significant amount of work resolving conflicts and dealing with API It may become necessary to make versions against -mm, linux-next, or a
changes. subsystem tree, though, to facilitate wider testing and review. Depending
on the area of your patch and what is going on elsewhere, basing a patch
against these other trees can require a significant amount of work
resolving conflicts and dealing with API changes.
Only the most simple changes should be formatted as a single patch; Only the most simple changes should be formatted as a single patch;
everything else should be made as a logical series of changes. Splitting everything else should be made as a logical series of changes. Splitting
...@@ -100,11 +103,11 @@ rules of thumb, however, which can help considerably: ...@@ -100,11 +103,11 @@ rules of thumb, however, which can help considerably:
result is a broken kernel, you will make life harder for developers and result is a broken kernel, you will make life harder for developers and
users who are engaging in the noble work of tracking down problems. users who are engaging in the noble work of tracking down problems.
- Do not overdo it, though. One developer recently posted a set of edits - Do not overdo it, though. One developer once posted a set of edits
to a single file as 500 separate patches - an act which did not make him to a single file as 500 separate patches - an act which did not make him
the most popular person on the kernel mailing list. A single patch can the most popular person on the kernel mailing list. A single patch can
be reasonably large as long as it still contains a single *logical* be reasonably large as long as it still contains a single *logical*
change. change.
- It can be tempting to add a whole new infrastructure with a series of - It can be tempting to add a whole new infrastructure with a series of
patches, but to leave that infrastructure unused until the final patch patches, but to leave that infrastructure unused until the final patch
...@@ -162,7 +165,8 @@ To that end, the summary line should describe the effects of and motivation ...@@ -162,7 +165,8 @@ To that end, the summary line should describe the effects of and motivation
for the change as well as possible given the one-line constraint. The for the change as well as possible given the one-line constraint. The
detailed description can then amplify on those topics and provide any detailed description can then amplify on those topics and provide any
needed additional information. If the patch fixes a bug, cite the commit needed additional information. If the patch fixes a bug, cite the commit
which introduced the bug if possible. If a problem is associated with which introduced the bug if possible (and please provide both the commit ID
and the title when citing commits). If a problem is associated with
specific log or compiler output, include that output to help others specific log or compiler output, include that output to help others
searching for a solution to the same problem. If the change is meant to searching for a solution to the same problem. If the change is meant to
support other changes coming in later patch, say so. If internal APIs are support other changes coming in later patch, say so. If internal APIs are
...@@ -230,7 +234,7 @@ take care of: ...@@ -230,7 +234,7 @@ take care of:
which have had gratuitous white-space changes or line wrapping performed which have had gratuitous white-space changes or line wrapping performed
by the mail client will not apply at the other end, and often will not by the mail client will not apply at the other end, and often will not
be examined in any detail. If there is any doubt at all, mail the patch be examined in any detail. If there is any doubt at all, mail the patch
to yourself and convince yourself that it shows up intact. to yourself and convince yourself that it shows up intact.
Documentation/email-clients.txt has some helpful hints on making Documentation/email-clients.txt has some helpful hints on making
specific mail clients work for sending patches. specific mail clients work for sending patches.
...@@ -287,7 +291,7 @@ something like: ...@@ -287,7 +291,7 @@ something like:
where "nn" is the ordinal number of the patch, "mm" is the total number of where "nn" is the ordinal number of the patch, "mm" is the total number of
patches in the series, and "subsys" is the name of the affected subsystem. patches in the series, and "subsys" is the name of the affected subsystem.
Clearly, nn/mm can be omitted for a single, standalone patch. Clearly, nn/mm can be omitted for a single, standalone patch.
If you have a significant series of patches, it is customary to send an If you have a significant series of patches, it is customary to send an
introductory description as part zero. This convention is not universally introductory description as part zero. This convention is not universally
...@@ -299,5 +303,5 @@ In general, the second and following parts of a multi-part patch should be ...@@ -299,5 +303,5 @@ In general, the second and following parts of a multi-part patch should be
sent as a reply to the first part so that they all thread together at the sent as a reply to the first part so that they all thread together at the
receiving end. Tools like git and quilt have commands to mail out a set of receiving end. Tools like git and quilt have commands to mail out a set of
patches with the proper threading. If you have a long series, though, and patches with the proper threading. If you have a long series, though, and
are using git, please provide the --no-chain-reply-to option to avoid are using git, please stay away from the --chain-reply-to option to avoid
creating exceptionally deep nesting. creating exceptionally deep nesting.
...@@ -66,6 +66,11 @@ be easy to become blinded by your own solution to a problem to the point ...@@ -66,6 +66,11 @@ be easy to become blinded by your own solution to a problem to the point
that you don't realize that something is fundamentally wrong or, perhaps, that you don't realize that something is fundamentally wrong or, perhaps,
you're not even solving the right problem. you're not even solving the right problem.
Andrew Morton has suggested that every review comment which does not result
in a code change should result in an additional code comment instead; that
can help future reviewers avoid the questions which came up the first time
around.
One fatal mistake is to ignore review comments in the hope that they will One fatal mistake is to ignore review comments in the hope that they will
go away. They will not go away. If you repost code without having go away. They will not go away. If you repost code without having
responded to the comments you got the time before, you're likely to find responded to the comments you got the time before, you're likely to find
...@@ -100,7 +105,7 @@ entry into a subsystem maintainer's tree. How that works varies from one ...@@ -100,7 +105,7 @@ entry into a subsystem maintainer's tree. How that works varies from one
subsystem to the next; each maintainer has his or her own way of doing subsystem to the next; each maintainer has his or her own way of doing
things. In particular, there may be more than one tree - one, perhaps, things. In particular, there may be more than one tree - one, perhaps,
dedicated to patches planned for the next merge window, and another for dedicated to patches planned for the next merge window, and another for
longer-term work. longer-term work.
For patches applying to areas for which there is no obvious subsystem tree For patches applying to areas for which there is no obvious subsystem tree
(memory management patches, for example), the default tree often ends up (memory management patches, for example), the default tree often ends up
...@@ -109,11 +114,10 @@ through the -mm tree. ...@@ -109,11 +114,10 @@ through the -mm tree.
Inclusion into a subsystem tree can bring a higher level of visibility to a Inclusion into a subsystem tree can bring a higher level of visibility to a
patch. Now other developers working with that tree will get the patch by patch. Now other developers working with that tree will get the patch by
default. Subsystem trees typically feed into -mm and linux-next as well, default. Subsystem trees typically feed linux-next as well, making their
making their contents visible to the development community as a whole. At contents visible to the development community as a whole. At this point,
this point, there's a good chance that you will get more comments from a there's a good chance that you will get more comments from a new set of
new set of reviewers; these comments need to be answered as in the previous reviewers; these comments need to be answered as in the previous round.
round.
What may also happen at this point, depending on the nature of your patch, What may also happen at this point, depending on the nature of your patch,
is that conflicts with work being done by others turn up. In the worst is that conflicts with work being done by others turn up. In the worst
......
...@@ -119,7 +119,7 @@ can affect your ability to get trees pulled in the future. Quoting Linus: ...@@ -119,7 +119,7 @@ can affect your ability to get trees pulled in the future. Quoting Linus:
to trust things *without* then having to go and check every to trust things *without* then having to go and check every
individual change by hand. individual change by hand.
(http://lwn.net/Articles/224135/). (http://lwn.net/Articles/224135/).
To avoid this kind of situation, ensure that all patches within a given To avoid this kind of situation, ensure that all patches within a given
branch stick closely to the associated topic; a "driver fixes" branch branch stick closely to the associated topic; a "driver fixes" branch
...@@ -138,7 +138,7 @@ When requesting a pull, be sure to give all the relevant information: where ...@@ -138,7 +138,7 @@ When requesting a pull, be sure to give all the relevant information: where
your tree is, what branch to pull, and what changes will result from the your tree is, what branch to pull, and what changes will result from the
pull. The git request-pull command can be helpful in this regard; it will pull. The git request-pull command can be helpful in this regard; it will
format the request as other developers expect, and will also check to be format the request as other developers expect, and will also check to be
sure that you have remembered to push those changes to the public server. sure that you have remembered to push those changes to the public server.
7.2: REVIEWING PATCHES 7.2: REVIEWING PATCHES
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment