blob: 9985d0f224d765f848fc0cf80f967ade0e02daa6 [file] [log] [blame] [view]
Varun Khanejadf1bc00e2017-08-10 05:22:401# Severity Guidelines for Security Issues
2
3[TOC]
4
5Vendors shipping products based on Chromium might wish to rate the severity of
6security issues in the products they release. This document contains guidelines
7for how to rate these issues. Check out our
8[security release management page](https://www.chromium.org/Home/chromium-security/security-release-management)
9for guidance on how to release fixes based on severity.
10
11Any significant mitigating factors, such as unusual or additional user
12interaction, or running Chrome with a specific command line flag or non-default
13feature enabled, may reduce an issues severity by one or more levels. Also note
14that most crashes do not indicate vulnerabilities. Chromium is designed to crash
15in a controlled manner (e.g., with a ```__debugBreak```) when memory is
16exhausted or in other exceptional circumstances.
17
18
Chris Palmer32301112019-02-06 00:02:5619## Critical severity {#TOC-Critical-severity}
Varun Khanejadf1bc00e2017-08-10 05:22:4020
Chris Palmer5c330772019-05-24 23:32:4321Critical severity issues allow an attacker to read or write arbitrary resources
22(including but not limited to the file system, registry, network, et c.) on the
23underlying platform, with the user's full privileges.
Varun Khanejadf1bc00e2017-08-10 05:22:4024
25They are normally assigned priority **Pri-0** and assigned to the current stable
26milestone (or earliest milestone affected). For critical severity bugs,
27[SheriffBot](https://www.chromium.org/issue-tracking/autotriage) will
28automatically assign the milestone.
29
30#### For critical vulnerabilities, we aim to deploy the patch to all Chrome users in under 30 days.
31
32Critical vulnerability details may be made public in 60 days,
33in accordance with Google's general [vulnerability disclosure recommendations](https://security.googleblog.com/2010/07/rebooting-responsible-disclosure-focus.html),
34or [faster (7 days)](https://security.googleblog.com/2013/05/disclosure-timeline-for-vulnerabilities.html)
35if there is evidence of active exploitation.
36
37Example bugs:
38
Eric Lawrencee410b0b2017-12-11 19:32:0739* Memory corruption in the browser process ([564501](https://crbug.com/564501)).
Varun Khanejadf1bc00e2017-08-10 05:22:4040* Exploit chains made up of multiple bugs that can lead to code execution
Chris Palmer5c330772019-05-24 23:32:4341 outside of the sandbox ([416449](https://crbug.com/416449)).
42* A bug that enables web content to read local files
43 ([962500](https://crbug.com/962500)).
Varun Khanejadf1bc00e2017-08-10 05:22:4044
45Note that the individual bugs that make up the chain will have lower severity
46ratings.
47
48
Chris Palmer32301112019-02-06 00:02:5649## High severity {#TOC-High-severity}
Varun Khanejadf1bc00e2017-08-10 05:22:4050
51High severity vulnerabilities allow an attacker to execute code in the context
52of, or otherwise impersonate other origins. Bugs which would normally be
53critical severity with unusual mitigating factors may be rated as high severity.
54For example, renderer sandbox escapes fall into this category as their impact is
55that of a critical severity bug, but they require the precondition of a
56compromised renderer.
57
58They are normally assigned priority **Pri-1** and assigned to the current stable
59milestone (or earliest milestone affected). For high severity bugs,
60[SheriffBot](https://www.chromium.org/issue-tracking/autotriage) will
61automatically assign the milestone.
62
63For high severity vulnerabilities, we aim to deploy the patch to all Chrome
64users in under 60 days.
65
66Example bugs:
67
68* A bug that allows full circumvention of the same origin policy. Universal XSS
69bugs fall into this category, as they allow script execution in the context of
70an arbitrary origin ([534923](https://crbug.com/534923)).
71* A bug that allows arbitrary code execution within the confines of the sandbox,
72such as renderer or GPU process memory corruption
73([570427](https://crbug.com/570427), [468936](https://crbug.com/468936)).
74* Complete control over the apparent origin in the omnibox
75([76666](https://crbug.com/76666)).
76* Memory corruption in the browser process that can only be triggered from a
77compromised renderer, leading to a sandbox escape
78([469152](https://crbug.com/469152)).
79* Kernel memory corruption that could be used as a sandbox escape from a
80compromised renderer ([377392](https://crbug.com/377392)).
81* Memory corruption in the browser process that requires specific user
82interaction, such as granting a permission ([455735](https://crbug.com/455735)).
83
84
Chris Palmer32301112019-02-06 00:02:5685## Medium severity {#TOC-Medium-severity}
Varun Khanejadf1bc00e2017-08-10 05:22:4086
87Medium severity bugs allow attackers to read or modify limited amounts of
88information, or are not harmful on their own but potentially harmful when
89combined with other bugs. This includes information leaks that could be useful
90in potential memory corruption exploits, or exposure of sensitive user
91information that an attacker can exfiltrate. Bugs that would normally rated at a
92higher severity level with unusual mitigating factors may be rated as medium
93severity.
94
95They are normally assigned priority **Pri-1** and assigned to the current stable
96milestone (or earliest milestone affected). If the fix seems too complicated to
97merge to the current stable milestone, they may be assigned to the next stable
98milestone.
99
100Example bugs:
101
102* An out-of-bounds read in a renderer process
103([281480](https://crbug.com/281480)).
104* An uninitialized memory read in the browser process where the values are
105passed to a compromised renderer via IPC ([469151](https://crbug.com/469151)).
106* Memory corruption that requires a specific extension to be installed
107([313743](https://crbug.com/313743)).
108* An HSTS bypass ([461481](https://crbug.com/461481)).
109* A bypass of the same origin policy for pages that meet several preconditions
110([419383](https://crbug.com/419383)).
111* A bug that allows web content to tamper with trusted browser UI
112([550047](https://crbug.com/550047)).
113* A bug that reduces the effectiveness of the sandbox
114([338538](https://crbug.com/338538)).
115* A bug that allows arbitrary pages to bypass security interstitials
116([540949](https://crbug.com/540949)).
117* A bug that allows an attacker to reliably read or infer browsing history
118([381808](https://crbug.com/381808)).
119* An address bar spoof where only certain URLs can be displayed, or with other
120mitigating factors ([265221](https://crbug.com/265221)).
121* Memory corruption in a renderer process that requires specific user
122interaction, such as dragging an object ([303772](https://crbug.com/303772)).
123
124
Chris Palmer32301112019-02-06 00:02:56125## Low severity {#TOC-Low-severity}
Varun Khanejadf1bc00e2017-08-10 05:22:40126
127Low severity vulnerabilities are usually bugs that would normally be a higher
128severity, but which have extreme mitigating factors or highly limited scope.
129
130They are normally assigned priority **Pri-2**. Milestones can be assigned to low
131severity bugs on a case-by-case basis, but they are not normally merged to
132stable or beta branches.
133
134Example bugs:
135
136* Bypass requirement for a user gesture ([256057](https://crbug.com/256057)).
137* Partial CSP bypass ([534570](https://crbug.com/534570)).
138* A limited extension permission bypass ([169632](https://crbug.com/169632)).
139* An uncontrolled single-byte out-of-bounds read
140([128163](https://crbug.com/128163)).
141
142The [security FAQ](faq.md) covers many of the cases that we do not consider to
143be security bugs, such as [denial of service](faq.md#TOC-Are-denial-of-service-issues-considered-security-bugs-).
144