1# Reporting Linux kernel bugs
2
3Before reporting a bug make sure nobody else already reported it. The easiest way to do this is to search through the [syzkaller mailing list](https://groups.google.com/forum/#!forum/syzkaller) for key frames present in the kernel stack traces.
4
5Please report found bugs to the Linux kernel maintainers.
6To find out the list of maintainers responsible for a particular kernel subsystem, use the [get_maintainer.pl](https://github.com/torvalds/linux/blob/master/scripts/get_maintainer.pl) script: `./scripts/get_maintainer.pl -f guilty_file.c`. Please add `syzkaller@googlegroups.com` to the CC list.
7Make sure to mention the exact kernel branch and revision where the bug occured.
8Many kernel mailing lists reject HTML formatted messages, so use the plain text mode when sending the report.
9
10Bugs without reproducers are way less likely to be triaged and fixed.
11If the bug is reproducible, include the reproducer (C source if possible, otherwise a syzkaller program) and the `.config` you used for your kernel.
12If the reprocucer is available only in the form of a syzkaller program, please link [the instructions on how to execute them](/docs/executing_syzkaller_programs.md) in your report.
13Check that the reproducer works if you run it manually.
14Syzkaller tries to simplify the reproducer, but the result might not be ideal.
15You can try to simplify or annotate the reproducer manually, that greatly helps kernel developers to figure out why the bug occurs.
16
17If you want to get extra credit, you can try to undestand the bug and develop a fix yourself.
18If you can't figure out the right fix, but have some understanding of the bug, please add your thoughts and conclusions to the report, that will save some time for kernel developers.
19
20## Reporting security bugs
21
22If you believe that a found bug poses potential security threat, consider following the instructions below.
23Note, that these instructions are a work-in-progress and based on my current undestanding of the disclosure proccess.
24This instruction is now being discussed [here](http://seclists.org/oss-sec/2017/q3/242).
25
26If you don't want to deal with this complex disclosure process you can either:
27
281. Report the bug privately to `security@kernel.org`. In this case it should be fixed in the upstream kernel, but there are no guarantees that the fix will be propagated to stable or distro kernels. The maximum embargo on this list is 7 days.
292. Report the bug privately to a vendor such as Red Hat (`secalert@redhat.com`) or SUSE (`security@suse.com`). They should fix the bug, assign a CVE, and notify other vendors. The maximum embargo on these lists is 5 weeks.
303. Report the bug publicly to `oss-security@lists.openwall.com`.
31
32If you want to deal with the disclosure yourself, read below.
33
34The three main mailing lists for reporting and disclosing Linux kernel security issues are `security@kernel.org`, `linux-distros@vs.openwall.org` and `oss-security@lists.openwall.com`.
35The links for the guidelines for these lists are below, please read them carefully before sending anything to these lists.
36
371. `security@kernel.org` - https://www.kernel.org/doc/html/latest/admin-guide/security-bugs.html
382. `linux-distros@vs.openwall.org` - http://oss-security.openwall.org/wiki/mailing-lists/distros
393. `oss-security@lists.openwall.com` - http://oss-security.openwall.org/wiki/mailing-lists/oss-security
40
41### Reporting minor security bugs
42
43To report minor security bugs (such as local DOS or local info leak):
44
451. Report the bug publicly to kernel developers as described above and wait until a fix is committed. Alternatively, you can develop and send a fix yourself.
462. Request a CVE from MITRE through [the web form](https://cveform.mitre.org/). Describe the bug details and add a link to the fix (from `patchwork.kernel.org`, `git.kernel.org` or `github.com`) in the request.
473. Once a CVE is assigned, send the bug details, the CVE number and a link to the fix to `oss-security@lists.openwall.com`.
48
49### Reporting major security bugs
50
51To report major security bugs (such as LPE, remote DOS, remote info leak or RCE):
52
531. Understand the bug and develop a patch with a fix if possible. Optionally develop a proof-of-concept exploit.
542. Notify `security@kernel.org`:
55    * Describe vulnerability details, include the proposed patch and optionally the exploit.
56    * Ask for 7 days of embargo.
57    * Work on the patch together with the `security@kernel.org` members.
583. Notify `linux-distros@vs.openwall.org`:
59    * Describe vulnerability details, include the proposed patch and optionally the exploit.
60    * Ask them to assign a CVE number.
61    * Ask for 7 days of embargo.
624. Wait 7 days for linux distros to apply the patch.
635. Ask `linux-distros@vs.openwall.org` to make the CVE description public and roll out the updated kernels.
646. Send the fix upstream:
65    * Mention the CVE number in the commit message.
66    * Mention syzkaller in the commit message.
677. Notify `oss-security@lists.openwall.com`:
68    * Describe vulnerability details, include a link to the committed patch.
698. Wait 1-3 days for people to update their kernels.
709. Optionally publish the exploit on `oss-security@lists.openwall.com`.
71
72A few notes:
73
74* There should ideally be no delay between reports to `security@kernel.org` and `linux-distros@vs.openwall.org`.
75* There should ideally be no delay between CVE description publication, distros' updates, upstream commit and notification to `oss-security@lists.openwall.com`. All of these should be on the same day, at worst.
76* The moment the issue is made public (e.g. patch is submitted upstream, CVE description published, etc.) it must be reported to `oss-security@lists.openwall.com` right away.
77
78A good example of an LPE announcement structure on `oss-security@lists.openwall.com` can be found [here](http://seclists.org/oss-sec/2016/q4/607), however the timeline doesn't look right there: public announcement should have occured right after the patch was submitted to netdev.
79