StablePatchFormat

Differences between revisions 2 and 24 (spanning 22 versions)
Revision 2 as of 2010-08-06 16:50:30
Size: 6072
Editor: pool-98-108-155-157
Comment:
Revision 24 as of 2019-03-11 18:05:08
Size: 8527
Editor: kleber-souza
Comment: Updated requirements for the subject line; fixed example.
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
Line 3: Line 2:
===================
Line 7: Line 5:
 1. Every stable patch *must* have the release name against which the patch
   
is targeted in it's subject line. That release name *must* be the first
   
string in the subject line and *must* be enclosed in "[ ]" brackets.
 1. Every patch '''must''' have the release name against which the patch is targeted in it's subject line. That release name '''must''' be the first string in the subject line and '''must''' be enclosed in "[ ]" brackets.
Line 11: Line 7:
*Example:*
{{{
[Lucid][pull request] Update to 2.6.32.16 Stable Kernel
}}}
 '''Example:'''
 {{{
 [Lucid][pull request] Update to 2.6.32.16 Stable Kernel
 }}}
Line 16: Line 12:
 1. Every patch request *must* contain one of the following on the Subject line
    after the release name string described previously:
+
[options="header"]
|==================================
| Descriptor | Meaning
| UBUNTU | This is a patch that the submitter has authored and is not yet upstream. The patch has been submitted to upstream but is of enough value for Ubuntu to carry it in our tree regardelss of upstream acceptance.
| UBUNTU SAUCE | This patch is never expected to go upstream but is of enough value for Ubuntu to carry it in our tree. It is very unlikely that any stable patches will have this.
| (pre-stable) | This patch is taken from the stable queue and is expected to eventually be replaced by a patch from a stable release.
|==================================
 1. If the patch requested doesn't come from the mainline tree it '''must''' contain one of the following on the Subject line after the release name string described previously:
Line 27: Line 14:
*Example:*
{{{
[Lucid][pull request] (pre-stable) Blank screen with KMS on Thinkpad X201 with Arrandale (i915)
}}}
 || Descriptor || Meaning ||
 || UBUNTU: || This is a patch to the Ubuntu Packaging this includes the contents of the various debian directories (where not covered by a more specific categorisation) ||
 || UBUNTU: [Config] || This is an update to the kernel configuration as recorded in the debian.<branch>/config directory ||
 || UBUNTU: ubuntu: || This is an update to an Ubuntu specific driver in the ubuntu directory. ||
 || UBUNTU: SAUCE: || This is a patch that the submitter has authored and is not yet upstream. The patch likely has been submitted to upstream but is of enough value for Ubuntu to carry it in our tree regardeless of upstream acceptance. ||
 || UBUNTU: SAUCE: (no-up) || This patch is never expected to go upstream but is of enough value for Ubuntu to carry it in our tree. It is very unlikely that any stable patches will have this. ||
 || UBUNTU: [Debian] || This patch changes the debian rules files (debian/rules, debian*/rules.d/* and possibly debian*/control and debian*/control.d/*). ||
 || (pre-stable) || This patch is taken from the stable queue and is expected to eventually be replaced by a patch from a stable release. ||
 || (upstream) || This patch is either developed by an Ubuntu kernel developer or is taken from an upstream maintainers tree and is expected to eventually be replaced by a patch from a mainline tree. ||

 Notes:
  1. The ''UBUNTU:'' prefix triggers the commit to be listed by author in the changelog, can be thought of as meaning submitted by the author

 '''Example:'''
 {{{
 [Lucid][pull request] (pre-stable) Blank screen with KMS on Thinkpad X201 with Arrandale (i915)
 }}}
Line 34: Line 34:
 1. Every stable patch *must* have an associated Launchpad bug and that bug
    should be part of the commit's comment section in the form of a "BugLink"
    block. A "BugLink" block *must* immediately follow the subject line and be
    the first text in the body of the commit comment. A "BugLink" block
    consists of:
 1. Every patch which is associated with a launchpad bug '''must''' have a link to the bug in the commit's comment section in the form of a "BugLink" block. A "BugLink" block '''must''' immediately follow the subject line and be the first text in the body of the commit comment. A "BugLink" block consists of:
Line 40: Line 36:
   1. A line containing "BugLink:" and a url to the launchpad bug. That url
      *must*
be of the format: "http://bugs.launchpad.net/bugs/<bug-id>" where
     
<bug-id> is the bug number of the associated Launchpad bug.
   1. One or more lines containing "BugLink:" and a url to the launchpad bug. That url '''must''' be of the format: "https://bugs.launchpad.net/bugs/<bug-id>" where <bug-id> is the bug number of the associated Launchpad bug.
Line 45: Line 39:
*Example:*
{{{
1: Subject: [PATCH] UBUNTU: SAUCE: Add thinkpad-acpi to modules in the ALSA subpackage
2:
3: BugLink: http://bugs.launchpad.net/bugs/599527
4:
}}}
 Every stable patch '''must''' have an associated Launchpad bug for tracking by the kernel stable and SRU teams.
Line 53: Line 41:
 1. Every stable patch *must* have a "Signed-off-by" line for the person
    that is submitting the patch. This "Signed-off-by" line *must* follow
    all other provinence lines and should be the last line in the commit
    comment.
 '''Example:'''
 {{{
 1: Subject: [PATCH] UBUNTU: SAUCE: Add thinkpad-acpi to modules in the ALSA subpackage
 2:
 3: BugLink: https://bugs.launchpad.net/bugs/599527
 4: BugLink: https://bugs.launchpad.net/bugs/123456
 5:
 }}}
Line 58: Line 50:
*Example:*
{{{
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
(backported from commit 5620ae29f1eabe655f44335231b580a78c8364ea upstream)
Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
}}}
 1. Every patch '''must''' have a "Signed-off-by" line for the person that is submitting the patch. This "Signed-off-by" line '''must''' follow all other provinence lines and should be the last line in the commit comment.
Line 66: Line 52:
 1. Every stable patch *must* have two "Ack-by" replies by "senior" members
    of the Ubuntu Kernel Team. "Senior" members of the kernel team are
    the members of the kernel_cdev group on zinc.
 '''Example:'''
 {{{
 Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
 Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
 (backported from commit 5620ae29f1eabe655f44335231b580a78c8364ea)
 Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
 }}}
Line 70: Line 60:
{{{
$ getent group kernel_cdev
kernel_cdev:x:2616:rtg,amitk,ogasawara,smb,cking,sconklin,apw
}}}
 1. Where acks are needed they should be placed in the provinence block. Every patch against Development releases following Kernel freeze and '''all''' patches against released kernels '''must''' have two "Ack-by" replies by "senior" members of the Ubuntu Kernel Team. "Senior" members of the kernel team are the members of the kernel_cdev group on zinc.
Line 75: Line 62:
*Example:*
{{{
Signed-off-by: Adam Jackson <ajax@redhat.com>
Signed-off-by: Eric Anholt <eric@anholt.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
(cherry-picked from commit d4e0018e3e4dd685af25d300fd26a0d5a984482e 2.6.34.y)
Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
Acked-by: Tim Gardner <tim.gardner@canonical.com>
Acked-by: Brad Figg <brad.figg@canonical.com>
Acked-by: Steve Conklin <sconklin@canonical.com>
}}}
 {{{
 $ getent group kernel_cdev
 kernel_cdev:x:2616:rtg,amitk,ogasawara,smb,cking,sconklin,apw
 }}}
Line 87: Line 67:
 1. Every patch *must* display the provenance of the patch. We want to preserve
    where the patch came from, who signed off on it, who ack'd it, whether it
    was cherry-picked from upstream or backported from an upstream commit and
    who finally applied it to an official Ubuntu source tree.
 '''Example:'''
 {{{
 Signed-off-by: Adam Jackson <ajax@redhat.com>
 Signed-off-by: Eric Anholt <eric@anholt.net>
 Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
 (cherry picked from commit d4e0018e3e4dd685af25d300fd26a0d5a984482e 2.6.34.y)
 Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
 Acked-by: Tim Gardner <tim.gardner@canonical.com>
 Acked-by: Brad Figg <brad.figg@canonical.com>
 Acked-by: Steve Conklin <sconklin@canonical.com>
 }}}
Line 92: Line 79:
    If the patch required backporting or changes, there should be a brief explanation
    immediately preceeding the original commit text and immediately after the
    "BugLink" block. There *must* also be a line in the provenance section in
    the format:
 1. Every patch '''must''' display the provenance of the patch. We want to preserve where the patch came from, who signed off on it, who ack'd it, whether it was cherry-picked from upstream or backported from an upstream commit and who finally applied it to an official Ubuntu source tree.
Line 97: Line 81:
{{{
(backported from commit <sha1> <upstream repo name>)
}}}
 If the patch required backporting or changes, there '''must''' also be a line in the provenance section in the format:
Line 101: Line 83:
  Please note that the opening and closing parenthesis are required.  {{{
 (backported from commit <sha1> <upstream repo name>)
 }}}

 Please note that the opening and closing parenthesis are required.

 There should be a brief explanation immediately after the "(backported from ...)" block, between square brackets, with the name of the person which introduced the change.

 If the patch is a simple cherry-pick from an upstream repo, that '''must''' also be spelled out in the provenance section in the form:

 {{{
 (cherry picked from commit <sha1> <upstream repo name>)
 }}}

 And the opening and closing parenthesis are required here as well.

 "<upstream repo name>" can be omitted if the patch comes from the mainline tree.

 '''Example:'''
 {{{
 Signed-off-by: Adam Jackson <ajax@redhat.com>
 Signed-off-by: Eric Anholt <eric@anholt.net>
 Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
 (cherry picked from commit d4e0018e3e4dd685af25d300fd26a0d5a984482e 2.6.34.y)
 Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
 Acked-by: Tim Gardner <tim.gardner@canonical.com>
 Acked-by: Brad Figg <brad.figg@canonical.com>
 Acked-by: Steve Conklin <sconklin@canonical.com>
 }}}
Line 104: Line 114:
  If tthe patch is a simple cherry-pick from an upstream repo that *must* also
  be spelled out in the provenance section in the form:
 1. Every '''CVE''' patch '''must''' contain a line at the beginning of the commit message that specifies the CVE number(s) related to the patch. This must be the first part of the body of the comment. There is the comment subject line, a blank line, the CVE number, a blank line and then the rest of the comment body.
Line 107: Line 116:
{{{
(cherry-pick from commit <sha1> <upstream repo name>)
}}}
 '''Example:'''
 {{{
 Subject: [Dapper] [CVE-2010-4258] [PATCH 1/1] do_exit(): make sure that we run with get_fs() == USER_DS
Line 111: Line 120:
  And the opening and closing parenthesis are required here as well.  CVE-2010-4258
Line 113: Line 122:
*Example:*
{{{
Signed-off-by: Adam Jackson <ajax@redhat.com>
Signed-off-by: Eric Anholt <eric@anholt.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
(cherry-picked from commit d4e0018e3e4dd685af25d300fd26a0d5a984482e 2.6.34.y)
Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
Acked-by: Tim Gardner <tim.gardner@canonical.com>
Acked-by: Brad Figg <brad.figg@canonical.com>
Acked-by: Steve Conklin <sconklin@canonical.com>
}}}
 BugLink: https://bugs.launchpad.net/bugs/723945
Line 125: Line 124:
 If a user manages to trigger an oops with fs set to KERNEL_DS, fs is not
 otherwise reset before do_exit(). do_exit may later (via mm_release in
 fork.c) do a put_user to a user-controlled address, potentially allowing
 a user to leverage an oops into a controlled write into kernel memory.

 ...
 }}}
Line 127: Line 133:
{{{
From f71ea7e15129435a07c4e4d0bc08be19e2d0415c Mon Sep 17 00:00:00 2001
From: Steve Conklin <sconklin@canonical.com>
Date: Thu, 29 Jul 2010 16:43:14 -0500
Subject: (pre-stable) drm/i915: make sure eDP panel is turned on
 {{{
 From f71ea7e15129435a07c4e4d0bc08be19e2d0415c Mon Sep 17 00:00:00 2001
 From: Steve Conklin <sconklin@canonical.com>
 Date: Thu, 29 Jul 2010 16:43:14 -0500
 Subject: [Lucid][PATCH] (pre-stable) drm/i915: make sure eDP panel is turned on
 
 BugLink: https://bugs.launchpad.net/bugs/578673
 
 Small modifications needed because of avariable rename.
 
 When enabling the eDP port, we need to make sure the panel is turned on
 after training the link. If we don't, it likely won't come back after
 suspend or may not come up at all.
 
 For unknown reasons, unlocking the panel regs before initiating a power
 on sequence is necessary. There are known bugs in the PCH panel
 sequencing logic, apparently this is one possible workaround.
 
 Fixes https://bugs.freedesktop.org/show_bug.cgi?id=28739.
 
 OriginalAuthor: Jesse Barnes <jbarnes@virtuousgeek.org>
 Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
 Tested-by: "Paulo J. S. Silva" <pjssilva@gmail.com>
 Signed-off-by: Eric Anholt <eric@anholt.net>
 (backported from commit c9fcc5d269949a0fbd46ffbea6cc83741e61c05f)
 [ bjf: context adjustments. ]
 Acked-by: Brad Figg <brad.figg@canonical.com>
 Acked-by: Steve Conklin <sconklin@canonical.com>
 Signed-off-by: Steve Conklin <sconklin@canonical.com>
 }}}
Line 133: Line 164:
BugLink: http://bugs.launchpad.net/bugs/578673

Small modifications needed because of avariable rename.

When enabling the eDP port, we need to make sure the panel is turned on
after training the link. If we don't, it likely won't come back after
suspend or may not come up at all.

For unknown reasons, unlocking the panel regs before initiating a power
on sequence is necessary. There are known bugs in the PCH panel
sequencing logic, apparently this is one possible workaround.

Fixes https://bugs.freedesktop.org/show_bug.cgi?id=28739.

OriginalAuthor: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Tested-by: "Paulo J. S. Silva" <pjssilva@gmail.com>
Signed-off-by: Eric Anholt <eric@anholt.net>
(backported from commit c9fcc5d269949a0fbd46ffbea6cc83741e61c05f upstream)
Acked-by: Brad Figg <brad.figg@canonical.com>
Acked-by: Steve Conklin <sconklin@canonical.com>
Signed-off-by: Steve Conklin <sconklin@canonical.com>
}}}
=== See Also ===
 || [[ KernelTeam/KernelUpdates | Kernel Updates ]] || Shows the SRU Justification format to be added to a bug. ||

Stable Patch Format

Subject Line

  1. Every patch must have the release name against which the patch is targeted in it's subject line. That release name must be the first string in the subject line and must be enclosed in "[ ]" brackets.

    Example:

     [Lucid][pull request] Update to 2.6.32.16 Stable Kernel
  2. If the patch requested doesn't come from the mainline tree it must contain one of the following on the Subject line after the release name string described previously:

    Descriptor

    Meaning

    UBUNTU:

    This is a patch to the Ubuntu Packaging this includes the contents of the various debian directories (where not covered by a more specific categorisation)

    UBUNTU: [Config]

    This is an update to the kernel configuration as recorded in the debian.<branch>/config directory

    UBUNTU: ubuntu:

    This is an update to an Ubuntu specific driver in the ubuntu directory.

    UBUNTU: SAUCE:

    This is a patch that the submitter has authored and is not yet upstream. The patch likely has been submitted to upstream but is of enough value for Ubuntu to carry it in our tree regardeless of upstream acceptance.

    UBUNTU: SAUCE: (no-up)

    This patch is never expected to go upstream but is of enough value for Ubuntu to carry it in our tree. It is very unlikely that any stable patches will have this.

    UBUNTU: [Debian]

    This patch changes the debian rules files (debian/rules, debian*/rules.d/* and possibly debian*/control and debian*/control.d/*).

    (pre-stable)

    This patch is taken from the stable queue and is expected to eventually be replaced by a patch from a stable release.

    (upstream)

    This patch is either developed by an Ubuntu kernel developer or is taken from an upstream maintainers tree and is expected to eventually be replaced by a patch from a mainline tree.

    Notes:
    1. The UBUNTU: prefix triggers the commit to be listed by author in the changelog, can be thought of as meaning submitted by the author

    Example:

     [Lucid][pull request] (pre-stable) Blank screen with KMS on Thinkpad X201 with Arrandale (i915)

Comment Body

  1. Every patch which is associated with a launchpad bug must have a link to the bug in the commit's comment section in the form of a "BugLink" block. A "BugLink" block must immediately follow the subject line and be the first text in the body of the commit comment. A "BugLink" block consists of:

    1. A blank line.
    2. One or more lines containing "BugLink:" and a url to the launchpad bug. That url must be of the format: "https://bugs.launchpad.net/bugs/<bug-id>" where <bug-id> is the bug number of the associated Launchpad bug.

    3. Another blank line.

    Every stable patch must have an associated Launchpad bug for tracking by the kernel stable and SRU teams.

    Example:

     1: Subject: [PATCH] UBUNTU: SAUCE: Add thinkpad-acpi to modules in the ALSA subpackage
     2:
     3: BugLink: https://bugs.launchpad.net/bugs/599527
     4: BugLink: https://bugs.launchpad.net/bugs/123456
     5:
  2. Every patch must have a "Signed-off-by" line for the person that is submitting the patch. This "Signed-off-by" line must follow all other provinence lines and should be the last line in the commit comment.

    Example:

     Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
     Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
     (backported from commit 5620ae29f1eabe655f44335231b580a78c8364ea)
     Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
  3. Where acks are needed they should be placed in the provinence block. Every patch against Development releases following Kernel freeze and all patches against released kernels must have two "Ack-by" replies by "senior" members of the Ubuntu Kernel Team. "Senior" members of the kernel team are the members of the kernel_cdev group on zinc.

     $ getent group kernel_cdev
     kernel_cdev:x:2616:rtg,amitk,ogasawara,smb,cking,sconklin,apw

    Example:

     Signed-off-by: Adam Jackson <ajax@redhat.com>
     Signed-off-by: Eric Anholt <eric@anholt.net>
     Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
     (cherry picked from commit d4e0018e3e4dd685af25d300fd26a0d5a984482e 2.6.34.y)
     Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
     Acked-by: Tim Gardner <tim.gardner@canonical.com>
     Acked-by: Brad Figg <brad.figg@canonical.com>
     Acked-by: Steve Conklin <sconklin@canonical.com>
  4. Every patch must display the provenance of the patch. We want to preserve where the patch came from, who signed off on it, who ack'd it, whether it was cherry-picked from upstream or backported from an upstream commit and who finally applied it to an official Ubuntu source tree.

    If the patch required backporting or changes, there must also be a line in the provenance section in the format:

     (backported from commit <sha1> <upstream repo name>)
    Please note that the opening and closing parenthesis are required. There should be a brief explanation immediately after the "(backported from ...)" block, between square brackets, with the name of the person which introduced the change.

    If the patch is a simple cherry-pick from an upstream repo, that must also be spelled out in the provenance section in the form:

     (cherry picked from commit <sha1> <upstream repo name>)
    And the opening and closing parenthesis are required here as well.

    "<upstream repo name>" can be omitted if the patch comes from the mainline tree.

    Example:

     Signed-off-by: Adam Jackson <ajax@redhat.com>
     Signed-off-by: Eric Anholt <eric@anholt.net>
     Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
     (cherry picked from commit d4e0018e3e4dd685af25d300fd26a0d5a984482e 2.6.34.y)
     Signed-off-by: Manoj Iyer <manoj.iyer@canonical.com>
     Acked-by: Tim Gardner <tim.gardner@canonical.com>
     Acked-by: Brad Figg <brad.figg@canonical.com>
     Acked-by: Steve Conklin <sconklin@canonical.com>
  5. Every CVE patch must contain a line at the beginning of the commit message that specifies the CVE number(s) related to the patch. This must be the first part of the body of the comment. There is the comment subject line, a blank line, the CVE number, a blank line and then the rest of the comment body.

    Example:

     Subject: [Dapper] [CVE-2010-4258] [PATCH 1/1] do_exit(): make sure that we run with get_fs() == USER_DS
    
     CVE-2010-4258
    
     BugLink: https://bugs.launchpad.net/bugs/723945
    
     If a user manages to trigger an oops with fs set to KERNEL_DS, fs is not
     otherwise reset before do_exit().  do_exit may later (via mm_release in
     fork.c) do a put_user to a user-controlled address, potentially allowing
     a user to leverage an oops into a controlled write into kernel memory.
    
     ...

Complete Example

  •  From f71ea7e15129435a07c4e4d0bc08be19e2d0415c Mon Sep 17 00:00:00 2001
     From: Steve Conklin <sconklin@canonical.com>
     Date: Thu, 29 Jul 2010 16:43:14 -0500
     Subject: [Lucid][PATCH] (pre-stable) drm/i915: make sure eDP panel is turned on
     
     BugLink: https://bugs.launchpad.net/bugs/578673
     
     Small modifications needed because of avariable rename.
     
     When enabling the eDP port, we need to make sure the panel is turned on
     after training the link.  If we don't, it likely won't come back after
     suspend or may not come up at all.
     
     For unknown reasons, unlocking the panel regs before initiating a power
     on sequence is necessary.  There are known bugs in the PCH panel
     sequencing logic, apparently this is one possible workaround.
     
     Fixes https://bugs.freedesktop.org/show_bug.cgi?id=28739.
     
     OriginalAuthor: Jesse Barnes <jbarnes@virtuousgeek.org>
     Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
     Tested-by: "Paulo J. S. Silva" <pjssilva@gmail.com>
     Signed-off-by: Eric Anholt <eric@anholt.net>
     (backported from commit c9fcc5d269949a0fbd46ffbea6cc83741e61c05f)
     [ bjf: context adjustments. ]
     Acked-by: Brad Figg <brad.figg@canonical.com>
     Acked-by: Steve Conklin <sconklin@canonical.com>
     Signed-off-by: Steve Conklin <sconklin@canonical.com>

See Also

  • Kernel Updates

    Shows the SRU Justification format to be added to a bug.

Kernel/Dev/StablePatchFormat (last edited 2024-02-22 15:53:06 by roxanan)