xref: /OK3568_Linux_fs/kernel/drivers/net/ethernet/intel/igc/igc_dump.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0
2*4882a593Smuzhiyun /* Copyright (c)  2018 Intel Corporation */
3*4882a593Smuzhiyun 
4*4882a593Smuzhiyun #include "igc.h"
5*4882a593Smuzhiyun 
6*4882a593Smuzhiyun struct igc_reg_info {
7*4882a593Smuzhiyun 	u32 ofs;
8*4882a593Smuzhiyun 	char *name;
9*4882a593Smuzhiyun };
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun static const struct igc_reg_info igc_reg_info_tbl[] = {
12*4882a593Smuzhiyun 	/* General Registers */
13*4882a593Smuzhiyun 	{IGC_CTRL, "CTRL"},
14*4882a593Smuzhiyun 	{IGC_STATUS, "STATUS"},
15*4882a593Smuzhiyun 	{IGC_CTRL_EXT, "CTRL_EXT"},
16*4882a593Smuzhiyun 	{IGC_MDIC, "MDIC"},
17*4882a593Smuzhiyun 
18*4882a593Smuzhiyun 	/* Interrupt Registers */
19*4882a593Smuzhiyun 	{IGC_ICR, "ICR"},
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun 	/* RX Registers */
22*4882a593Smuzhiyun 	{IGC_RCTL, "RCTL"},
23*4882a593Smuzhiyun 	{IGC_RDLEN(0), "RDLEN"},
24*4882a593Smuzhiyun 	{IGC_RDH(0), "RDH"},
25*4882a593Smuzhiyun 	{IGC_RDT(0), "RDT"},
26*4882a593Smuzhiyun 	{IGC_RXDCTL(0), "RXDCTL"},
27*4882a593Smuzhiyun 	{IGC_RDBAL(0), "RDBAL"},
28*4882a593Smuzhiyun 	{IGC_RDBAH(0), "RDBAH"},
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun 	/* TX Registers */
31*4882a593Smuzhiyun 	{IGC_TCTL, "TCTL"},
32*4882a593Smuzhiyun 	{IGC_TDBAL(0), "TDBAL"},
33*4882a593Smuzhiyun 	{IGC_TDBAH(0), "TDBAH"},
34*4882a593Smuzhiyun 	{IGC_TDLEN(0), "TDLEN"},
35*4882a593Smuzhiyun 	{IGC_TDH(0), "TDH"},
36*4882a593Smuzhiyun 	{IGC_TDT(0), "TDT"},
37*4882a593Smuzhiyun 	{IGC_TXDCTL(0), "TXDCTL"},
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun 	/* List Terminator */
40*4882a593Smuzhiyun 	{}
41*4882a593Smuzhiyun };
42*4882a593Smuzhiyun 
43*4882a593Smuzhiyun /* igc_regdump - register printout routine */
igc_regdump(struct igc_hw * hw,struct igc_reg_info * reginfo)44*4882a593Smuzhiyun static void igc_regdump(struct igc_hw *hw, struct igc_reg_info *reginfo)
45*4882a593Smuzhiyun {
46*4882a593Smuzhiyun 	struct net_device *dev = igc_get_hw_dev(hw);
47*4882a593Smuzhiyun 	int n = 0;
48*4882a593Smuzhiyun 	char rname[16];
49*4882a593Smuzhiyun 	u32 regs[8];
50*4882a593Smuzhiyun 
51*4882a593Smuzhiyun 	switch (reginfo->ofs) {
52*4882a593Smuzhiyun 	case IGC_RDLEN(0):
53*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
54*4882a593Smuzhiyun 			regs[n] = rd32(IGC_RDLEN(n));
55*4882a593Smuzhiyun 		break;
56*4882a593Smuzhiyun 	case IGC_RDH(0):
57*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
58*4882a593Smuzhiyun 			regs[n] = rd32(IGC_RDH(n));
59*4882a593Smuzhiyun 		break;
60*4882a593Smuzhiyun 	case IGC_RDT(0):
61*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
62*4882a593Smuzhiyun 			regs[n] = rd32(IGC_RDT(n));
63*4882a593Smuzhiyun 		break;
64*4882a593Smuzhiyun 	case IGC_RXDCTL(0):
65*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
66*4882a593Smuzhiyun 			regs[n] = rd32(IGC_RXDCTL(n));
67*4882a593Smuzhiyun 		break;
68*4882a593Smuzhiyun 	case IGC_RDBAL(0):
69*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
70*4882a593Smuzhiyun 			regs[n] = rd32(IGC_RDBAL(n));
71*4882a593Smuzhiyun 		break;
72*4882a593Smuzhiyun 	case IGC_RDBAH(0):
73*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
74*4882a593Smuzhiyun 			regs[n] = rd32(IGC_RDBAH(n));
75*4882a593Smuzhiyun 		break;
76*4882a593Smuzhiyun 	case IGC_TDBAL(0):
77*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
78*4882a593Smuzhiyun 			regs[n] = rd32(IGC_RDBAL(n));
79*4882a593Smuzhiyun 		break;
80*4882a593Smuzhiyun 	case IGC_TDBAH(0):
81*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
82*4882a593Smuzhiyun 			regs[n] = rd32(IGC_TDBAH(n));
83*4882a593Smuzhiyun 		break;
84*4882a593Smuzhiyun 	case IGC_TDLEN(0):
85*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
86*4882a593Smuzhiyun 			regs[n] = rd32(IGC_TDLEN(n));
87*4882a593Smuzhiyun 		break;
88*4882a593Smuzhiyun 	case IGC_TDH(0):
89*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
90*4882a593Smuzhiyun 			regs[n] = rd32(IGC_TDH(n));
91*4882a593Smuzhiyun 		break;
92*4882a593Smuzhiyun 	case IGC_TDT(0):
93*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
94*4882a593Smuzhiyun 			regs[n] = rd32(IGC_TDT(n));
95*4882a593Smuzhiyun 		break;
96*4882a593Smuzhiyun 	case IGC_TXDCTL(0):
97*4882a593Smuzhiyun 		for (n = 0; n < 4; n++)
98*4882a593Smuzhiyun 			regs[n] = rd32(IGC_TXDCTL(n));
99*4882a593Smuzhiyun 		break;
100*4882a593Smuzhiyun 	default:
101*4882a593Smuzhiyun 		netdev_info(dev, "%-15s %08x\n", reginfo->name,
102*4882a593Smuzhiyun 			    rd32(reginfo->ofs));
103*4882a593Smuzhiyun 		return;
104*4882a593Smuzhiyun 	}
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun 	snprintf(rname, 16, "%s%s", reginfo->name, "[0-3]");
107*4882a593Smuzhiyun 	netdev_info(dev, "%-15s %08x %08x %08x %08x\n", rname, regs[0], regs[1],
108*4882a593Smuzhiyun 		    regs[2], regs[3]);
109*4882a593Smuzhiyun }
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun /* igc_rings_dump - Tx-rings and Rx-rings */
igc_rings_dump(struct igc_adapter * adapter)112*4882a593Smuzhiyun void igc_rings_dump(struct igc_adapter *adapter)
113*4882a593Smuzhiyun {
114*4882a593Smuzhiyun 	struct net_device *netdev = adapter->netdev;
115*4882a593Smuzhiyun 	struct my_u0 { u64 a; u64 b; } *u0;
116*4882a593Smuzhiyun 	union igc_adv_tx_desc *tx_desc;
117*4882a593Smuzhiyun 	union igc_adv_rx_desc *rx_desc;
118*4882a593Smuzhiyun 	struct igc_ring *tx_ring;
119*4882a593Smuzhiyun 	struct igc_ring *rx_ring;
120*4882a593Smuzhiyun 	u32 staterr;
121*4882a593Smuzhiyun 	u16 i, n;
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun 	if (!netif_msg_hw(adapter))
124*4882a593Smuzhiyun 		return;
125*4882a593Smuzhiyun 
126*4882a593Smuzhiyun 	netdev_info(netdev, "Device info: state %016lX trans_start %016lX\n",
127*4882a593Smuzhiyun 		    netdev->state, dev_trans_start(netdev));
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun 	/* Print TX Ring Summary */
130*4882a593Smuzhiyun 	if (!netif_running(netdev))
131*4882a593Smuzhiyun 		goto exit;
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun 	netdev_info(netdev, "TX Rings Summary\n");
134*4882a593Smuzhiyun 	netdev_info(netdev, "Queue [NTU] [NTC] [bi(ntc)->dma  ] leng ntw timestamp\n");
135*4882a593Smuzhiyun 	for (n = 0; n < adapter->num_tx_queues; n++) {
136*4882a593Smuzhiyun 		struct igc_tx_buffer *buffer_info;
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun 		tx_ring = adapter->tx_ring[n];
139*4882a593Smuzhiyun 		buffer_info = &tx_ring->tx_buffer_info[tx_ring->next_to_clean];
140*4882a593Smuzhiyun 
141*4882a593Smuzhiyun 		netdev_info(netdev, "%5d %5X %5X %016llX %04X %p %016llX\n",
142*4882a593Smuzhiyun 			    n, tx_ring->next_to_use, tx_ring->next_to_clean,
143*4882a593Smuzhiyun 			    (u64)dma_unmap_addr(buffer_info, dma),
144*4882a593Smuzhiyun 			    dma_unmap_len(buffer_info, len),
145*4882a593Smuzhiyun 			    buffer_info->next_to_watch,
146*4882a593Smuzhiyun 			    (u64)buffer_info->time_stamp);
147*4882a593Smuzhiyun 	}
148*4882a593Smuzhiyun 
149*4882a593Smuzhiyun 	/* Print TX Rings */
150*4882a593Smuzhiyun 	if (!netif_msg_tx_done(adapter))
151*4882a593Smuzhiyun 		goto rx_ring_summary;
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun 	netdev_info(netdev, "TX Rings Dump\n");
154*4882a593Smuzhiyun 
155*4882a593Smuzhiyun 	/* Transmit Descriptor Formats
156*4882a593Smuzhiyun 	 *
157*4882a593Smuzhiyun 	 * Advanced Transmit Descriptor
158*4882a593Smuzhiyun 	 *   +--------------------------------------------------------------+
159*4882a593Smuzhiyun 	 * 0 |         Buffer Address [63:0]                                |
160*4882a593Smuzhiyun 	 *   +--------------------------------------------------------------+
161*4882a593Smuzhiyun 	 * 8 | PAYLEN  | PORTS  |CC|IDX | STA | DCMD  |DTYP|MAC|RSV| DTALEN |
162*4882a593Smuzhiyun 	 *   +--------------------------------------------------------------+
163*4882a593Smuzhiyun 	 *   63      46 45    40 39 38 36 35 32 31   24             15       0
164*4882a593Smuzhiyun 	 */
165*4882a593Smuzhiyun 
166*4882a593Smuzhiyun 	for (n = 0; n < adapter->num_tx_queues; n++) {
167*4882a593Smuzhiyun 		tx_ring = adapter->tx_ring[n];
168*4882a593Smuzhiyun 		netdev_info(netdev, "------------------------------------\n");
169*4882a593Smuzhiyun 		netdev_info(netdev, "TX QUEUE INDEX = %d\n",
170*4882a593Smuzhiyun 			    tx_ring->queue_index);
171*4882a593Smuzhiyun 		netdev_info(netdev, "------------------------------------\n");
172*4882a593Smuzhiyun 		netdev_info(netdev, "T [desc]     [address 63:0  ] [PlPOCIStDDM Ln] [bi->dma       ] leng  ntw timestamp        bi->skb\n");
173*4882a593Smuzhiyun 
174*4882a593Smuzhiyun 		for (i = 0; tx_ring->desc && (i < tx_ring->count); i++) {
175*4882a593Smuzhiyun 			const char *next_desc;
176*4882a593Smuzhiyun 			struct igc_tx_buffer *buffer_info;
177*4882a593Smuzhiyun 
178*4882a593Smuzhiyun 			tx_desc = IGC_TX_DESC(tx_ring, i);
179*4882a593Smuzhiyun 			buffer_info = &tx_ring->tx_buffer_info[i];
180*4882a593Smuzhiyun 			u0 = (struct my_u0 *)tx_desc;
181*4882a593Smuzhiyun 			if (i == tx_ring->next_to_use &&
182*4882a593Smuzhiyun 			    i == tx_ring->next_to_clean)
183*4882a593Smuzhiyun 				next_desc = " NTC/U";
184*4882a593Smuzhiyun 			else if (i == tx_ring->next_to_use)
185*4882a593Smuzhiyun 				next_desc = " NTU";
186*4882a593Smuzhiyun 			else if (i == tx_ring->next_to_clean)
187*4882a593Smuzhiyun 				next_desc = " NTC";
188*4882a593Smuzhiyun 			else
189*4882a593Smuzhiyun 				next_desc = "";
190*4882a593Smuzhiyun 
191*4882a593Smuzhiyun 			netdev_info(netdev, "T [0x%03X]    %016llX %016llX %016llX %04X  %p %016llX %p%s\n",
192*4882a593Smuzhiyun 				    i, le64_to_cpu(u0->a),
193*4882a593Smuzhiyun 				    le64_to_cpu(u0->b),
194*4882a593Smuzhiyun 				    (u64)dma_unmap_addr(buffer_info, dma),
195*4882a593Smuzhiyun 				    dma_unmap_len(buffer_info, len),
196*4882a593Smuzhiyun 				    buffer_info->next_to_watch,
197*4882a593Smuzhiyun 				    (u64)buffer_info->time_stamp,
198*4882a593Smuzhiyun 				    buffer_info->skb, next_desc);
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun 			if (netif_msg_pktdata(adapter) && buffer_info->skb)
201*4882a593Smuzhiyun 				print_hex_dump(KERN_INFO, "",
202*4882a593Smuzhiyun 					       DUMP_PREFIX_ADDRESS,
203*4882a593Smuzhiyun 					       16, 1, buffer_info->skb->data,
204*4882a593Smuzhiyun 					       dma_unmap_len(buffer_info, len),
205*4882a593Smuzhiyun 					       true);
206*4882a593Smuzhiyun 		}
207*4882a593Smuzhiyun 	}
208*4882a593Smuzhiyun 
209*4882a593Smuzhiyun 	/* Print RX Rings Summary */
210*4882a593Smuzhiyun rx_ring_summary:
211*4882a593Smuzhiyun 	netdev_info(netdev, "RX Rings Summary\n");
212*4882a593Smuzhiyun 	netdev_info(netdev, "Queue [NTU] [NTC]\n");
213*4882a593Smuzhiyun 	for (n = 0; n < adapter->num_rx_queues; n++) {
214*4882a593Smuzhiyun 		rx_ring = adapter->rx_ring[n];
215*4882a593Smuzhiyun 		netdev_info(netdev, "%5d %5X %5X\n", n, rx_ring->next_to_use,
216*4882a593Smuzhiyun 			    rx_ring->next_to_clean);
217*4882a593Smuzhiyun 	}
218*4882a593Smuzhiyun 
219*4882a593Smuzhiyun 	/* Print RX Rings */
220*4882a593Smuzhiyun 	if (!netif_msg_rx_status(adapter))
221*4882a593Smuzhiyun 		goto exit;
222*4882a593Smuzhiyun 
223*4882a593Smuzhiyun 	netdev_info(netdev, "RX Rings Dump\n");
224*4882a593Smuzhiyun 
225*4882a593Smuzhiyun 	/* Advanced Receive Descriptor (Read) Format
226*4882a593Smuzhiyun 	 *    63                                           1        0
227*4882a593Smuzhiyun 	 *    +-----------------------------------------------------+
228*4882a593Smuzhiyun 	 *  0 |       Packet Buffer Address [63:1]           |A0/NSE|
229*4882a593Smuzhiyun 	 *    +----------------------------------------------+------+
230*4882a593Smuzhiyun 	 *  8 |       Header Buffer Address [63:1]           |  DD  |
231*4882a593Smuzhiyun 	 *    +-----------------------------------------------------+
232*4882a593Smuzhiyun 	 *
233*4882a593Smuzhiyun 	 *
234*4882a593Smuzhiyun 	 * Advanced Receive Descriptor (Write-Back) Format
235*4882a593Smuzhiyun 	 *
236*4882a593Smuzhiyun 	 *   63       48 47    32 31  30      21 20 17 16   4 3     0
237*4882a593Smuzhiyun 	 *   +------------------------------------------------------+
238*4882a593Smuzhiyun 	 * 0 | Packet     IP     |SPH| HDR_LEN   | RSV|Packet|  RSS |
239*4882a593Smuzhiyun 	 *   | Checksum   Ident  |   |           |    | Type | Type |
240*4882a593Smuzhiyun 	 *   +------------------------------------------------------+
241*4882a593Smuzhiyun 	 * 8 | VLAN Tag | Length | Extended Error | Extended Status |
242*4882a593Smuzhiyun 	 *   +------------------------------------------------------+
243*4882a593Smuzhiyun 	 *   63       48 47    32 31            20 19               0
244*4882a593Smuzhiyun 	 */
245*4882a593Smuzhiyun 
246*4882a593Smuzhiyun 	for (n = 0; n < adapter->num_rx_queues; n++) {
247*4882a593Smuzhiyun 		rx_ring = adapter->rx_ring[n];
248*4882a593Smuzhiyun 		netdev_info(netdev, "------------------------------------\n");
249*4882a593Smuzhiyun 		netdev_info(netdev, "RX QUEUE INDEX = %d\n",
250*4882a593Smuzhiyun 			    rx_ring->queue_index);
251*4882a593Smuzhiyun 		netdev_info(netdev, "------------------------------------\n");
252*4882a593Smuzhiyun 		netdev_info(netdev, "R  [desc]      [ PktBuf     A0] [  HeadBuf   DD] [bi->dma       ] [bi->skb] <-- Adv Rx Read format\n");
253*4882a593Smuzhiyun 		netdev_info(netdev, "RWB[desc]      [PcsmIpSHl PtRs] [vl er S cks ln] ---------------- [bi->skb] <-- Adv Rx Write-Back format\n");
254*4882a593Smuzhiyun 
255*4882a593Smuzhiyun 		for (i = 0; i < rx_ring->count; i++) {
256*4882a593Smuzhiyun 			const char *next_desc;
257*4882a593Smuzhiyun 			struct igc_rx_buffer *buffer_info;
258*4882a593Smuzhiyun 
259*4882a593Smuzhiyun 			buffer_info = &rx_ring->rx_buffer_info[i];
260*4882a593Smuzhiyun 			rx_desc = IGC_RX_DESC(rx_ring, i);
261*4882a593Smuzhiyun 			u0 = (struct my_u0 *)rx_desc;
262*4882a593Smuzhiyun 			staterr = le32_to_cpu(rx_desc->wb.upper.status_error);
263*4882a593Smuzhiyun 
264*4882a593Smuzhiyun 			if (i == rx_ring->next_to_use)
265*4882a593Smuzhiyun 				next_desc = " NTU";
266*4882a593Smuzhiyun 			else if (i == rx_ring->next_to_clean)
267*4882a593Smuzhiyun 				next_desc = " NTC";
268*4882a593Smuzhiyun 			else
269*4882a593Smuzhiyun 				next_desc = "";
270*4882a593Smuzhiyun 
271*4882a593Smuzhiyun 			if (staterr & IGC_RXD_STAT_DD) {
272*4882a593Smuzhiyun 				/* Descriptor Done */
273*4882a593Smuzhiyun 				netdev_info(netdev, "%s[0x%03X]     %016llX %016llX ---------------- %s\n",
274*4882a593Smuzhiyun 					    "RWB", i,
275*4882a593Smuzhiyun 					    le64_to_cpu(u0->a),
276*4882a593Smuzhiyun 					    le64_to_cpu(u0->b),
277*4882a593Smuzhiyun 					    next_desc);
278*4882a593Smuzhiyun 			} else {
279*4882a593Smuzhiyun 				netdev_info(netdev, "%s[0x%03X]     %016llX %016llX %016llX %s\n",
280*4882a593Smuzhiyun 					    "R  ", i,
281*4882a593Smuzhiyun 					    le64_to_cpu(u0->a),
282*4882a593Smuzhiyun 					    le64_to_cpu(u0->b),
283*4882a593Smuzhiyun 					    (u64)buffer_info->dma,
284*4882a593Smuzhiyun 					    next_desc);
285*4882a593Smuzhiyun 
286*4882a593Smuzhiyun 				if (netif_msg_pktdata(adapter) &&
287*4882a593Smuzhiyun 				    buffer_info->dma && buffer_info->page) {
288*4882a593Smuzhiyun 					print_hex_dump(KERN_INFO, "",
289*4882a593Smuzhiyun 						       DUMP_PREFIX_ADDRESS,
290*4882a593Smuzhiyun 						       16, 1,
291*4882a593Smuzhiyun 						       page_address
292*4882a593Smuzhiyun 						       (buffer_info->page) +
293*4882a593Smuzhiyun 						       buffer_info->page_offset,
294*4882a593Smuzhiyun 						       igc_rx_bufsz(rx_ring),
295*4882a593Smuzhiyun 						       true);
296*4882a593Smuzhiyun 				}
297*4882a593Smuzhiyun 			}
298*4882a593Smuzhiyun 		}
299*4882a593Smuzhiyun 	}
300*4882a593Smuzhiyun 
301*4882a593Smuzhiyun exit:
302*4882a593Smuzhiyun 	return;
303*4882a593Smuzhiyun }
304*4882a593Smuzhiyun 
305*4882a593Smuzhiyun /* igc_regs_dump - registers dump */
igc_regs_dump(struct igc_adapter * adapter)306*4882a593Smuzhiyun void igc_regs_dump(struct igc_adapter *adapter)
307*4882a593Smuzhiyun {
308*4882a593Smuzhiyun 	struct igc_hw *hw = &adapter->hw;
309*4882a593Smuzhiyun 	struct igc_reg_info *reginfo;
310*4882a593Smuzhiyun 
311*4882a593Smuzhiyun 	/* Print Registers */
312*4882a593Smuzhiyun 	netdev_info(adapter->netdev, "Register Dump\n");
313*4882a593Smuzhiyun 	netdev_info(adapter->netdev, "Register Name   Value\n");
314*4882a593Smuzhiyun 	for (reginfo = (struct igc_reg_info *)igc_reg_info_tbl;
315*4882a593Smuzhiyun 	     reginfo->name; reginfo++) {
316*4882a593Smuzhiyun 		igc_regdump(hw, reginfo);
317*4882a593Smuzhiyun 	}
318*4882a593Smuzhiyun }
319