WIP FPC-III support
[linux/fpc-iii.git] / Documentation / networking / netif-msg.rst
blobb20d265a734d7269125383097312638ab3c393ff
1 .. SPDX-License-Identifier: GPL-2.0
3 ===============
4 NETIF Msg Level
5 ===============
7 The design of the network interface message level setting.
9 History
10 -------
12  The design of the debugging message interface was guided and
13  constrained by backwards compatibility previous practice.  It is useful
14  to understand the history and evolution in order to understand current
15  practice and relate it to older driver source code.
17  From the beginning of Linux, each network device driver has had a local
18  integer variable that controls the debug message level.  The message
19  level ranged from 0 to 7, and monotonically increased in verbosity.
21  The message level was not precisely defined past level 3, but were
22  always implemented within +-1 of the specified level.  Drivers tended
23  to shed the more verbose level messages as they matured.
25    - 0  Minimal messages, only essential information on fatal errors.
26    - 1  Standard messages, initialization status.  No run-time messages
27    - 2  Special media selection messages, generally timer-driver.
28    - 3  Interface starts and stops, including normal status messages
29    - 4  Tx and Rx frame error messages, and abnormal driver operation
30    - 5  Tx packet queue information, interrupt events.
31    - 6  Status on each completed Tx packet and received Rx packets
32    - 7  Initial contents of Tx and Rx packets
34  Initially this message level variable was uniquely named in each driver
35  e.g. "lance_debug", so that a kernel symbolic debugger could locate and
36  modify the setting.  When kernel modules became common, the variables
37  were consistently renamed to "debug" and allowed to be set as a module
38  parameter.
40  This approach worked well.  However there is always a demand for
41  additional features.  Over the years the following emerged as
42  reasonable and easily implemented enhancements
44    - Using an ioctl() call to modify the level.
45    - Per-interface rather than per-driver message level setting.
46    - More selective control over the type of messages emitted.
48  The netif_msg recommendation adds these features with only a minor
49  complexity and code size increase.
51  The recommendation is the following points
53   - Retaining the per-driver integer variable "debug" as a module
54     parameter with a default level of '1'.
56   - Adding a per-interface private variable named "msg_enable".  The
57     variable is a bit map rather than a level, and is initialized as::
59        1 << debug
61     Or more precisely::
63         debug < 0 ? 0 : 1 << min(sizeof(int)-1, debug)
65     Messages should changes from::
67       if (debug > 1)
68            printk(MSG_DEBUG "%s: ...
70     to::
72       if (np->msg_enable & NETIF_MSG_LINK)
73            printk(MSG_DEBUG "%s: ...
76 The set of message levels is named
79   =========   ===================       ============
80   Old level   Name                      Bit position
81   =========   ===================       ============
82     0         NETIF_MSG_DRV             0x0001
83     1         NETIF_MSG_PROBE           0x0002
84     2         NETIF_MSG_LINK            0x0004
85     2         NETIF_MSG_TIMER           0x0004
86     3         NETIF_MSG_IFDOWN          0x0008
87     3         NETIF_MSG_IFUP            0x0008
88     4         NETIF_MSG_RX_ERR          0x0010
89     4         NETIF_MSG_TX_ERR          0x0010
90     5         NETIF_MSG_TX_QUEUED       0x0020
91     5         NETIF_MSG_INTR            0x0020
92     6         NETIF_MSG_TX_DONE         0x0040
93     6         NETIF_MSG_RX_STATUS       0x0040
94     7         NETIF_MSG_PKTDATA         0x0080
95   =========   ===================       ============