- TX: Put the CAN frame from the socket buffer to the CAN controller.
 - RX: Put the CAN frame from the CAN controller to the socket buffer.
 
-See e.g. at Documentation/networking/netdevices.txt . The differences
+See e.g. at Documentation/networking/netdevices.rst . The differences
 for writing CAN network device driver are described below:
 
 
 
+.. SPDX-License-Identifier: GPL-2.0
 
+=====================================
 Network Devices, the Kernel, and You!
+=====================================
 
 
 Introduction
        Don't use it for new drivers.
 
        Context: Process with BHs disabled or BH (timer),
-                will be called with interrupts disabled by netconsole.
+                will be called with interrupts disabled by netconsole.
 
-       Return codes: 
-       o NETDEV_TX_OK everything ok. 
-       o NETDEV_TX_BUSY Cannot transmit packet, try later 
+       Return codes:
+
+       * NETDEV_TX_OK everything ok.
+       * NETDEV_TX_BUSY Cannot transmit packet, try later
          Usually a bug, means queue start/stop flow control is broken in
          the driver. Note: the driver must NOT put the skb in its DMA ring.
 
 struct napi_struct synchronization rules
 ========================================
 napi->poll:
-       Synchronization: NAPI_STATE_SCHED bit in napi->state.  Device
+       Synchronization:
+               NAPI_STATE_SCHED bit in napi->state.  Device
                driver's ndo_stop method will invoke napi_disable() on
                all NAPI instances which will do a sleeping poll on the
                NAPI_STATE_SCHED napi->state bit, waiting for all pending
                NAPI activity to cease.
-       Context: softirq
-                will be called with interrupts disabled by netconsole.
+
+       Context:
+                softirq
+                will be called with interrupts disabled by netconsole.