1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef COMPONENTS_NACL_BROWSER_BAD_MESSAGE_H_
6 #define COMPONENTS_NACL_BROWSER_BAD_MESSAGE_H_
9 class BrowserMessageFilter
;
13 namespace bad_message
{
15 // The browser process often chooses to terminate a renderer if it receives
16 // a bad IPC message. The reasons are tracked for metrics.
18 // See also content/browser/bad_message.h.
20 // NOTE: Do not remove or reorder elements in this list. Add new entries at the
21 // end. Items may be renamed but do not change the values. We rely on the enum
22 // values in histograms.
23 enum BadMessageReason
{
24 NFH_OPEN_EXECUTABLE_BAD_ROUTING_ID
= 0,
25 NHMF_LAUNCH_CONTINUATION_BAD_ROUTING_ID
= 1,
26 NHMF_GET_NEXE_FD_BAD_URL
= 2,
28 // Please add new elements here. The naming convention is abbreviated class
29 // name (e.g. NaclHostMessageFilter becomes NHMF) plus a unique description of
30 // the reason. After making changes, you MUST update histograms.xml by
32 // "python tools/metrics/histograms/update_bad_message_reasons.py"
36 // Called when a browser message filter receives a bad IPC message from a
37 // renderer or other child process. Logs the event, records a histogram metric
38 // for the |reason|, and terminates the process for |filter|.
39 void ReceivedBadMessage(content::BrowserMessageFilter
* filter
,
40 BadMessageReason reason
);
42 } // namespace bad_message
45 #endif // COMPONENTS_NACL_BROWSER_BAD_MESSAGE_H_