Mauro Carvalho Chehab | 609d99a | 2016-09-19 08:07:56 -0300 | [diff] [blame] | 1 | .. _applying_patches: |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 2 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 3 | Applying Patches To The Linux Kernel |
| 4 | ++++++++++++++++++++++++++++++++++++ |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 5 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 6 | Original by: |
| 7 | Jesper Juhl, August 2005 |
| 8 | |
Jonathan Corbet | 67972a5 | 2016-10-26 16:48:36 -0600 | [diff] [blame] | 9 | .. note:: |
| 10 | |
| 11 | This document is obsolete. In most cases, rather than using ``patch`` |
| 12 | manually, you'll almost certainly want to look at using Git instead. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 13 | |
| 14 | A frequently asked question on the Linux Kernel Mailing List is how to apply |
| 15 | a patch to the kernel or, more specifically, what base kernel a patch for |
| 16 | one of the many trees/branches should be applied to. Hopefully this document |
| 17 | will explain this to you. |
| 18 | |
| 19 | In addition to explaining how to apply and revert patches, a brief |
| 20 | description of the different kernel trees (and examples of how to apply |
| 21 | their specific patches) is also provided. |
| 22 | |
| 23 | |
| 24 | What is a patch? |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 25 | ================ |
| 26 | |
| 27 | A patch is a small text document containing a delta of changes between two |
| 28 | different versions of a source tree. Patches are created with the ``diff`` |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 29 | program. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 30 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 31 | To correctly apply a patch you need to know what base it was generated from |
| 32 | and what new version the patch will change the source tree into. These |
| 33 | should both be present in the patch file metadata or be possible to deduce |
| 34 | from the filename. |
| 35 | |
| 36 | |
| 37 | How do I apply or revert a patch? |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 38 | ================================= |
| 39 | |
| 40 | You apply a patch with the ``patch`` program. The patch program reads a diff |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 41 | (or patch) file and makes the changes to the source tree described in it. |
| 42 | |
| 43 | Patches for the Linux kernel are generated relative to the parent directory |
| 44 | holding the kernel source dir. |
| 45 | |
| 46 | This means that paths to files inside the patch file contain the name of the |
| 47 | kernel source directories it was generated against (or some other directory |
| 48 | names like "a/" and "b/"). |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 49 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 50 | Since this is unlikely to match the name of the kernel source dir on your |
| 51 | local machine (but is often useful info to see what version an otherwise |
| 52 | unlabeled patch was generated against) you should change into your kernel |
| 53 | source directory and then strip the first element of the path from filenames |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 54 | in the patch file when applying it (the ``-p1`` argument to ``patch`` does |
| 55 | this). |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 56 | |
| 57 | To revert a previously applied patch, use the -R argument to patch. |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 58 | So, if you applied a patch like this:: |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 59 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 60 | patch -p1 < ../patch-x.y.z |
| 61 | |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 62 | You can revert (undo) it like this:: |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 63 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 64 | patch -R -p1 < ../patch-x.y.z |
| 65 | |
| 66 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 67 | How do I feed a patch/diff file to ``patch``? |
| 68 | ============================================= |
| 69 | |
| 70 | This (as usual with Linux and other UNIX like operating systems) can be |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 71 | done in several different ways. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 72 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 73 | In all the examples below I feed the file (in uncompressed form) to patch |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 74 | via stdin using the following syntax:: |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 75 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 76 | patch -p1 < path/to/patch-x.y.z |
| 77 | |
| 78 | If you just want to be able to follow the examples below and don't want to |
| 79 | know of more than one way to use patch, then you can stop reading this |
| 80 | section here. |
| 81 | |
| 82 | Patch can also get the name of the file to use via the -i argument, like |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 83 | this:: |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 84 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 85 | patch -p1 -i path/to/patch-x.y.z |
| 86 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 87 | If your patch file is compressed with gzip or xz and you don't want to |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 88 | uncompress it before applying it, then you can feed it to patch like this |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 89 | instead:: |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 90 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 91 | xzcat path/to/patch-x.y.z.xz | patch -p1 |
| 92 | bzcat path/to/patch-x.y.z.gz | patch -p1 |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 93 | |
| 94 | If you wish to uncompress the patch file by hand first before applying it |
| 95 | (what I assume you've done in the examples below), then you simply run |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 96 | gunzip or xz on the file -- like this:: |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 97 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 98 | gunzip patch-x.y.z.gz |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 99 | xz -d patch-x.y.z.xz |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 100 | |
| 101 | Which will leave you with a plain text patch-x.y.z file that you can feed to |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 102 | patch via stdin or the ``-i`` argument, as you prefer. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 103 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 104 | A few other nice arguments for patch are ``-s`` which causes patch to be silent |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 105 | except for errors which is nice to prevent errors from scrolling out of the |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 106 | screen too fast, and ``--dry-run`` which causes patch to just print a listing of |
| 107 | what would happen, but doesn't actually make any changes. Finally ``--verbose`` |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 108 | tells patch to print more information about the work being done. |
| 109 | |
| 110 | |
| 111 | Common errors when patching |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 112 | =========================== |
| 113 | |
| 114 | When patch applies a patch file it attempts to verify the sanity of the |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 115 | file in different ways. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 116 | |
Oscar Utbult | 2d69049a | 2014-09-25 15:41:35 +0200 | [diff] [blame] | 117 | Checking that the file looks like a valid patch file and checking the code |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 118 | around the bits being modified matches the context provided in the patch are |
| 119 | just two of the basic sanity checks patch does. |
| 120 | |
| 121 | If patch encounters something that doesn't look quite right it has two |
| 122 | options. It can either refuse to apply the changes and abort or it can try |
| 123 | to find a way to make the patch apply with a few minor changes. |
| 124 | |
| 125 | One example of something that's not 'quite right' that patch will attempt to |
| 126 | fix up is if all the context matches, the lines being changed match, but the |
| 127 | line numbers are different. This can happen, for example, if the patch makes |
| 128 | a change in the middle of the file but for some reasons a few lines have |
| 129 | been added or removed near the beginning of the file. In that case |
| 130 | everything looks good it has just moved up or down a bit, and patch will |
| 131 | usually adjust the line numbers and apply the patch. |
| 132 | |
| 133 | Whenever patch applies a patch that it had to modify a bit to make it fit |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 134 | it'll tell you about it by saying the patch applied with **fuzz**. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 135 | You should be wary of such changes since even though patch probably got it |
| 136 | right it doesn't /always/ get it right, and the result will sometimes be |
| 137 | wrong. |
| 138 | |
| 139 | When patch encounters a change that it can't fix up with fuzz it rejects it |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 140 | outright and leaves a file with a ``.rej`` extension (a reject file). You can |
Jesper Juhl | 90f2447 | 2006-01-08 01:03:38 -0800 | [diff] [blame] | 141 | read this file to see exactly what change couldn't be applied, so you can |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 142 | go fix it up by hand if you wish. |
| 143 | |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 144 | If you don't have any third-party patches applied to your kernel source, but |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 145 | only patches from kernel.org and you apply the patches in the correct order, |
| 146 | and have made no modifications yourself to the source files, then you should |
| 147 | never see a fuzz or reject message from patch. If you do see such messages |
| 148 | anyway, then there's a high risk that either your local source tree or the |
| 149 | patch file is corrupted in some way. In that case you should probably try |
Jesper Juhl | 90f2447 | 2006-01-08 01:03:38 -0800 | [diff] [blame] | 150 | re-downloading the patch and if things are still not OK then you'd be advised |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 151 | to start with a fresh tree downloaded in full from kernel.org. |
| 152 | |
| 153 | Let's look a bit more at some of the messages patch can produce. |
| 154 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 155 | If patch stops and presents a ``File to patch:`` prompt, then patch could not |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 156 | find a file to be patched. Most likely you forgot to specify -p1 or you are |
| 157 | in the wrong directory. Less often, you'll find patches that need to be |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 158 | applied with ``-p0`` instead of ``-p1`` (reading the patch file should reveal if |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 159 | this is the case -- if so, then this is an error by the person who created |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 160 | the patch but is not fatal). |
| 161 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 162 | If you get ``Hunk #2 succeeded at 1887 with fuzz 2 (offset 7 lines).`` or a |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 163 | message similar to that, then it means that patch had to adjust the location |
| 164 | of the change (in this example it needed to move 7 lines from where it |
| 165 | expected to make the change to make it fit). |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 166 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 167 | The resulting file may or may not be OK, depending on the reason the file |
| 168 | was different than expected. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 169 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 170 | This often happens if you try to apply a patch that was generated against a |
| 171 | different kernel version than the one you are trying to patch. |
| 172 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 173 | If you get a message like ``Hunk #3 FAILED at 2387.``, then it means that the |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 174 | patch could not be applied correctly and the patch program was unable to |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 175 | fuzz its way through. This will generate a ``.rej`` file with the change that |
| 176 | caused the patch to fail and also a ``.orig`` file showing you the original |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 177 | content that couldn't be changed. |
| 178 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 179 | If you get ``Reversed (or previously applied) patch detected! Assume -R? [n]`` |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 180 | then patch detected that the change contained in the patch seems to have |
| 181 | already been made. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 182 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 183 | If you actually did apply this patch previously and you just re-applied it |
| 184 | in error, then just say [n]o and abort this patch. If you applied this patch |
| 185 | previously and actually intended to revert it, but forgot to specify -R, |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 186 | then you can say [**y**]es here to make patch revert it for you. |
| 187 | |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 188 | This can also happen if the creator of the patch reversed the source and |
| 189 | destination directories when creating the patch, and in that case reverting |
| 190 | the patch will in fact apply it. |
| 191 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 192 | A message similar to ``patch: **** unexpected end of file in patch`` or |
| 193 | ``patch unexpectedly ends in middle of line`` means that patch could make no |
| 194 | sense of the file you fed to it. Either your download is broken, you tried to |
| 195 | feed patch a compressed patch file without uncompressing it first, or the patch |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 196 | file that you are using has been mangled by a mail client or mail transfer |
| 197 | agent along the way somewhere, e.g., by splitting a long line into two lines. |
| 198 | Often these warnings can easily be fixed by joining (concatenating) the |
| 199 | two lines that had been split. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 200 | |
| 201 | As I already mentioned above, these errors should never happen if you apply |
| 202 | a patch from kernel.org to the correct version of an unmodified source tree. |
| 203 | So if you get these errors with kernel.org patches then you should probably |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 204 | assume that either your patch file or your tree is broken and I'd advise you |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 205 | to start over with a fresh download of a full kernel tree and the patch you |
| 206 | wish to apply. |
| 207 | |
| 208 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 209 | Are there any alternatives to ``patch``? |
| 210 | ======================================== |
Jesper Juhl | 90f2447 | 2006-01-08 01:03:38 -0800 | [diff] [blame] | 211 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 212 | |
| 213 | Yes there are alternatives. |
| 214 | |
| 215 | You can use the ``interdiff`` program (http://cyberelk.net/tim/patchutils/) to |
Jesper Juhl | 90f2447 | 2006-01-08 01:03:38 -0800 | [diff] [blame] | 216 | generate a patch representing the differences between two patches and then |
| 217 | apply the result. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 218 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 219 | This will let you move from something like 4.7.2 to 4.7.3 in a single |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 220 | step. The -z flag to interdiff will even let you feed it patches in gzip or |
| 221 | bzip2 compressed form directly without the use of zcat or bzcat or manual |
| 222 | decompression. |
| 223 | |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 224 | Here's how you'd go from 4.7.2 to 4.7.3 in a single step:: |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 225 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 226 | interdiff -z ../patch-4.7.2.gz ../patch-4.7.3.gz | patch -p1 |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 227 | |
| 228 | Although interdiff may save you a step or two you are generally advised to |
| 229 | do the additional steps since interdiff can get things wrong in some cases. |
| 230 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 231 | Another alternative is ``ketchup``, which is a python script for automatic |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 232 | downloading and applying of patches (http://www.selenic.com/ketchup/). |
| 233 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 234 | Other nice tools are diffstat, which shows a summary of changes made by a |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 235 | patch; lsdiff, which displays a short listing of affected files in a patch |
| 236 | file, along with (optionally) the line numbers of the start of each patch; |
| 237 | and grepdiff, which displays a list of the files modified by a patch where |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 238 | the patch contains a given regular expression. |
| 239 | |
| 240 | |
| 241 | Where can I download the patches? |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 242 | ================================= |
| 243 | |
| 244 | The patches are available at http://kernel.org/ |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 245 | Most recent patches are linked from the front page, but they also have |
| 246 | specific homes. |
| 247 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 248 | The 4.x.y (-stable) and 4.x patches live at |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 249 | |
SeongJae Park | 3bdadc86 | 2017-03-27 22:05:34 +0900 | [diff] [blame] | 250 | https://www.kernel.org/pub/linux/kernel/v4.x/ |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 251 | |
| 252 | The -rc patches live at |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 253 | |
SeongJae Park | 3bdadc86 | 2017-03-27 22:05:34 +0900 | [diff] [blame] | 254 | https://www.kernel.org/pub/linux/kernel/v4.x/testing/ |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 255 | |
| 256 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 257 | The 4.x kernels |
| 258 | =============== |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 259 | |
| 260 | These are the base stable releases released by Linus. The highest numbered |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 261 | release is the most recent. |
| 262 | |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 263 | If regressions or other serious flaws are found, then a -stable fix patch |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 264 | will be released (see below) on top of this base. Once a new 4.x base |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 265 | kernel is released, a patch is made available that is a delta between the |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 266 | previous 4.x kernel and the new one. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 267 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 268 | To apply a patch moving from 4.6 to 4.7, you'd do the following (note |
| 269 | that such patches do **NOT** apply on top of 4.x.y kernels but on top of the |
| 270 | base 4.x kernel -- if you need to move from 4.x.y to 4.x+1 you need to |
| 271 | first revert the 4.x.y patch). |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 272 | |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 273 | Here are some examples:: |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 274 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 275 | # moving from 4.6 to 4.7 |
| 276 | |
| 277 | $ cd ~/linux-4.6 # change to kernel source dir |
| 278 | $ patch -p1 < ../patch-4.7 # apply the 4.7 patch |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 279 | $ cd .. |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 280 | $ mv linux-4.6 linux-4.7 # rename source dir |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 281 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 282 | # moving from 4.6.1 to 4.7 |
| 283 | |
| 284 | $ cd ~/linux-4.6.1 # change to kernel source dir |
| 285 | $ patch -p1 -R < ../patch-4.6.1 # revert the 4.6.1 patch |
| 286 | # source dir is now 4.6 |
| 287 | $ patch -p1 < ../patch-4.7 # apply new 4.7 patch |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 288 | $ cd .. |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 289 | $ mv linux-4.6.1 linux-4.7 # rename source dir |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 290 | |
| 291 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 292 | The 4.x.y kernels |
| 293 | ================= |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 294 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 295 | Kernels with 3-digit versions are -stable kernels. They contain small(ish) |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 296 | critical fixes for security problems or significant regressions discovered |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 297 | in a given 4.x kernel. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 298 | |
| 299 | This is the recommended branch for users who want the most recent stable |
| 300 | kernel and are not interested in helping test development/experimental |
| 301 | versions. |
| 302 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 303 | If no 4.x.y kernel is available, then the highest numbered 4.x kernel is |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 304 | the current stable kernel. |
| 305 | |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 306 | .. note:: |
| 307 | |
| 308 | The -stable team usually do make incremental patches available as well |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 309 | as patches against the latest mainline release, but I only cover the |
| 310 | non-incremental ones below. The incremental ones can be found at |
SeongJae Park | 3bdadc86 | 2017-03-27 22:05:34 +0900 | [diff] [blame] | 311 | https://www.kernel.org/pub/linux/kernel/v4.x/incr/ |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 312 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 313 | These patches are not incremental, meaning that for example the 4.7.3 |
| 314 | patch does not apply on top of the 4.7.2 kernel source, but rather on top |
| 315 | of the base 4.7 kernel source. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 316 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 317 | So, in order to apply the 4.7.3 patch to your existing 4.7.2 kernel |
| 318 | source you have to first back out the 4.7.2 patch (so you are left with a |
| 319 | base 4.7 kernel source) and then apply the new 4.7.3 patch. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 320 | |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 321 | Here's a small example:: |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 322 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 323 | $ cd ~/linux-4.7.2 # change to the kernel source dir |
| 324 | $ patch -p1 -R < ../patch-4.7.2 # revert the 4.7.2 patch |
| 325 | $ patch -p1 < ../patch-4.7.3 # apply the new 4.7.3 patch |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 326 | $ cd .. |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 327 | $ mv linux-4.7.2 linux-4.7.3 # rename the kernel source dir |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 328 | |
| 329 | The -rc kernels |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 330 | =============== |
| 331 | |
| 332 | These are release-candidate kernels. These are development kernels released |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 333 | by Linus whenever he deems the current git (the kernel's source management |
| 334 | tool) tree to be in a reasonably sane state adequate for testing. |
| 335 | |
| 336 | These kernels are not stable and you should expect occasional breakage if |
| 337 | you intend to run them. This is however the most stable of the main |
| 338 | development branches and is also what will eventually turn into the next |
| 339 | stable kernel, so it is important that it be tested by as many people as |
| 340 | possible. |
| 341 | |
| 342 | This is a good branch to run for people who want to help out testing |
| 343 | development kernels but do not want to run some of the really experimental |
Randy Dunlap | f7a6dd8 | 2017-08-28 17:40:39 -0700 | [diff] [blame] | 344 | stuff (such people should see the sections about -next and -mm kernels below). |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 345 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 346 | The -rc patches are not incremental, they apply to a base 4.x kernel, just |
| 347 | like the 4.x.y patches described above. The kernel version before the -rcN |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 348 | suffix denotes the version of the kernel that this -rc kernel will eventually |
| 349 | turn into. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 350 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 351 | So, 4.8-rc5 means that this is the fifth release candidate for the 4.8 |
| 352 | kernel and the patch should be applied on top of the 4.7 kernel source. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 353 | |
Jonathan Corbet | 1b49ecf | 2016-09-20 18:46:36 -0600 | [diff] [blame] | 354 | Here are 3 examples of how to apply these patches:: |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 355 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 356 | # first an example of moving from 4.7 to 4.8-rc3 |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 357 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 358 | $ cd ~/linux-4.7 # change to the 4.7 source dir |
| 359 | $ patch -p1 < ../patch-4.8-rc3 # apply the 4.8-rc3 patch |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 360 | $ cd .. |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 361 | $ mv linux-4.7 linux-4.8-rc3 # rename the source dir |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 362 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 363 | # now let's move from 4.8-rc3 to 4.8-rc5 |
| 364 | |
| 365 | $ cd ~/linux-4.8-rc3 # change to the 4.8-rc3 dir |
| 366 | $ patch -p1 -R < ../patch-4.8-rc3 # revert the 4.8-rc3 patch |
| 367 | $ patch -p1 < ../patch-4.8-rc5 # apply the new 4.8-rc5 patch |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 368 | $ cd .. |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 369 | $ mv linux-4.8-rc3 linux-4.8-rc5 # rename the source dir |
| 370 | |
| 371 | # finally let's try and move from 4.7.3 to 4.8-rc5 |
| 372 | |
| 373 | $ cd ~/linux-4.7.3 # change to the kernel source dir |
| 374 | $ patch -p1 -R < ../patch-4.7.3 # revert the 4.7.3 patch |
| 375 | $ patch -p1 < ../patch-4.8-rc5 # apply new 4.8-rc5 patch |
| 376 | $ cd .. |
| 377 | $ mv linux-4.7.3 linux-4.8-rc5 # rename the kernel source dir |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 378 | |
| 379 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 380 | The -mm patches and the linux-next tree |
| 381 | ======================================= |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 382 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 383 | The -mm patches are experimental patches released by Andrew Morton. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 384 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 385 | In the past, -mm tree were used to also test subsystem patches, but this |
| 386 | function is now done via the |
Mauro Carvalho Chehab | 3a61bad | 2016-09-21 10:04:16 -0300 | [diff] [blame] | 387 | `linux-next <https://www.kernel.org/doc/man-pages/linux-next.html>` |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 388 | tree. The Subsystem maintainers push their patches first to linux-next, |
| 389 | and, during the merge window, sends them directly to Linus. |
Mauro Carvalho Chehab | 9299c3e | 2016-09-19 08:07:40 -0300 | [diff] [blame] | 390 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 391 | The -mm patches serve as a sort of proving ground for new features and other |
| 392 | experimental patches that aren't merged via a subsystem tree. |
| 393 | Once such patches has proved its worth in -mm for a while Andrew pushes |
| 394 | it on to Linus for inclusion in mainline. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 395 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 396 | The linux-next tree is daily updated, and includes the -mm patches. |
| 397 | Both are in constant flux and contains many experimental features, a |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 398 | lot of debugging patches not appropriate for mainline etc., and is the most |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 399 | experimental of the branches described in this document. |
| 400 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 401 | These patches are not appropriate for use on systems that are supposed to be |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 402 | stable and they are more risky to run than any of the other branches (make |
Randy Dunlap | c594a50 | 2006-01-09 20:53:56 -0800 | [diff] [blame] | 403 | sure you have up-to-date backups -- that goes for any experimental kernel but |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 404 | even more so for -mm patches or using a Kernel from the linux-next tree). |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 405 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 406 | Testing of -mm patches and linux-next is greatly appreciated since the whole |
| 407 | point of those are to weed out regressions, crashes, data corruption bugs, |
| 408 | build breakage (and any other bug in general) before changes are merged into |
| 409 | the more stable mainline Linus tree. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 410 | |
Mauro Carvalho Chehab | 330ae7e | 2016-09-19 08:07:41 -0300 | [diff] [blame] | 411 | But testers of -mm and linux-next should be aware that breakages are |
| 412 | more common than in any other tree. |
Jesper Juhl | 754c797 | 2005-09-09 13:10:12 -0700 | [diff] [blame] | 413 | |
| 414 | |
Jesper Juhl | 90f2447 | 2006-01-08 01:03:38 -0800 | [diff] [blame] | 415 | This concludes this list of explanations of the various kernel trees. |
| 416 | I hope you are now clear on how to apply the various patches and help testing |
| 417 | the kernel. |
| 418 | |
| 419 | Thank you's to Randy Dunlap, Rolf Eike Beer, Linus Torvalds, Bodo Eggert, |
| 420 | Johannes Stezenbach, Grant Coady, Pavel Machek and others that I may have |
| 421 | forgotten for their reviews and contributions to this document. |