1 // SPDX-License-Identifier: GPL-2.0 2 /* Marvell RVU Admin Function driver 3 * 4 * Copyright (C) 2019 Marvell. 5 * 6 */ 7 8 #ifdef CONFIG_DEBUG_FS 9 10 #include <linux/fs.h> 11 #include <linux/debugfs.h> 12 #include <linux/module.h> 13 #include <linux/pci.h> 14 15 #include "rvu_struct.h" 16 #include "rvu_reg.h" 17 #include "rvu.h" 18 #include "cgx.h" 19 #include "lmac_common.h" 20 #include "npc.h" 21 #include "rvu_npc_hash.h" 22 #include "mcs.h" 23 24 #define DEBUGFS_DIR_NAME "octeontx2" 25 26 enum { 27 CGX_STAT0, 28 CGX_STAT1, 29 CGX_STAT2, 30 CGX_STAT3, 31 CGX_STAT4, 32 CGX_STAT5, 33 CGX_STAT6, 34 CGX_STAT7, 35 CGX_STAT8, 36 CGX_STAT9, 37 CGX_STAT10, 38 CGX_STAT11, 39 CGX_STAT12, 40 CGX_STAT13, 41 CGX_STAT14, 42 CGX_STAT15, 43 CGX_STAT16, 44 CGX_STAT17, 45 CGX_STAT18, 46 }; 47 48 /* NIX TX stats */ 49 enum nix_stat_lf_tx { 50 TX_UCAST = 0x0, 51 TX_BCAST = 0x1, 52 TX_MCAST = 0x2, 53 TX_DROP = 0x3, 54 TX_OCTS = 0x4, 55 TX_STATS_ENUM_LAST, 56 }; 57 58 /* NIX RX stats */ 59 enum nix_stat_lf_rx { 60 RX_OCTS = 0x0, 61 RX_UCAST = 0x1, 62 RX_BCAST = 0x2, 63 RX_MCAST = 0x3, 64 RX_DROP = 0x4, 65 RX_DROP_OCTS = 0x5, 66 RX_FCS = 0x6, 67 RX_ERR = 0x7, 68 RX_DRP_BCAST = 0x8, 69 RX_DRP_MCAST = 0x9, 70 RX_DRP_L3BCAST = 0xa, 71 RX_DRP_L3MCAST = 0xb, 72 RX_STATS_ENUM_LAST, 73 }; 74 75 static char *cgx_rx_stats_fields[] = { 76 [CGX_STAT0] = "Received packets", 77 [CGX_STAT1] = "Octets of received packets", 78 [CGX_STAT2] = "Received PAUSE packets", 79 [CGX_STAT3] = "Received PAUSE and control packets", 80 [CGX_STAT4] = "Filtered DMAC0 (NIX-bound) packets", 81 [CGX_STAT5] = "Filtered DMAC0 (NIX-bound) octets", 82 [CGX_STAT6] = "Packets dropped due to RX FIFO full", 83 [CGX_STAT7] = "Octets dropped due to RX FIFO full", 84 [CGX_STAT8] = "Error packets", 85 [CGX_STAT9] = "Filtered DMAC1 (NCSI-bound) packets", 86 [CGX_STAT10] = "Filtered DMAC1 (NCSI-bound) octets", 87 [CGX_STAT11] = "NCSI-bound packets dropped", 88 [CGX_STAT12] = "NCSI-bound octets dropped", 89 }; 90 91 static char *cgx_tx_stats_fields[] = { 92 [CGX_STAT0] = "Packets dropped due to excessive collisions", 93 [CGX_STAT1] = "Packets dropped due to excessive deferral", 94 [CGX_STAT2] = "Multiple collisions before successful transmission", 95 [CGX_STAT3] = "Single collisions before successful transmission", 96 [CGX_STAT4] = "Total octets sent on the interface", 97 [CGX_STAT5] = "Total frames sent on the interface", 98 [CGX_STAT6] = "Packets sent with an octet count < 64", 99 [CGX_STAT7] = "Packets sent with an octet count == 64", 100 [CGX_STAT8] = "Packets sent with an octet count of 65-127", 101 [CGX_STAT9] = "Packets sent with an octet count of 128-255", 102 [CGX_STAT10] = "Packets sent with an octet count of 256-511", 103 [CGX_STAT11] = "Packets sent with an octet count of 512-1023", 104 [CGX_STAT12] = "Packets sent with an octet count of 1024-1518", 105 [CGX_STAT13] = "Packets sent with an octet count of > 1518", 106 [CGX_STAT14] = "Packets sent to a broadcast DMAC", 107 [CGX_STAT15] = "Packets sent to the multicast DMAC", 108 [CGX_STAT16] = "Transmit underflow and were truncated", 109 [CGX_STAT17] = "Control/PAUSE packets sent", 110 }; 111 112 static char *rpm_rx_stats_fields[] = { 113 "Octets of received packets", 114 "Octets of received packets with out error", 115 "Received packets with alignment errors", 116 "Control/PAUSE packets received", 117 "Packets received with Frame too long Errors", 118 "Packets received with a1nrange length Errors", 119 "Received packets", 120 "Packets received with FrameCheckSequenceErrors", 121 "Packets received with VLAN header", 122 "Error packets", 123 "Packets received with unicast DMAC", 124 "Packets received with multicast DMAC", 125 "Packets received with broadcast DMAC", 126 "Dropped packets", 127 "Total frames received on interface", 128 "Packets received with an octet count < 64", 129 "Packets received with an octet count == 64", 130 "Packets received with an octet count of 65-127", 131 "Packets received with an octet count of 128-255", 132 "Packets received with an octet count of 256-511", 133 "Packets received with an octet count of 512-1023", 134 "Packets received with an octet count of 1024-1518", 135 "Packets received with an octet count of > 1518", 136 "Oversized Packets", 137 "Jabber Packets", 138 "Fragmented Packets", 139 "CBFC(class based flow control) pause frames received for class 0", 140 "CBFC pause frames received for class 1", 141 "CBFC pause frames received for class 2", 142 "CBFC pause frames received for class 3", 143 "CBFC pause frames received for class 4", 144 "CBFC pause frames received for class 5", 145 "CBFC pause frames received for class 6", 146 "CBFC pause frames received for class 7", 147 "CBFC pause frames received for class 8", 148 "CBFC pause frames received for class 9", 149 "CBFC pause frames received for class 10", 150 "CBFC pause frames received for class 11", 151 "CBFC pause frames received for class 12", 152 "CBFC pause frames received for class 13", 153 "CBFC pause frames received for class 14", 154 "CBFC pause frames received for class 15", 155 "MAC control packets received", 156 }; 157 158 static char *rpm_tx_stats_fields[] = { 159 "Total octets sent on the interface", 160 "Total octets transmitted OK", 161 "Control/Pause frames sent", 162 "Total frames transmitted OK", 163 "Total frames sent with VLAN header", 164 "Error Packets", 165 "Packets sent to unicast DMAC", 166 "Packets sent to the multicast DMAC", 167 "Packets sent to a broadcast DMAC", 168 "Packets sent with an octet count == 64", 169 "Packets sent with an octet count of 65-127", 170 "Packets sent with an octet count of 128-255", 171 "Packets sent with an octet count of 256-511", 172 "Packets sent with an octet count of 512-1023", 173 "Packets sent with an octet count of 1024-1518", 174 "Packets sent with an octet count of > 1518", 175 "CBFC(class based flow control) pause frames transmitted for class 0", 176 "CBFC pause frames transmitted for class 1", 177 "CBFC pause frames transmitted for class 2", 178 "CBFC pause frames transmitted for class 3", 179 "CBFC pause frames transmitted for class 4", 180 "CBFC pause frames transmitted for class 5", 181 "CBFC pause frames transmitted for class 6", 182 "CBFC pause frames transmitted for class 7", 183 "CBFC pause frames transmitted for class 8", 184 "CBFC pause frames transmitted for class 9", 185 "CBFC pause frames transmitted for class 10", 186 "CBFC pause frames transmitted for class 11", 187 "CBFC pause frames transmitted for class 12", 188 "CBFC pause frames transmitted for class 13", 189 "CBFC pause frames transmitted for class 14", 190 "CBFC pause frames transmitted for class 15", 191 "MAC control packets sent", 192 "Total frames sent on the interface" 193 }; 194 195 enum cpt_eng_type { 196 CPT_AE_TYPE = 1, 197 CPT_SE_TYPE = 2, 198 CPT_IE_TYPE = 3, 199 }; 200 201 #define rvu_dbg_NULL NULL 202 #define rvu_dbg_open_NULL NULL 203 204 #define RVU_DEBUG_SEQ_FOPS(name, read_op, write_op) \ 205 static int rvu_dbg_open_##name(struct inode *inode, struct file *file) \ 206 { \ 207 return single_open(file, rvu_dbg_##read_op, inode->i_private); \ 208 } \ 209 static const struct file_operations rvu_dbg_##name##_fops = { \ 210 .owner = THIS_MODULE, \ 211 .open = rvu_dbg_open_##name, \ 212 .read = seq_read, \ 213 .write = rvu_dbg_##write_op, \ 214 .llseek = seq_lseek, \ 215 .release = single_release, \ 216 } 217 218 #define RVU_DEBUG_FOPS(name, read_op, write_op) \ 219 static const struct file_operations rvu_dbg_##name##_fops = { \ 220 .owner = THIS_MODULE, \ 221 .open = simple_open, \ 222 .read = rvu_dbg_##read_op, \ 223 .write = rvu_dbg_##write_op \ 224 } 225 226 static void print_nix_qsize(struct seq_file *filp, struct rvu_pfvf *pfvf); 227 228 static int rvu_dbg_mcs_port_stats_display(struct seq_file *filp, void *unused, int dir) 229 { 230 struct mcs *mcs = filp->private; 231 struct mcs_port_stats stats; 232 int lmac; 233 234 seq_puts(filp, "\n port stats\n"); 235 mutex_lock(&mcs->stats_lock); 236 for_each_set_bit(lmac, &mcs->hw->lmac_bmap, mcs->hw->lmac_cnt) { 237 mcs_get_port_stats(mcs, &stats, lmac, dir); 238 seq_printf(filp, "port%d: Tcam Miss: %lld\n", lmac, stats.tcam_miss_cnt); 239 seq_printf(filp, "port%d: Parser errors: %lld\n", lmac, stats.parser_err_cnt); 240 241 if (dir == MCS_RX && mcs->hw->mcs_blks > 1) 242 seq_printf(filp, "port%d: Preempt error: %lld\n", lmac, 243 stats.preempt_err_cnt); 244 if (dir == MCS_TX) 245 seq_printf(filp, "port%d: Sectag insert error: %lld\n", lmac, 246 stats.sectag_insert_err_cnt); 247 } 248 mutex_unlock(&mcs->stats_lock); 249 return 0; 250 } 251 252 static int rvu_dbg_mcs_rx_port_stats_display(struct seq_file *filp, void *unused) 253 { 254 return rvu_dbg_mcs_port_stats_display(filp, unused, MCS_RX); 255 } 256 257 RVU_DEBUG_SEQ_FOPS(mcs_rx_port_stats, mcs_rx_port_stats_display, NULL); 258 259 static int rvu_dbg_mcs_tx_port_stats_display(struct seq_file *filp, void *unused) 260 { 261 return rvu_dbg_mcs_port_stats_display(filp, unused, MCS_TX); 262 } 263 264 RVU_DEBUG_SEQ_FOPS(mcs_tx_port_stats, mcs_tx_port_stats_display, NULL); 265 266 static int rvu_dbg_mcs_sa_stats_display(struct seq_file *filp, void *unused, int dir) 267 { 268 struct mcs *mcs = filp->private; 269 struct mcs_sa_stats stats; 270 struct rsrc_bmap *map; 271 int sa_id; 272 273 if (dir == MCS_TX) { 274 map = &mcs->tx.sa; 275 mutex_lock(&mcs->stats_lock); 276 for_each_set_bit(sa_id, map->bmap, mcs->hw->sa_entries) { 277 seq_puts(filp, "\n TX SA stats\n"); 278 mcs_get_sa_stats(mcs, &stats, sa_id, MCS_TX); 279 seq_printf(filp, "sa%d: Pkts encrypted: %lld\n", sa_id, 280 stats.pkt_encrypt_cnt); 281 282 seq_printf(filp, "sa%d: Pkts protected: %lld\n", sa_id, 283 stats.pkt_protected_cnt); 284 } 285 mutex_unlock(&mcs->stats_lock); 286 return 0; 287 } 288 289 /* RX stats */ 290 map = &mcs->rx.sa; 291 mutex_lock(&mcs->stats_lock); 292 for_each_set_bit(sa_id, map->bmap, mcs->hw->sa_entries) { 293 seq_puts(filp, "\n RX SA stats\n"); 294 mcs_get_sa_stats(mcs, &stats, sa_id, MCS_RX); 295 seq_printf(filp, "sa%d: Invalid pkts: %lld\n", sa_id, stats.pkt_invalid_cnt); 296 seq_printf(filp, "sa%d: Pkts no sa error: %lld\n", sa_id, stats.pkt_nosaerror_cnt); 297 seq_printf(filp, "sa%d: Pkts not valid: %lld\n", sa_id, stats.pkt_notvalid_cnt); 298 seq_printf(filp, "sa%d: Pkts ok: %lld\n", sa_id, stats.pkt_ok_cnt); 299 seq_printf(filp, "sa%d: Pkts no sa: %lld\n", sa_id, stats.pkt_nosa_cnt); 300 } 301 mutex_unlock(&mcs->stats_lock); 302 return 0; 303 } 304 305 static int rvu_dbg_mcs_rx_sa_stats_display(struct seq_file *filp, void *unused) 306 { 307 return rvu_dbg_mcs_sa_stats_display(filp, unused, MCS_RX); 308 } 309 310 RVU_DEBUG_SEQ_FOPS(mcs_rx_sa_stats, mcs_rx_sa_stats_display, NULL); 311 312 static int rvu_dbg_mcs_tx_sa_stats_display(struct seq_file *filp, void *unused) 313 { 314 return rvu_dbg_mcs_sa_stats_display(filp, unused, MCS_TX); 315 } 316 317 RVU_DEBUG_SEQ_FOPS(mcs_tx_sa_stats, mcs_tx_sa_stats_display, NULL); 318 319 static int rvu_dbg_mcs_tx_sc_stats_display(struct seq_file *filp, void *unused) 320 { 321 struct mcs *mcs = filp->private; 322 struct mcs_sc_stats stats; 323 struct rsrc_bmap *map; 324 int sc_id; 325 326 map = &mcs->tx.sc; 327 seq_puts(filp, "\n SC stats\n"); 328 329 mutex_lock(&mcs->stats_lock); 330 for_each_set_bit(sc_id, map->bmap, mcs->hw->sc_entries) { 331 mcs_get_sc_stats(mcs, &stats, sc_id, MCS_TX); 332 seq_printf(filp, "\n=======sc%d======\n\n", sc_id); 333 seq_printf(filp, "sc%d: Pkts encrypted: %lld\n", sc_id, stats.pkt_encrypt_cnt); 334 seq_printf(filp, "sc%d: Pkts protected: %lld\n", sc_id, stats.pkt_protected_cnt); 335 336 if (mcs->hw->mcs_blks == 1) { 337 seq_printf(filp, "sc%d: Octets encrypted: %lld\n", sc_id, 338 stats.octet_encrypt_cnt); 339 seq_printf(filp, "sc%d: Octets protected: %lld\n", sc_id, 340 stats.octet_protected_cnt); 341 } 342 } 343 mutex_unlock(&mcs->stats_lock); 344 return 0; 345 } 346 347 RVU_DEBUG_SEQ_FOPS(mcs_tx_sc_stats, mcs_tx_sc_stats_display, NULL); 348 349 static int rvu_dbg_mcs_rx_sc_stats_display(struct seq_file *filp, void *unused) 350 { 351 struct mcs *mcs = filp->private; 352 struct mcs_sc_stats stats; 353 struct rsrc_bmap *map; 354 int sc_id; 355 356 map = &mcs->rx.sc; 357 seq_puts(filp, "\n SC stats\n"); 358 359 mutex_lock(&mcs->stats_lock); 360 for_each_set_bit(sc_id, map->bmap, mcs->hw->sc_entries) { 361 mcs_get_sc_stats(mcs, &stats, sc_id, MCS_RX); 362 seq_printf(filp, "\n=======sc%d======\n\n", sc_id); 363 seq_printf(filp, "sc%d: Cam hits: %lld\n", sc_id, stats.hit_cnt); 364 seq_printf(filp, "sc%d: Invalid pkts: %lld\n", sc_id, stats.pkt_invalid_cnt); 365 seq_printf(filp, "sc%d: Late pkts: %lld\n", sc_id, stats.pkt_late_cnt); 366 seq_printf(filp, "sc%d: Notvalid pkts: %lld\n", sc_id, stats.pkt_notvalid_cnt); 367 seq_printf(filp, "sc%d: Unchecked pkts: %lld\n", sc_id, stats.pkt_unchecked_cnt); 368 369 if (mcs->hw->mcs_blks > 1) { 370 seq_printf(filp, "sc%d: Delay pkts: %lld\n", sc_id, stats.pkt_delay_cnt); 371 seq_printf(filp, "sc%d: Pkts ok: %lld\n", sc_id, stats.pkt_ok_cnt); 372 } 373 if (mcs->hw->mcs_blks == 1) { 374 seq_printf(filp, "sc%d: Octets decrypted: %lld\n", sc_id, 375 stats.octet_decrypt_cnt); 376 seq_printf(filp, "sc%d: Octets validated: %lld\n", sc_id, 377 stats.octet_validate_cnt); 378 } 379 } 380 mutex_unlock(&mcs->stats_lock); 381 return 0; 382 } 383 384 RVU_DEBUG_SEQ_FOPS(mcs_rx_sc_stats, mcs_rx_sc_stats_display, NULL); 385 386 static int rvu_dbg_mcs_flowid_stats_display(struct seq_file *filp, void *unused, int dir) 387 { 388 struct mcs *mcs = filp->private; 389 struct mcs_flowid_stats stats; 390 struct rsrc_bmap *map; 391 int flow_id; 392 393 seq_puts(filp, "\n Flowid stats\n"); 394 395 if (dir == MCS_RX) 396 map = &mcs->rx.flow_ids; 397 else 398 map = &mcs->tx.flow_ids; 399 400 mutex_lock(&mcs->stats_lock); 401 for_each_set_bit(flow_id, map->bmap, mcs->hw->tcam_entries) { 402 mcs_get_flowid_stats(mcs, &stats, flow_id, dir); 403 seq_printf(filp, "Flowid%d: Hit:%lld\n", flow_id, stats.tcam_hit_cnt); 404 } 405 mutex_unlock(&mcs->stats_lock); 406 return 0; 407 } 408 409 static int rvu_dbg_mcs_tx_flowid_stats_display(struct seq_file *filp, void *unused) 410 { 411 return rvu_dbg_mcs_flowid_stats_display(filp, unused, MCS_TX); 412 } 413 414 RVU_DEBUG_SEQ_FOPS(mcs_tx_flowid_stats, mcs_tx_flowid_stats_display, NULL); 415 416 static int rvu_dbg_mcs_rx_flowid_stats_display(struct seq_file *filp, void *unused) 417 { 418 return rvu_dbg_mcs_flowid_stats_display(filp, unused, MCS_RX); 419 } 420 421 RVU_DEBUG_SEQ_FOPS(mcs_rx_flowid_stats, mcs_rx_flowid_stats_display, NULL); 422 423 static int rvu_dbg_mcs_tx_secy_stats_display(struct seq_file *filp, void *unused) 424 { 425 struct mcs *mcs = filp->private; 426 struct mcs_secy_stats stats; 427 struct rsrc_bmap *map; 428 int secy_id; 429 430 map = &mcs->tx.secy; 431 seq_puts(filp, "\n MCS TX secy stats\n"); 432 433 mutex_lock(&mcs->stats_lock); 434 for_each_set_bit(secy_id, map->bmap, mcs->hw->secy_entries) { 435 mcs_get_tx_secy_stats(mcs, &stats, secy_id); 436 seq_printf(filp, "\n=======Secy%d======\n\n", secy_id); 437 seq_printf(filp, "secy%d: Ctrl bcast pkts: %lld\n", secy_id, 438 stats.ctl_pkt_bcast_cnt); 439 seq_printf(filp, "secy%d: Ctrl Mcast pkts: %lld\n", secy_id, 440 stats.ctl_pkt_mcast_cnt); 441 seq_printf(filp, "secy%d: Ctrl ucast pkts: %lld\n", secy_id, 442 stats.ctl_pkt_ucast_cnt); 443 seq_printf(filp, "secy%d: Ctrl octets: %lld\n", secy_id, stats.ctl_octet_cnt); 444 seq_printf(filp, "secy%d: Unctrl bcast cnt: %lld\n", secy_id, 445 stats.unctl_pkt_bcast_cnt); 446 seq_printf(filp, "secy%d: Unctrl mcast pkts: %lld\n", secy_id, 447 stats.unctl_pkt_mcast_cnt); 448 seq_printf(filp, "secy%d: Unctrl ucast pkts: %lld\n", secy_id, 449 stats.unctl_pkt_ucast_cnt); 450 seq_printf(filp, "secy%d: Unctrl octets: %lld\n", secy_id, stats.unctl_octet_cnt); 451 seq_printf(filp, "secy%d: Octet encrypted: %lld\n", secy_id, 452 stats.octet_encrypted_cnt); 453 seq_printf(filp, "secy%d: octet protected: %lld\n", secy_id, 454 stats.octet_protected_cnt); 455 seq_printf(filp, "secy%d: Pkts on active sa: %lld\n", secy_id, 456 stats.pkt_noactivesa_cnt); 457 seq_printf(filp, "secy%d: Pkts too long: %lld\n", secy_id, stats.pkt_toolong_cnt); 458 seq_printf(filp, "secy%d: Pkts untagged: %lld\n", secy_id, stats.pkt_untagged_cnt); 459 } 460 mutex_unlock(&mcs->stats_lock); 461 return 0; 462 } 463 464 RVU_DEBUG_SEQ_FOPS(mcs_tx_secy_stats, mcs_tx_secy_stats_display, NULL); 465 466 static int rvu_dbg_mcs_rx_secy_stats_display(struct seq_file *filp, void *unused) 467 { 468 struct mcs *mcs = filp->private; 469 struct mcs_secy_stats stats; 470 struct rsrc_bmap *map; 471 int secy_id; 472 473 map = &mcs->rx.secy; 474 seq_puts(filp, "\n MCS secy stats\n"); 475 476 mutex_lock(&mcs->stats_lock); 477 for_each_set_bit(secy_id, map->bmap, mcs->hw->secy_entries) { 478 mcs_get_rx_secy_stats(mcs, &stats, secy_id); 479 seq_printf(filp, "\n=======Secy%d======\n\n", secy_id); 480 seq_printf(filp, "secy%d: Ctrl bcast pkts: %lld\n", secy_id, 481 stats.ctl_pkt_bcast_cnt); 482 seq_printf(filp, "secy%d: Ctrl Mcast pkts: %lld\n", secy_id, 483 stats.ctl_pkt_mcast_cnt); 484 seq_printf(filp, "secy%d: Ctrl ucast pkts: %lld\n", secy_id, 485 stats.ctl_pkt_ucast_cnt); 486 seq_printf(filp, "secy%d: Ctrl octets: %lld\n", secy_id, stats.ctl_octet_cnt); 487 seq_printf(filp, "secy%d: Unctrl bcast cnt: %lld\n", secy_id, 488 stats.unctl_pkt_bcast_cnt); 489 seq_printf(filp, "secy%d: Unctrl mcast pkts: %lld\n", secy_id, 490 stats.unctl_pkt_mcast_cnt); 491 seq_printf(filp, "secy%d: Unctrl ucast pkts: %lld\n", secy_id, 492 stats.unctl_pkt_ucast_cnt); 493 seq_printf(filp, "secy%d: Unctrl octets: %lld\n", secy_id, stats.unctl_octet_cnt); 494 seq_printf(filp, "secy%d: Octet decrypted: %lld\n", secy_id, 495 stats.octet_decrypted_cnt); 496 seq_printf(filp, "secy%d: octet validated: %lld\n", secy_id, 497 stats.octet_validated_cnt); 498 seq_printf(filp, "secy%d: Pkts on disable port: %lld\n", secy_id, 499 stats.pkt_port_disabled_cnt); 500 seq_printf(filp, "secy%d: Pkts with badtag: %lld\n", secy_id, stats.pkt_badtag_cnt); 501 seq_printf(filp, "secy%d: Pkts with no SA(sectag.tci.c=0): %lld\n", secy_id, 502 stats.pkt_nosa_cnt); 503 seq_printf(filp, "secy%d: Pkts with nosaerror: %lld\n", secy_id, 504 stats.pkt_nosaerror_cnt); 505 seq_printf(filp, "secy%d: Tagged ctrl pkts: %lld\n", secy_id, 506 stats.pkt_tagged_ctl_cnt); 507 seq_printf(filp, "secy%d: Untaged pkts: %lld\n", secy_id, stats.pkt_untaged_cnt); 508 seq_printf(filp, "secy%d: Ctrl pkts: %lld\n", secy_id, stats.pkt_ctl_cnt); 509 if (mcs->hw->mcs_blks > 1) 510 seq_printf(filp, "secy%d: pkts notag: %lld\n", secy_id, 511 stats.pkt_notag_cnt); 512 } 513 mutex_unlock(&mcs->stats_lock); 514 return 0; 515 } 516 517 RVU_DEBUG_SEQ_FOPS(mcs_rx_secy_stats, mcs_rx_secy_stats_display, NULL); 518 519 static void rvu_dbg_mcs_init(struct rvu *rvu) 520 { 521 struct mcs *mcs; 522 char dname[10]; 523 int i; 524 525 if (!rvu->mcs_blk_cnt) 526 return; 527 528 rvu->rvu_dbg.mcs_root = debugfs_create_dir("mcs", rvu->rvu_dbg.root); 529 530 for (i = 0; i < rvu->mcs_blk_cnt; i++) { 531 mcs = mcs_get_pdata(i); 532 533 sprintf(dname, "mcs%d", i); 534 rvu->rvu_dbg.mcs = debugfs_create_dir(dname, 535 rvu->rvu_dbg.mcs_root); 536 537 rvu->rvu_dbg.mcs_rx = debugfs_create_dir("rx_stats", rvu->rvu_dbg.mcs); 538 539 debugfs_create_file("flowid", 0600, rvu->rvu_dbg.mcs_rx, mcs, 540 &rvu_dbg_mcs_rx_flowid_stats_fops); 541 542 debugfs_create_file("secy", 0600, rvu->rvu_dbg.mcs_rx, mcs, 543 &rvu_dbg_mcs_rx_secy_stats_fops); 544 545 debugfs_create_file("sc", 0600, rvu->rvu_dbg.mcs_rx, mcs, 546 &rvu_dbg_mcs_rx_sc_stats_fops); 547 548 debugfs_create_file("sa", 0600, rvu->rvu_dbg.mcs_rx, mcs, 549 &rvu_dbg_mcs_rx_sa_stats_fops); 550 551 debugfs_create_file("port", 0600, rvu->rvu_dbg.mcs_rx, mcs, 552 &rvu_dbg_mcs_rx_port_stats_fops); 553 554 rvu->rvu_dbg.mcs_tx = debugfs_create_dir("tx_stats", rvu->rvu_dbg.mcs); 555 556 debugfs_create_file("flowid", 0600, rvu->rvu_dbg.mcs_tx, mcs, 557 &rvu_dbg_mcs_tx_flowid_stats_fops); 558 559 debugfs_create_file("secy", 0600, rvu->rvu_dbg.mcs_tx, mcs, 560 &rvu_dbg_mcs_tx_secy_stats_fops); 561 562 debugfs_create_file("sc", 0600, rvu->rvu_dbg.mcs_tx, mcs, 563 &rvu_dbg_mcs_tx_sc_stats_fops); 564 565 debugfs_create_file("sa", 0600, rvu->rvu_dbg.mcs_tx, mcs, 566 &rvu_dbg_mcs_tx_sa_stats_fops); 567 568 debugfs_create_file("port", 0600, rvu->rvu_dbg.mcs_tx, mcs, 569 &rvu_dbg_mcs_tx_port_stats_fops); 570 } 571 } 572 573 #define LMT_MAPTBL_ENTRY_SIZE 16 574 /* Dump LMTST map table */ 575 static ssize_t rvu_dbg_lmtst_map_table_display(struct file *filp, 576 char __user *buffer, 577 size_t count, loff_t *ppos) 578 { 579 struct rvu *rvu = filp->private_data; 580 u64 lmt_addr, val, tbl_base; 581 int pf, vf, num_vfs, hw_vfs; 582 void __iomem *lmt_map_base; 583 int buf_size = 10240; 584 size_t off = 0; 585 int index = 0; 586 char *buf; 587 int ret; 588 589 /* don't allow partial reads */ 590 if (*ppos != 0) 591 return 0; 592 593 buf = kzalloc(buf_size, GFP_KERNEL); 594 if (!buf) 595 return -ENOMEM; 596 597 tbl_base = rvu_read64(rvu, BLKADDR_APR, APR_AF_LMT_MAP_BASE); 598 599 lmt_map_base = ioremap_wc(tbl_base, 128 * 1024); 600 if (!lmt_map_base) { 601 dev_err(rvu->dev, "Failed to setup lmt map table mapping!!\n"); 602 kfree(buf); 603 return false; 604 } 605 606 off += scnprintf(&buf[off], buf_size - 1 - off, 607 "\n\t\t\t\t\tLmtst Map Table Entries"); 608 off += scnprintf(&buf[off], buf_size - 1 - off, 609 "\n\t\t\t\t\t======================="); 610 off += scnprintf(&buf[off], buf_size - 1 - off, "\nPcifunc\t\t\t"); 611 off += scnprintf(&buf[off], buf_size - 1 - off, "Table Index\t\t"); 612 off += scnprintf(&buf[off], buf_size - 1 - off, 613 "Lmtline Base (word 0)\t\t"); 614 off += scnprintf(&buf[off], buf_size - 1 - off, 615 "Lmt Map Entry (word 1)"); 616 off += scnprintf(&buf[off], buf_size - 1 - off, "\n"); 617 for (pf = 0; pf < rvu->hw->total_pfs; pf++) { 618 off += scnprintf(&buf[off], buf_size - 1 - off, "PF%d \t\t\t", 619 pf); 620 621 index = pf * rvu->hw->total_vfs * LMT_MAPTBL_ENTRY_SIZE; 622 off += scnprintf(&buf[off], buf_size - 1 - off, " 0x%llx\t\t", 623 (tbl_base + index)); 624 lmt_addr = readq(lmt_map_base + index); 625 off += scnprintf(&buf[off], buf_size - 1 - off, 626 " 0x%016llx\t\t", lmt_addr); 627 index += 8; 628 val = readq(lmt_map_base + index); 629 off += scnprintf(&buf[off], buf_size - 1 - off, " 0x%016llx\n", 630 val); 631 /* Reading num of VFs per PF */ 632 rvu_get_pf_numvfs(rvu, pf, &num_vfs, &hw_vfs); 633 for (vf = 0; vf < num_vfs; vf++) { 634 index = (pf * rvu->hw->total_vfs * 16) + 635 ((vf + 1) * LMT_MAPTBL_ENTRY_SIZE); 636 off += scnprintf(&buf[off], buf_size - 1 - off, 637 "PF%d:VF%d \t\t", pf, vf); 638 off += scnprintf(&buf[off], buf_size - 1 - off, 639 " 0x%llx\t\t", (tbl_base + index)); 640 lmt_addr = readq(lmt_map_base + index); 641 off += scnprintf(&buf[off], buf_size - 1 - off, 642 " 0x%016llx\t\t", lmt_addr); 643 index += 8; 644 val = readq(lmt_map_base + index); 645 off += scnprintf(&buf[off], buf_size - 1 - off, 646 " 0x%016llx\n", val); 647 } 648 } 649 off += scnprintf(&buf[off], buf_size - 1 - off, "\n"); 650 651 ret = min(off, count); 652 if (copy_to_user(buffer, buf, ret)) 653 ret = -EFAULT; 654 kfree(buf); 655 656 iounmap(lmt_map_base); 657 if (ret < 0) 658 return ret; 659 660 *ppos = ret; 661 return ret; 662 } 663 664 RVU_DEBUG_FOPS(lmtst_map_table, lmtst_map_table_display, NULL); 665 666 static void get_lf_str_list(const struct rvu_block *block, int pcifunc, 667 char *lfs) 668 { 669 int lf = 0, seq = 0, len = 0, prev_lf = block->lf.max; 670 671 for_each_set_bit(lf, block->lf.bmap, block->lf.max) { 672 if (lf >= block->lf.max) 673 break; 674 675 if (block->fn_map[lf] != pcifunc) 676 continue; 677 678 if (lf == prev_lf + 1) { 679 prev_lf = lf; 680 seq = 1; 681 continue; 682 } 683 684 if (seq) 685 len += sprintf(lfs + len, "-%d,%d", prev_lf, lf); 686 else 687 len += (len ? sprintf(lfs + len, ",%d", lf) : 688 sprintf(lfs + len, "%d", lf)); 689 690 prev_lf = lf; 691 seq = 0; 692 } 693 694 if (seq) 695 len += sprintf(lfs + len, "-%d", prev_lf); 696 697 lfs[len] = '\0'; 698 } 699 700 static int get_max_column_width(struct rvu *rvu) 701 { 702 int index, pf, vf, lf_str_size = 12, buf_size = 256; 703 struct rvu_block block; 704 u16 pcifunc; 705 char *buf; 706 707 buf = kzalloc(buf_size, GFP_KERNEL); 708 if (!buf) 709 return -ENOMEM; 710 711 for (pf = 0; pf < rvu->hw->total_pfs; pf++) { 712 for (vf = 0; vf <= rvu->hw->total_vfs; vf++) { 713 pcifunc = pf << 10 | vf; 714 if (!pcifunc) 715 continue; 716 717 for (index = 0; index < BLK_COUNT; index++) { 718 block = rvu->hw->block[index]; 719 if (!strlen(block.name)) 720 continue; 721 722 get_lf_str_list(&block, pcifunc, buf); 723 if (lf_str_size <= strlen(buf)) 724 lf_str_size = strlen(buf) + 1; 725 } 726 } 727 } 728 729 kfree(buf); 730 return lf_str_size; 731 } 732 733 /* Dumps current provisioning status of all RVU block LFs */ 734 static ssize_t rvu_dbg_rsrc_attach_status(struct file *filp, 735 char __user *buffer, 736 size_t count, loff_t *ppos) 737 { 738 int index, off = 0, flag = 0, len = 0, i = 0; 739 struct rvu *rvu = filp->private_data; 740 int bytes_not_copied = 0; 741 struct rvu_block block; 742 int pf, vf, pcifunc; 743 int buf_size = 2048; 744 int lf_str_size; 745 char *lfs; 746 char *buf; 747 748 /* don't allow partial reads */ 749 if (*ppos != 0) 750 return 0; 751 752 buf = kzalloc(buf_size, GFP_KERNEL); 753 if (!buf) 754 return -ENOMEM; 755 756 /* Get the maximum width of a column */ 757 lf_str_size = get_max_column_width(rvu); 758 759 lfs = kzalloc(lf_str_size, GFP_KERNEL); 760 if (!lfs) { 761 kfree(buf); 762 return -ENOMEM; 763 } 764 off += scnprintf(&buf[off], buf_size - 1 - off, "%-*s", lf_str_size, 765 "pcifunc"); 766 for (index = 0; index < BLK_COUNT; index++) 767 if (strlen(rvu->hw->block[index].name)) { 768 off += scnprintf(&buf[off], buf_size - 1 - off, 769 "%-*s", lf_str_size, 770 rvu->hw->block[index].name); 771 } 772 773 off += scnprintf(&buf[off], buf_size - 1 - off, "\n"); 774 bytes_not_copied = copy_to_user(buffer + (i * off), buf, off); 775 if (bytes_not_copied) 776 goto out; 777 778 i++; 779 *ppos += off; 780 for (pf = 0; pf < rvu->hw->total_pfs; pf++) { 781 for (vf = 0; vf <= rvu->hw->total_vfs; vf++) { 782 off = 0; 783 flag = 0; 784 pcifunc = pf << 10 | vf; 785 if (!pcifunc) 786 continue; 787 788 if (vf) { 789 sprintf(lfs, "PF%d:VF%d", pf, vf - 1); 790 off = scnprintf(&buf[off], 791 buf_size - 1 - off, 792 "%-*s", lf_str_size, lfs); 793 } else { 794 sprintf(lfs, "PF%d", pf); 795 off = scnprintf(&buf[off], 796 buf_size - 1 - off, 797 "%-*s", lf_str_size, lfs); 798 } 799 800 for (index = 0; index < BLK_COUNT; index++) { 801 block = rvu->hw->block[index]; 802 if (!strlen(block.name)) 803 continue; 804 len = 0; 805 lfs[len] = '\0'; 806 get_lf_str_list(&block, pcifunc, lfs); 807 if (strlen(lfs)) 808 flag = 1; 809 810 off += scnprintf(&buf[off], buf_size - 1 - off, 811 "%-*s", lf_str_size, lfs); 812 } 813 if (flag) { 814 off += scnprintf(&buf[off], 815 buf_size - 1 - off, "\n"); 816 bytes_not_copied = copy_to_user(buffer + 817 (i * off), 818 buf, off); 819 if (bytes_not_copied) 820 goto out; 821 822 i++; 823 *ppos += off; 824 } 825 } 826 } 827 828 out: 829 kfree(lfs); 830 kfree(buf); 831 if (bytes_not_copied) 832 return -EFAULT; 833 834 return *ppos; 835 } 836 837 RVU_DEBUG_FOPS(rsrc_status, rsrc_attach_status, NULL); 838 839 static int rvu_dbg_rvu_pf_cgx_map_display(struct seq_file *filp, void *unused) 840 { 841 char cgx[10], lmac[10], chan[10]; 842 struct rvu *rvu = filp->private; 843 struct pci_dev *pdev = NULL; 844 struct mac_ops *mac_ops; 845 struct rvu_pfvf *pfvf; 846 int pf, domain, blkid; 847 u8 cgx_id, lmac_id; 848 u16 pcifunc; 849 850 domain = 2; 851 mac_ops = get_mac_ops(rvu_first_cgx_pdata(rvu)); 852 /* There can be no CGX devices at all */ 853 if (!mac_ops) 854 return 0; 855 seq_printf(filp, "PCI dev\t\tRVU PF Func\tNIX block\t%s\tLMAC\tCHAN\n", 856 mac_ops->name); 857 for (pf = 0; pf < rvu->hw->total_pfs; pf++) { 858 if (!is_pf_cgxmapped(rvu, pf)) 859 continue; 860 861 pdev = pci_get_domain_bus_and_slot(domain, pf + 1, 0); 862 if (!pdev) 863 continue; 864 865 cgx[0] = 0; 866 lmac[0] = 0; 867 pcifunc = pf << 10; 868 pfvf = rvu_get_pfvf(rvu, pcifunc); 869 870 if (pfvf->nix_blkaddr == BLKADDR_NIX0) 871 blkid = 0; 872 else 873 blkid = 1; 874 875 rvu_get_cgx_lmac_id(rvu->pf2cgxlmac_map[pf], &cgx_id, 876 &lmac_id); 877 sprintf(cgx, "%s%d", mac_ops->name, cgx_id); 878 sprintf(lmac, "LMAC%d", lmac_id); 879 sprintf(chan, "%d", 880 rvu_nix_chan_cgx(rvu, cgx_id, lmac_id, 0)); 881 seq_printf(filp, "%s\t0x%x\t\tNIX%d\t\t%s\t%s\t%s\n", 882 dev_name(&pdev->dev), pcifunc, blkid, cgx, lmac, 883 chan); 884 885 pci_dev_put(pdev); 886 } 887 return 0; 888 } 889 890 RVU_DEBUG_SEQ_FOPS(rvu_pf_cgx_map, rvu_pf_cgx_map_display, NULL); 891 892 static bool rvu_dbg_is_valid_lf(struct rvu *rvu, int blkaddr, int lf, 893 u16 *pcifunc) 894 { 895 struct rvu_block *block; 896 struct rvu_hwinfo *hw; 897 898 hw = rvu->hw; 899 block = &hw->block[blkaddr]; 900 901 if (lf < 0 || lf >= block->lf.max) { 902 dev_warn(rvu->dev, "Invalid LF: valid range: 0-%d\n", 903 block->lf.max - 1); 904 return false; 905 } 906 907 *pcifunc = block->fn_map[lf]; 908 if (!*pcifunc) { 909 dev_warn(rvu->dev, 910 "This LF is not attached to any RVU PFFUNC\n"); 911 return false; 912 } 913 return true; 914 } 915 916 static void print_npa_qsize(struct seq_file *m, struct rvu_pfvf *pfvf) 917 { 918 char *buf; 919 920 buf = kmalloc(PAGE_SIZE, GFP_KERNEL); 921 if (!buf) 922 return; 923 924 if (!pfvf->aura_ctx) { 925 seq_puts(m, "Aura context is not initialized\n"); 926 } else { 927 bitmap_print_to_pagebuf(false, buf, pfvf->aura_bmap, 928 pfvf->aura_ctx->qsize); 929 seq_printf(m, "Aura count : %d\n", pfvf->aura_ctx->qsize); 930 seq_printf(m, "Aura context ena/dis bitmap : %s\n", buf); 931 } 932 933 if (!pfvf->pool_ctx) { 934 seq_puts(m, "Pool context is not initialized\n"); 935 } else { 936 bitmap_print_to_pagebuf(false, buf, pfvf->pool_bmap, 937 pfvf->pool_ctx->qsize); 938 seq_printf(m, "Pool count : %d\n", pfvf->pool_ctx->qsize); 939 seq_printf(m, "Pool context ena/dis bitmap : %s\n", buf); 940 } 941 kfree(buf); 942 } 943 944 /* The 'qsize' entry dumps current Aura/Pool context Qsize 945 * and each context's current enable/disable status in a bitmap. 946 */ 947 static int rvu_dbg_qsize_display(struct seq_file *filp, void *unsused, 948 int blktype) 949 { 950 void (*print_qsize)(struct seq_file *filp, 951 struct rvu_pfvf *pfvf) = NULL; 952 struct dentry *current_dir; 953 struct rvu_pfvf *pfvf; 954 struct rvu *rvu; 955 int qsize_id; 956 u16 pcifunc; 957 int blkaddr; 958 959 rvu = filp->private; 960 switch (blktype) { 961 case BLKTYPE_NPA: 962 qsize_id = rvu->rvu_dbg.npa_qsize_id; 963 print_qsize = print_npa_qsize; 964 break; 965 966 case BLKTYPE_NIX: 967 qsize_id = rvu->rvu_dbg.nix_qsize_id; 968 print_qsize = print_nix_qsize; 969 break; 970 971 default: 972 return -EINVAL; 973 } 974 975 if (blktype == BLKTYPE_NPA) { 976 blkaddr = BLKADDR_NPA; 977 } else { 978 current_dir = filp->file->f_path.dentry->d_parent; 979 blkaddr = (!strcmp(current_dir->d_name.name, "nix1") ? 980 BLKADDR_NIX1 : BLKADDR_NIX0); 981 } 982 983 if (!rvu_dbg_is_valid_lf(rvu, blkaddr, qsize_id, &pcifunc)) 984 return -EINVAL; 985 986 pfvf = rvu_get_pfvf(rvu, pcifunc); 987 print_qsize(filp, pfvf); 988 989 return 0; 990 } 991 992 static ssize_t rvu_dbg_qsize_write(struct file *filp, 993 const char __user *buffer, size_t count, 994 loff_t *ppos, int blktype) 995 { 996 char *blk_string = (blktype == BLKTYPE_NPA) ? "npa" : "nix"; 997 struct seq_file *seqfile = filp->private_data; 998 char *cmd_buf, *cmd_buf_tmp, *subtoken; 999 struct rvu *rvu = seqfile->private; 1000 struct dentry *current_dir; 1001 int blkaddr; 1002 u16 pcifunc; 1003 int ret, lf; 1004 1005 cmd_buf = memdup_user_nul(buffer, count); 1006 if (IS_ERR(cmd_buf)) 1007 return -ENOMEM; 1008 1009 cmd_buf_tmp = strchr(cmd_buf, '\n'); 1010 if (cmd_buf_tmp) { 1011 *cmd_buf_tmp = '\0'; 1012 count = cmd_buf_tmp - cmd_buf + 1; 1013 } 1014 1015 cmd_buf_tmp = cmd_buf; 1016 subtoken = strsep(&cmd_buf, " "); 1017 ret = subtoken ? kstrtoint(subtoken, 10, &lf) : -EINVAL; 1018 if (cmd_buf) 1019 ret = -EINVAL; 1020 1021 if (ret < 0 || !strncmp(subtoken, "help", 4)) { 1022 dev_info(rvu->dev, "Use echo <%s-lf > qsize\n", blk_string); 1023 goto qsize_write_done; 1024 } 1025 1026 if (blktype == BLKTYPE_NPA) { 1027 blkaddr = BLKADDR_NPA; 1028 } else { 1029 current_dir = filp->f_path.dentry->d_parent; 1030 blkaddr = (!strcmp(current_dir->d_name.name, "nix1") ? 1031 BLKADDR_NIX1 : BLKADDR_NIX0); 1032 } 1033 1034 if (!rvu_dbg_is_valid_lf(rvu, blkaddr, lf, &pcifunc)) { 1035 ret = -EINVAL; 1036 goto qsize_write_done; 1037 } 1038 if (blktype == BLKTYPE_NPA) 1039 rvu->rvu_dbg.npa_qsize_id = lf; 1040 else 1041 rvu->rvu_dbg.nix_qsize_id = lf; 1042 1043 qsize_write_done: 1044 kfree(cmd_buf_tmp); 1045 return ret ? ret : count; 1046 } 1047 1048 static ssize_t rvu_dbg_npa_qsize_write(struct file *filp, 1049 const char __user *buffer, 1050 size_t count, loff_t *ppos) 1051 { 1052 return rvu_dbg_qsize_write(filp, buffer, count, ppos, 1053 BLKTYPE_NPA); 1054 } 1055 1056 static int rvu_dbg_npa_qsize_display(struct seq_file *filp, void *unused) 1057 { 1058 return rvu_dbg_qsize_display(filp, unused, BLKTYPE_NPA); 1059 } 1060 1061 RVU_DEBUG_SEQ_FOPS(npa_qsize, npa_qsize_display, npa_qsize_write); 1062 1063 /* Dumps given NPA Aura's context */ 1064 static void print_npa_aura_ctx(struct seq_file *m, struct npa_aq_enq_rsp *rsp) 1065 { 1066 struct npa_aura_s *aura = &rsp->aura; 1067 struct rvu *rvu = m->private; 1068 1069 seq_printf(m, "W0: Pool addr\t\t%llx\n", aura->pool_addr); 1070 1071 seq_printf(m, "W1: ena\t\t\t%d\nW1: pool caching\t%d\n", 1072 aura->ena, aura->pool_caching); 1073 seq_printf(m, "W1: pool way mask\t%d\nW1: avg con\t\t%d\n", 1074 aura->pool_way_mask, aura->avg_con); 1075 seq_printf(m, "W1: pool drop ena\t%d\nW1: aura drop ena\t%d\n", 1076 aura->pool_drop_ena, aura->aura_drop_ena); 1077 seq_printf(m, "W1: bp_ena\t\t%d\nW1: aura drop\t\t%d\n", 1078 aura->bp_ena, aura->aura_drop); 1079 seq_printf(m, "W1: aura shift\t\t%d\nW1: avg_level\t\t%d\n", 1080 aura->shift, aura->avg_level); 1081 1082 seq_printf(m, "W2: count\t\t%llu\nW2: nix0_bpid\t\t%d\nW2: nix1_bpid\t\t%d\n", 1083 (u64)aura->count, aura->nix0_bpid, aura->nix1_bpid); 1084 1085 seq_printf(m, "W3: limit\t\t%llu\nW3: bp\t\t\t%d\nW3: fc_ena\t\t%d\n", 1086 (u64)aura->limit, aura->bp, aura->fc_ena); 1087 1088 if (!is_rvu_otx2(rvu)) 1089 seq_printf(m, "W3: fc_be\t\t%d\n", aura->fc_be); 1090 seq_printf(m, "W3: fc_up_crossing\t%d\nW3: fc_stype\t\t%d\n", 1091 aura->fc_up_crossing, aura->fc_stype); 1092 seq_printf(m, "W3: fc_hyst_bits\t%d\n", aura->fc_hyst_bits); 1093 1094 seq_printf(m, "W4: fc_addr\t\t%llx\n", aura->fc_addr); 1095 1096 seq_printf(m, "W5: pool_drop\t\t%d\nW5: update_time\t\t%d\n", 1097 aura->pool_drop, aura->update_time); 1098 seq_printf(m, "W5: err_int \t\t%d\nW5: err_int_ena\t\t%d\n", 1099 aura->err_int, aura->err_int_ena); 1100 seq_printf(m, "W5: thresh_int\t\t%d\nW5: thresh_int_ena \t%d\n", 1101 aura->thresh_int, aura->thresh_int_ena); 1102 seq_printf(m, "W5: thresh_up\t\t%d\nW5: thresh_qint_idx\t%d\n", 1103 aura->thresh_up, aura->thresh_qint_idx); 1104 seq_printf(m, "W5: err_qint_idx \t%d\n", aura->err_qint_idx); 1105 1106 seq_printf(m, "W6: thresh\t\t%llu\n", (u64)aura->thresh); 1107 if (!is_rvu_otx2(rvu)) 1108 seq_printf(m, "W6: fc_msh_dst\t\t%d\n", aura->fc_msh_dst); 1109 } 1110 1111 /* Dumps given NPA Pool's context */ 1112 static void print_npa_pool_ctx(struct seq_file *m, struct npa_aq_enq_rsp *rsp) 1113 { 1114 struct npa_pool_s *pool = &rsp->pool; 1115 struct rvu *rvu = m->private; 1116 1117 seq_printf(m, "W0: Stack base\t\t%llx\n", pool->stack_base); 1118 1119 seq_printf(m, "W1: ena \t\t%d\nW1: nat_align \t\t%d\n", 1120 pool->ena, pool->nat_align); 1121 seq_printf(m, "W1: stack_caching\t%d\nW1: stack_way_mask\t%d\n", 1122 pool->stack_caching, pool->stack_way_mask); 1123 seq_printf(m, "W1: buf_offset\t\t%d\nW1: buf_size\t\t%d\n", 1124 pool->buf_offset, pool->buf_size); 1125 1126 seq_printf(m, "W2: stack_max_pages \t%d\nW2: stack_pages\t\t%d\n", 1127 pool->stack_max_pages, pool->stack_pages); 1128 1129 seq_printf(m, "W3: op_pc \t\t%llu\n", (u64)pool->op_pc); 1130 1131 seq_printf(m, "W4: stack_offset\t%d\nW4: shift\t\t%d\nW4: avg_level\t\t%d\n", 1132 pool->stack_offset, pool->shift, pool->avg_level); 1133 seq_printf(m, "W4: avg_con \t\t%d\nW4: fc_ena\t\t%d\nW4: fc_stype\t\t%d\n", 1134 pool->avg_con, pool->fc_ena, pool->fc_stype); 1135 seq_printf(m, "W4: fc_hyst_bits\t%d\nW4: fc_up_crossing\t%d\n", 1136 pool->fc_hyst_bits, pool->fc_up_crossing); 1137 if (!is_rvu_otx2(rvu)) 1138 seq_printf(m, "W4: fc_be\t\t%d\n", pool->fc_be); 1139 seq_printf(m, "W4: update_time\t\t%d\n", pool->update_time); 1140 1141 seq_printf(m, "W5: fc_addr\t\t%llx\n", pool->fc_addr); 1142 1143 seq_printf(m, "W6: ptr_start\t\t%llx\n", pool->ptr_start); 1144 1145 seq_printf(m, "W7: ptr_end\t\t%llx\n", pool->ptr_end); 1146 1147 seq_printf(m, "W8: err_int\t\t%d\nW8: err_int_ena\t\t%d\n", 1148 pool->err_int, pool->err_int_ena); 1149 seq_printf(m, "W8: thresh_int\t\t%d\n", pool->thresh_int); 1150 seq_printf(m, "W8: thresh_int_ena\t%d\nW8: thresh_up\t\t%d\n", 1151 pool->thresh_int_ena, pool->thresh_up); 1152 seq_printf(m, "W8: thresh_qint_idx\t%d\nW8: err_qint_idx\t%d\n", 1153 pool->thresh_qint_idx, pool->err_qint_idx); 1154 if (!is_rvu_otx2(rvu)) 1155 seq_printf(m, "W8: fc_msh_dst\t\t%d\n", pool->fc_msh_dst); 1156 } 1157 1158 /* Reads aura/pool's ctx from admin queue */ 1159 static int rvu_dbg_npa_ctx_display(struct seq_file *m, void *unused, int ctype) 1160 { 1161 void (*print_npa_ctx)(struct seq_file *m, struct npa_aq_enq_rsp *rsp); 1162 struct npa_aq_enq_req aq_req; 1163 struct npa_aq_enq_rsp rsp; 1164 struct rvu_pfvf *pfvf; 1165 int aura, rc, max_id; 1166 int npalf, id, all; 1167 struct rvu *rvu; 1168 u16 pcifunc; 1169 1170 rvu = m->private; 1171 1172 switch (ctype) { 1173 case NPA_AQ_CTYPE_AURA: 1174 npalf = rvu->rvu_dbg.npa_aura_ctx.lf; 1175 id = rvu->rvu_dbg.npa_aura_ctx.id; 1176 all = rvu->rvu_dbg.npa_aura_ctx.all; 1177 break; 1178 1179 case NPA_AQ_CTYPE_POOL: 1180 npalf = rvu->rvu_dbg.npa_pool_ctx.lf; 1181 id = rvu->rvu_dbg.npa_pool_ctx.id; 1182 all = rvu->rvu_dbg.npa_pool_ctx.all; 1183 break; 1184 default: 1185 return -EINVAL; 1186 } 1187 1188 if (!rvu_dbg_is_valid_lf(rvu, BLKADDR_NPA, npalf, &pcifunc)) 1189 return -EINVAL; 1190 1191 pfvf = rvu_get_pfvf(rvu, pcifunc); 1192 if (ctype == NPA_AQ_CTYPE_AURA && !pfvf->aura_ctx) { 1193 seq_puts(m, "Aura context is not initialized\n"); 1194 return -EINVAL; 1195 } else if (ctype == NPA_AQ_CTYPE_POOL && !pfvf->pool_ctx) { 1196 seq_puts(m, "Pool context is not initialized\n"); 1197 return -EINVAL; 1198 } 1199 1200 memset(&aq_req, 0, sizeof(struct npa_aq_enq_req)); 1201 aq_req.hdr.pcifunc = pcifunc; 1202 aq_req.ctype = ctype; 1203 aq_req.op = NPA_AQ_INSTOP_READ; 1204 if (ctype == NPA_AQ_CTYPE_AURA) { 1205 max_id = pfvf->aura_ctx->qsize; 1206 print_npa_ctx = print_npa_aura_ctx; 1207 } else { 1208 max_id = pfvf->pool_ctx->qsize; 1209 print_npa_ctx = print_npa_pool_ctx; 1210 } 1211 1212 if (id < 0 || id >= max_id) { 1213 seq_printf(m, "Invalid %s, valid range is 0-%d\n", 1214 (ctype == NPA_AQ_CTYPE_AURA) ? "aura" : "pool", 1215 max_id - 1); 1216 return -EINVAL; 1217 } 1218 1219 if (all) 1220 id = 0; 1221 else 1222 max_id = id + 1; 1223 1224 for (aura = id; aura < max_id; aura++) { 1225 aq_req.aura_id = aura; 1226 1227 /* Skip if queue is uninitialized */ 1228 if (ctype == NPA_AQ_CTYPE_POOL && !test_bit(aura, pfvf->pool_bmap)) 1229 continue; 1230 1231 seq_printf(m, "======%s : %d=======\n", 1232 (ctype == NPA_AQ_CTYPE_AURA) ? "AURA" : "POOL", 1233 aq_req.aura_id); 1234 rc = rvu_npa_aq_enq_inst(rvu, &aq_req, &rsp); 1235 if (rc) { 1236 seq_puts(m, "Failed to read context\n"); 1237 return -EINVAL; 1238 } 1239 print_npa_ctx(m, &rsp); 1240 } 1241 return 0; 1242 } 1243 1244 static int write_npa_ctx(struct rvu *rvu, bool all, 1245 int npalf, int id, int ctype) 1246 { 1247 struct rvu_pfvf *pfvf; 1248 int max_id = 0; 1249 u16 pcifunc; 1250 1251 if (!rvu_dbg_is_valid_lf(rvu, BLKADDR_NPA, npalf, &pcifunc)) 1252 return -EINVAL; 1253 1254 pfvf = rvu_get_pfvf(rvu, pcifunc); 1255 1256 if (ctype == NPA_AQ_CTYPE_AURA) { 1257 if (!pfvf->aura_ctx) { 1258 dev_warn(rvu->dev, "Aura context is not initialized\n"); 1259 return -EINVAL; 1260 } 1261 max_id = pfvf->aura_ctx->qsize; 1262 } else if (ctype == NPA_AQ_CTYPE_POOL) { 1263 if (!pfvf->pool_ctx) { 1264 dev_warn(rvu->dev, "Pool context is not initialized\n"); 1265 return -EINVAL; 1266 } 1267 max_id = pfvf->pool_ctx->qsize; 1268 } 1269 1270 if (id < 0 || id >= max_id) { 1271 dev_warn(rvu->dev, "Invalid %s, valid range is 0-%d\n", 1272 (ctype == NPA_AQ_CTYPE_AURA) ? "aura" : "pool", 1273 max_id - 1); 1274 return -EINVAL; 1275 } 1276 1277 switch (ctype) { 1278 case NPA_AQ_CTYPE_AURA: 1279 rvu->rvu_dbg.npa_aura_ctx.lf = npalf; 1280 rvu->rvu_dbg.npa_aura_ctx.id = id; 1281 rvu->rvu_dbg.npa_aura_ctx.all = all; 1282 break; 1283 1284 case NPA_AQ_CTYPE_POOL: 1285 rvu->rvu_dbg.npa_pool_ctx.lf = npalf; 1286 rvu->rvu_dbg.npa_pool_ctx.id = id; 1287 rvu->rvu_dbg.npa_pool_ctx.all = all; 1288 break; 1289 default: 1290 return -EINVAL; 1291 } 1292 return 0; 1293 } 1294 1295 static int parse_cmd_buffer_ctx(char *cmd_buf, size_t *count, 1296 const char __user *buffer, int *npalf, 1297 int *id, bool *all) 1298 { 1299 int bytes_not_copied; 1300 char *cmd_buf_tmp; 1301 char *subtoken; 1302 int ret; 1303 1304 bytes_not_copied = copy_from_user(cmd_buf, buffer, *count); 1305 if (bytes_not_copied) 1306 return -EFAULT; 1307 1308 cmd_buf[*count] = '\0'; 1309 cmd_buf_tmp = strchr(cmd_buf, '\n'); 1310 1311 if (cmd_buf_tmp) { 1312 *cmd_buf_tmp = '\0'; 1313 *count = cmd_buf_tmp - cmd_buf + 1; 1314 } 1315 1316 subtoken = strsep(&cmd_buf, " "); 1317 ret = subtoken ? kstrtoint(subtoken, 10, npalf) : -EINVAL; 1318 if (ret < 0) 1319 return ret; 1320 subtoken = strsep(&cmd_buf, " "); 1321 if (subtoken && strcmp(subtoken, "all") == 0) { 1322 *all = true; 1323 } else { 1324 ret = subtoken ? kstrtoint(subtoken, 10, id) : -EINVAL; 1325 if (ret < 0) 1326 return ret; 1327 } 1328 if (cmd_buf) 1329 return -EINVAL; 1330 return ret; 1331 } 1332 1333 static ssize_t rvu_dbg_npa_ctx_write(struct file *filp, 1334 const char __user *buffer, 1335 size_t count, loff_t *ppos, int ctype) 1336 { 1337 char *cmd_buf, *ctype_string = (ctype == NPA_AQ_CTYPE_AURA) ? 1338 "aura" : "pool"; 1339 struct seq_file *seqfp = filp->private_data; 1340 struct rvu *rvu = seqfp->private; 1341 int npalf, id = 0, ret; 1342 bool all = false; 1343 1344 if ((*ppos != 0) || !count) 1345 return -EINVAL; 1346 1347 cmd_buf = kzalloc(count + 1, GFP_KERNEL); 1348 if (!cmd_buf) 1349 return count; 1350 ret = parse_cmd_buffer_ctx(cmd_buf, &count, buffer, 1351 &npalf, &id, &all); 1352 if (ret < 0) { 1353 dev_info(rvu->dev, 1354 "Usage: echo <npalf> [%s number/all] > %s_ctx\n", 1355 ctype_string, ctype_string); 1356 goto done; 1357 } else { 1358 ret = write_npa_ctx(rvu, all, npalf, id, ctype); 1359 } 1360 done: 1361 kfree(cmd_buf); 1362 return ret ? ret : count; 1363 } 1364 1365 static ssize_t rvu_dbg_npa_aura_ctx_write(struct file *filp, 1366 const char __user *buffer, 1367 size_t count, loff_t *ppos) 1368 { 1369 return rvu_dbg_npa_ctx_write(filp, buffer, count, ppos, 1370 NPA_AQ_CTYPE_AURA); 1371 } 1372 1373 static int rvu_dbg_npa_aura_ctx_display(struct seq_file *filp, void *unused) 1374 { 1375 return rvu_dbg_npa_ctx_display(filp, unused, NPA_AQ_CTYPE_AURA); 1376 } 1377 1378 RVU_DEBUG_SEQ_FOPS(npa_aura_ctx, npa_aura_ctx_display, npa_aura_ctx_write); 1379 1380 static ssize_t rvu_dbg_npa_pool_ctx_write(struct file *filp, 1381 const char __user *buffer, 1382 size_t count, loff_t *ppos) 1383 { 1384 return rvu_dbg_npa_ctx_write(filp, buffer, count, ppos, 1385 NPA_AQ_CTYPE_POOL); 1386 } 1387 1388 static int rvu_dbg_npa_pool_ctx_display(struct seq_file *filp, void *unused) 1389 { 1390 return rvu_dbg_npa_ctx_display(filp, unused, NPA_AQ_CTYPE_POOL); 1391 } 1392 1393 RVU_DEBUG_SEQ_FOPS(npa_pool_ctx, npa_pool_ctx_display, npa_pool_ctx_write); 1394 1395 static void ndc_cache_stats(struct seq_file *s, int blk_addr, 1396 int ctype, int transaction) 1397 { 1398 u64 req, out_req, lat, cant_alloc; 1399 struct nix_hw *nix_hw; 1400 struct rvu *rvu; 1401 int port; 1402 1403 if (blk_addr == BLKADDR_NDC_NPA0) { 1404 rvu = s->private; 1405 } else { 1406 nix_hw = s->private; 1407 rvu = nix_hw->rvu; 1408 } 1409 1410 for (port = 0; port < NDC_MAX_PORT; port++) { 1411 req = rvu_read64(rvu, blk_addr, NDC_AF_PORTX_RTX_RWX_REQ_PC 1412 (port, ctype, transaction)); 1413 lat = rvu_read64(rvu, blk_addr, NDC_AF_PORTX_RTX_RWX_LAT_PC 1414 (port, ctype, transaction)); 1415 out_req = rvu_read64(rvu, blk_addr, 1416 NDC_AF_PORTX_RTX_RWX_OSTDN_PC 1417 (port, ctype, transaction)); 1418 cant_alloc = rvu_read64(rvu, blk_addr, 1419 NDC_AF_PORTX_RTX_CANT_ALLOC_PC 1420 (port, transaction)); 1421 seq_printf(s, "\nPort:%d\n", port); 1422 seq_printf(s, "\tTotal Requests:\t\t%lld\n", req); 1423 seq_printf(s, "\tTotal Time Taken:\t%lld cycles\n", lat); 1424 seq_printf(s, "\tAvg Latency:\t\t%lld cycles\n", lat / req); 1425 seq_printf(s, "\tOutstanding Requests:\t%lld\n", out_req); 1426 seq_printf(s, "\tCant Alloc Requests:\t%lld\n", cant_alloc); 1427 } 1428 } 1429 1430 static int ndc_blk_cache_stats(struct seq_file *s, int idx, int blk_addr) 1431 { 1432 seq_puts(s, "\n***** CACHE mode read stats *****\n"); 1433 ndc_cache_stats(s, blk_addr, CACHING, NDC_READ_TRANS); 1434 seq_puts(s, "\n***** CACHE mode write stats *****\n"); 1435 ndc_cache_stats(s, blk_addr, CACHING, NDC_WRITE_TRANS); 1436 seq_puts(s, "\n***** BY-PASS mode read stats *****\n"); 1437 ndc_cache_stats(s, blk_addr, BYPASS, NDC_READ_TRANS); 1438 seq_puts(s, "\n***** BY-PASS mode write stats *****\n"); 1439 ndc_cache_stats(s, blk_addr, BYPASS, NDC_WRITE_TRANS); 1440 return 0; 1441 } 1442 1443 static int rvu_dbg_npa_ndc_cache_display(struct seq_file *filp, void *unused) 1444 { 1445 return ndc_blk_cache_stats(filp, NPA0_U, BLKADDR_NDC_NPA0); 1446 } 1447 1448 RVU_DEBUG_SEQ_FOPS(npa_ndc_cache, npa_ndc_cache_display, NULL); 1449 1450 static int ndc_blk_hits_miss_stats(struct seq_file *s, int idx, int blk_addr) 1451 { 1452 struct nix_hw *nix_hw; 1453 struct rvu *rvu; 1454 int bank, max_bank; 1455 u64 ndc_af_const; 1456 1457 if (blk_addr == BLKADDR_NDC_NPA0) { 1458 rvu = s->private; 1459 } else { 1460 nix_hw = s->private; 1461 rvu = nix_hw->rvu; 1462 } 1463 1464 ndc_af_const = rvu_read64(rvu, blk_addr, NDC_AF_CONST); 1465 max_bank = FIELD_GET(NDC_AF_BANK_MASK, ndc_af_const); 1466 for (bank = 0; bank < max_bank; bank++) { 1467 seq_printf(s, "BANK:%d\n", bank); 1468 seq_printf(s, "\tHits:\t%lld\n", 1469 (u64)rvu_read64(rvu, blk_addr, 1470 NDC_AF_BANKX_HIT_PC(bank))); 1471 seq_printf(s, "\tMiss:\t%lld\n", 1472 (u64)rvu_read64(rvu, blk_addr, 1473 NDC_AF_BANKX_MISS_PC(bank))); 1474 } 1475 return 0; 1476 } 1477 1478 static int rvu_dbg_nix_ndc_rx_cache_display(struct seq_file *filp, void *unused) 1479 { 1480 struct nix_hw *nix_hw = filp->private; 1481 int blkaddr = 0; 1482 int ndc_idx = 0; 1483 1484 blkaddr = (nix_hw->blkaddr == BLKADDR_NIX1 ? 1485 BLKADDR_NDC_NIX1_RX : BLKADDR_NDC_NIX0_RX); 1486 ndc_idx = (nix_hw->blkaddr == BLKADDR_NIX1 ? NIX1_RX : NIX0_RX); 1487 1488 return ndc_blk_cache_stats(filp, ndc_idx, blkaddr); 1489 } 1490 1491 RVU_DEBUG_SEQ_FOPS(nix_ndc_rx_cache, nix_ndc_rx_cache_display, NULL); 1492 1493 static int rvu_dbg_nix_ndc_tx_cache_display(struct seq_file *filp, void *unused) 1494 { 1495 struct nix_hw *nix_hw = filp->private; 1496 int blkaddr = 0; 1497 int ndc_idx = 0; 1498 1499 blkaddr = (nix_hw->blkaddr == BLKADDR_NIX1 ? 1500 BLKADDR_NDC_NIX1_TX : BLKADDR_NDC_NIX0_TX); 1501 ndc_idx = (nix_hw->blkaddr == BLKADDR_NIX1 ? NIX1_TX : NIX0_TX); 1502 1503 return ndc_blk_cache_stats(filp, ndc_idx, blkaddr); 1504 } 1505 1506 RVU_DEBUG_SEQ_FOPS(nix_ndc_tx_cache, nix_ndc_tx_cache_display, NULL); 1507 1508 static int rvu_dbg_npa_ndc_hits_miss_display(struct seq_file *filp, 1509 void *unused) 1510 { 1511 return ndc_blk_hits_miss_stats(filp, NPA0_U, BLKADDR_NDC_NPA0); 1512 } 1513 1514 RVU_DEBUG_SEQ_FOPS(npa_ndc_hits_miss, npa_ndc_hits_miss_display, NULL); 1515 1516 static int rvu_dbg_nix_ndc_rx_hits_miss_display(struct seq_file *filp, 1517 void *unused) 1518 { 1519 struct nix_hw *nix_hw = filp->private; 1520 int ndc_idx = NPA0_U; 1521 int blkaddr = 0; 1522 1523 blkaddr = (nix_hw->blkaddr == BLKADDR_NIX1 ? 1524 BLKADDR_NDC_NIX1_RX : BLKADDR_NDC_NIX0_RX); 1525 1526 return ndc_blk_hits_miss_stats(filp, ndc_idx, blkaddr); 1527 } 1528 1529 RVU_DEBUG_SEQ_FOPS(nix_ndc_rx_hits_miss, nix_ndc_rx_hits_miss_display, NULL); 1530 1531 static int rvu_dbg_nix_ndc_tx_hits_miss_display(struct seq_file *filp, 1532 void *unused) 1533 { 1534 struct nix_hw *nix_hw = filp->private; 1535 int ndc_idx = NPA0_U; 1536 int blkaddr = 0; 1537 1538 blkaddr = (nix_hw->blkaddr == BLKADDR_NIX1 ? 1539 BLKADDR_NDC_NIX1_TX : BLKADDR_NDC_NIX0_TX); 1540 1541 return ndc_blk_hits_miss_stats(filp, ndc_idx, blkaddr); 1542 } 1543 1544 RVU_DEBUG_SEQ_FOPS(nix_ndc_tx_hits_miss, nix_ndc_tx_hits_miss_display, NULL); 1545 1546 static void print_nix_cn10k_sq_ctx(struct seq_file *m, 1547 struct nix_cn10k_sq_ctx_s *sq_ctx) 1548 { 1549 seq_printf(m, "W0: ena \t\t\t%d\nW0: qint_idx \t\t\t%d\n", 1550 sq_ctx->ena, sq_ctx->qint_idx); 1551 seq_printf(m, "W0: substream \t\t\t0x%03x\nW0: sdp_mcast \t\t\t%d\n", 1552 sq_ctx->substream, sq_ctx->sdp_mcast); 1553 seq_printf(m, "W0: cq \t\t\t\t%d\nW0: sqe_way_mask \t\t%d\n\n", 1554 sq_ctx->cq, sq_ctx->sqe_way_mask); 1555 1556 seq_printf(m, "W1: smq \t\t\t%d\nW1: cq_ena \t\t\t%d\nW1: xoff\t\t\t%d\n", 1557 sq_ctx->smq, sq_ctx->cq_ena, sq_ctx->xoff); 1558 seq_printf(m, "W1: sso_ena \t\t\t%d\nW1: smq_rr_weight\t\t%d\n", 1559 sq_ctx->sso_ena, sq_ctx->smq_rr_weight); 1560 seq_printf(m, "W1: default_chan\t\t%d\nW1: sqb_count\t\t\t%d\n\n", 1561 sq_ctx->default_chan, sq_ctx->sqb_count); 1562 1563 seq_printf(m, "W2: smq_rr_count_lb \t\t%d\n", sq_ctx->smq_rr_count_lb); 1564 seq_printf(m, "W2: smq_rr_count_ub \t\t%d\n", sq_ctx->smq_rr_count_ub); 1565 seq_printf(m, "W2: sqb_aura \t\t\t%d\nW2: sq_int \t\t\t%d\n", 1566 sq_ctx->sqb_aura, sq_ctx->sq_int); 1567 seq_printf(m, "W2: sq_int_ena \t\t\t%d\nW2: sqe_stype \t\t\t%d\n", 1568 sq_ctx->sq_int_ena, sq_ctx->sqe_stype); 1569 1570 seq_printf(m, "W3: max_sqe_size\t\t%d\nW3: cq_limit\t\t\t%d\n", 1571 sq_ctx->max_sqe_size, sq_ctx->cq_limit); 1572 seq_printf(m, "W3: lmt_dis \t\t\t%d\nW3: mnq_dis \t\t\t%d\n", 1573 sq_ctx->mnq_dis, sq_ctx->lmt_dis); 1574 seq_printf(m, "W3: smq_next_sq\t\t\t%d\nW3: smq_lso_segnum\t\t%d\n", 1575 sq_ctx->smq_next_sq, sq_ctx->smq_lso_segnum); 1576 seq_printf(m, "W3: tail_offset \t\t%d\nW3: smenq_offset\t\t%d\n", 1577 sq_ctx->tail_offset, sq_ctx->smenq_offset); 1578 seq_printf(m, "W3: head_offset\t\t\t%d\nW3: smenq_next_sqb_vld\t\t%d\n\n", 1579 sq_ctx->head_offset, sq_ctx->smenq_next_sqb_vld); 1580 1581 seq_printf(m, "W3: smq_next_sq_vld\t\t%d\nW3: smq_pend\t\t\t%d\n", 1582 sq_ctx->smq_next_sq_vld, sq_ctx->smq_pend); 1583 seq_printf(m, "W4: next_sqb \t\t\t%llx\n\n", sq_ctx->next_sqb); 1584 seq_printf(m, "W5: tail_sqb \t\t\t%llx\n\n", sq_ctx->tail_sqb); 1585 seq_printf(m, "W6: smenq_sqb \t\t\t%llx\n\n", sq_ctx->smenq_sqb); 1586 seq_printf(m, "W7: smenq_next_sqb \t\t%llx\n\n", 1587 sq_ctx->smenq_next_sqb); 1588 1589 seq_printf(m, "W8: head_sqb\t\t\t%llx\n\n", sq_ctx->head_sqb); 1590 1591 seq_printf(m, "W9: vfi_lso_total\t\t%d\n", sq_ctx->vfi_lso_total); 1592 seq_printf(m, "W9: vfi_lso_sizem1\t\t%d\nW9: vfi_lso_sb\t\t\t%d\n", 1593 sq_ctx->vfi_lso_sizem1, sq_ctx->vfi_lso_sb); 1594 seq_printf(m, "W9: vfi_lso_mps\t\t\t%d\nW9: vfi_lso_vlan0_ins_ena\t%d\n", 1595 sq_ctx->vfi_lso_mps, sq_ctx->vfi_lso_vlan0_ins_ena); 1596 seq_printf(m, "W9: vfi_lso_vlan1_ins_ena\t%d\nW9: vfi_lso_vld \t\t%d\n\n", 1597 sq_ctx->vfi_lso_vld, sq_ctx->vfi_lso_vlan1_ins_ena); 1598 1599 seq_printf(m, "W10: scm_lso_rem \t\t%llu\n\n", 1600 (u64)sq_ctx->scm_lso_rem); 1601 seq_printf(m, "W11: octs \t\t\t%llu\n\n", (u64)sq_ctx->octs); 1602 seq_printf(m, "W12: pkts \t\t\t%llu\n\n", (u64)sq_ctx->pkts); 1603 seq_printf(m, "W14: dropped_octs \t\t%llu\n\n", 1604 (u64)sq_ctx->dropped_octs); 1605 seq_printf(m, "W15: dropped_pkts \t\t%llu\n\n", 1606 (u64)sq_ctx->dropped_pkts); 1607 } 1608 1609 static void print_tm_tree(struct seq_file *m, 1610 struct nix_aq_enq_rsp *rsp, u64 sq) 1611 { 1612 struct nix_sq_ctx_s *sq_ctx = &rsp->sq; 1613 struct nix_hw *nix_hw = m->private; 1614 struct rvu *rvu = nix_hw->rvu; 1615 u16 p1, p2, p3, p4, schq; 1616 int blkaddr; 1617 u64 cfg; 1618 1619 blkaddr = nix_hw->blkaddr; 1620 schq = sq_ctx->smq; 1621 1622 cfg = rvu_read64(rvu, blkaddr, NIX_AF_MDQX_PARENT(schq)); 1623 p1 = FIELD_GET(NIX_AF_MDQ_PARENT_MASK, cfg); 1624 1625 cfg = rvu_read64(rvu, blkaddr, NIX_AF_TL4X_PARENT(p1)); 1626 p2 = FIELD_GET(NIX_AF_TL4_PARENT_MASK, cfg); 1627 1628 cfg = rvu_read64(rvu, blkaddr, NIX_AF_TL3X_PARENT(p2)); 1629 p3 = FIELD_GET(NIX_AF_TL3_PARENT_MASK, cfg); 1630 1631 cfg = rvu_read64(rvu, blkaddr, NIX_AF_TL2X_PARENT(p3)); 1632 p4 = FIELD_GET(NIX_AF_TL2_PARENT_MASK, cfg); 1633 seq_printf(m, 1634 "SQ(%llu) -> SMQ(%u) -> TL4(%u) -> TL3(%u) -> TL2(%u) -> TL1(%u)\n", 1635 sq, schq, p1, p2, p3, p4); 1636 } 1637 1638 /*dumps given tm_tree registers*/ 1639 static int rvu_dbg_nix_tm_tree_display(struct seq_file *m, void *unused) 1640 { 1641 int qidx, nixlf, rc, id, max_id = 0; 1642 struct nix_hw *nix_hw = m->private; 1643 struct rvu *rvu = nix_hw->rvu; 1644 struct nix_aq_enq_req aq_req; 1645 struct nix_aq_enq_rsp rsp; 1646 struct rvu_pfvf *pfvf; 1647 u16 pcifunc; 1648 1649 nixlf = rvu->rvu_dbg.nix_tm_ctx.lf; 1650 id = rvu->rvu_dbg.nix_tm_ctx.id; 1651 1652 if (!rvu_dbg_is_valid_lf(rvu, nix_hw->blkaddr, nixlf, &pcifunc)) 1653 return -EINVAL; 1654 1655 pfvf = rvu_get_pfvf(rvu, pcifunc); 1656 max_id = pfvf->sq_ctx->qsize; 1657 1658 memset(&aq_req, 0, sizeof(struct nix_aq_enq_req)); 1659 aq_req.hdr.pcifunc = pcifunc; 1660 aq_req.ctype = NIX_AQ_CTYPE_SQ; 1661 aq_req.op = NIX_AQ_INSTOP_READ; 1662 seq_printf(m, "pcifunc is 0x%x\n", pcifunc); 1663 for (qidx = id; qidx < max_id; qidx++) { 1664 aq_req.qidx = qidx; 1665 1666 /* Skip SQ's if not initialized */ 1667 if (!test_bit(qidx, pfvf->sq_bmap)) 1668 continue; 1669 1670 rc = rvu_mbox_handler_nix_aq_enq(rvu, &aq_req, &rsp); 1671 1672 if (rc) { 1673 seq_printf(m, "Failed to read SQ(%d) context\n", 1674 aq_req.qidx); 1675 continue; 1676 } 1677 print_tm_tree(m, &rsp, aq_req.qidx); 1678 } 1679 return 0; 1680 } 1681 1682 static ssize_t rvu_dbg_nix_tm_tree_write(struct file *filp, 1683 const char __user *buffer, 1684 size_t count, loff_t *ppos) 1685 { 1686 struct seq_file *m = filp->private_data; 1687 struct nix_hw *nix_hw = m->private; 1688 struct rvu *rvu = nix_hw->rvu; 1689 struct rvu_pfvf *pfvf; 1690 u16 pcifunc; 1691 u64 nixlf; 1692 int ret; 1693 1694 ret = kstrtoull_from_user(buffer, count, 10, &nixlf); 1695 if (ret) 1696 return ret; 1697 1698 if (!rvu_dbg_is_valid_lf(rvu, nix_hw->blkaddr, nixlf, &pcifunc)) 1699 return -EINVAL; 1700 1701 pfvf = rvu_get_pfvf(rvu, pcifunc); 1702 if (!pfvf->sq_ctx) { 1703 dev_warn(rvu->dev, "SQ context is not initialized\n"); 1704 return -EINVAL; 1705 } 1706 1707 rvu->rvu_dbg.nix_tm_ctx.lf = nixlf; 1708 return count; 1709 } 1710 1711 RVU_DEBUG_SEQ_FOPS(nix_tm_tree, nix_tm_tree_display, nix_tm_tree_write); 1712 1713 static void print_tm_topo(struct seq_file *m, u64 schq, u32 lvl) 1714 { 1715 struct nix_hw *nix_hw = m->private; 1716 struct rvu *rvu = nix_hw->rvu; 1717 int blkaddr, link, link_level; 1718 struct rvu_hwinfo *hw; 1719 1720 hw = rvu->hw; 1721 blkaddr = nix_hw->blkaddr; 1722 if (lvl == NIX_TXSCH_LVL_MDQ) { 1723 seq_printf(m, "NIX_AF_SMQ[%llu]_CFG =0x%llx\n", schq, 1724 rvu_read64(rvu, blkaddr, NIX_AF_SMQX_CFG(schq))); 1725 seq_printf(m, "NIX_AF_SMQ[%llu]_STATUS =0x%llx\n", schq, 1726 rvu_read64(rvu, blkaddr, NIX_AF_SMQX_STATUS(schq))); 1727 seq_printf(m, "NIX_AF_MDQ[%llu]_OUT_MD_COUNT =0x%llx\n", schq, 1728 rvu_read64(rvu, blkaddr, 1729 NIX_AF_MDQX_OUT_MD_COUNT(schq))); 1730 seq_printf(m, "NIX_AF_MDQ[%llu]_SCHEDULE =0x%llx\n", schq, 1731 rvu_read64(rvu, blkaddr, 1732 NIX_AF_MDQX_SCHEDULE(schq))); 1733 seq_printf(m, "NIX_AF_MDQ[%llu]_SHAPE =0x%llx\n", schq, 1734 rvu_read64(rvu, blkaddr, NIX_AF_MDQX_SHAPE(schq))); 1735 seq_printf(m, "NIX_AF_MDQ[%llu]_CIR =0x%llx\n", schq, 1736 rvu_read64(rvu, blkaddr, NIX_AF_MDQX_CIR(schq))); 1737 seq_printf(m, "NIX_AF_MDQ[%llu]_PIR =0x%llx\n", schq, 1738 rvu_read64(rvu, blkaddr, NIX_AF_MDQX_PIR(schq))); 1739 seq_printf(m, "NIX_AF_MDQ[%llu]_SW_XOFF =0x%llx\n", schq, 1740 rvu_read64(rvu, blkaddr, NIX_AF_MDQX_SW_XOFF(schq))); 1741 seq_printf(m, "NIX_AF_MDQ[%llu]_PARENT =0x%llx\n", schq, 1742 rvu_read64(rvu, blkaddr, NIX_AF_MDQX_PARENT(schq))); 1743 seq_puts(m, "\n"); 1744 } 1745 1746 if (lvl == NIX_TXSCH_LVL_TL4) { 1747 seq_printf(m, "NIX_AF_TL4[%llu]_SDP_LINK_CFG =0x%llx\n", schq, 1748 rvu_read64(rvu, blkaddr, 1749 NIX_AF_TL4X_SDP_LINK_CFG(schq))); 1750 seq_printf(m, "NIX_AF_TL4[%llu]_SCHEDULE =0x%llx\n", schq, 1751 rvu_read64(rvu, blkaddr, 1752 NIX_AF_TL4X_SCHEDULE(schq))); 1753 seq_printf(m, "NIX_AF_TL4[%llu]_SHAPE =0x%llx\n", schq, 1754 rvu_read64(rvu, blkaddr, NIX_AF_TL4X_SHAPE(schq))); 1755 seq_printf(m, "NIX_AF_TL4[%llu]_CIR =0x%llx\n", schq, 1756 rvu_read64(rvu, blkaddr, NIX_AF_TL4X_CIR(schq))); 1757 seq_printf(m, "NIX_AF_TL4[%llu]_PIR =0x%llx\n", schq, 1758 rvu_read64(rvu, blkaddr, NIX_AF_TL4X_PIR(schq))); 1759 seq_printf(m, "NIX_AF_TL4[%llu]_SW_XOFF =0x%llx\n", schq, 1760 rvu_read64(rvu, blkaddr, NIX_AF_TL4X_SW_XOFF(schq))); 1761 seq_printf(m, "NIX_AF_TL4[%llu]_TOPOLOGY =0x%llx\n", schq, 1762 rvu_read64(rvu, blkaddr, 1763 NIX_AF_TL4X_TOPOLOGY(schq))); 1764 seq_printf(m, "NIX_AF_TL4[%llu]_PARENT =0x%llx\n", schq, 1765 rvu_read64(rvu, blkaddr, NIX_AF_TL4X_PARENT(schq))); 1766 seq_printf(m, "NIX_AF_TL4[%llu]_MD_DEBUG0 =0x%llx\n", schq, 1767 rvu_read64(rvu, blkaddr, 1768 NIX_AF_TL4X_MD_DEBUG0(schq))); 1769 seq_printf(m, "NIX_AF_TL4[%llu]_MD_DEBUG1 =0x%llx\n", schq, 1770 rvu_read64(rvu, blkaddr, 1771 NIX_AF_TL4X_MD_DEBUG1(schq))); 1772 seq_puts(m, "\n"); 1773 } 1774 1775 if (lvl == NIX_TXSCH_LVL_TL3) { 1776 seq_printf(m, "NIX_AF_TL3[%llu]_SCHEDULE =0x%llx\n", schq, 1777 rvu_read64(rvu, blkaddr, 1778 NIX_AF_TL3X_SCHEDULE(schq))); 1779 seq_printf(m, "NIX_AF_TL3[%llu]_SHAPE =0x%llx\n", schq, 1780 rvu_read64(rvu, blkaddr, NIX_AF_TL3X_SHAPE(schq))); 1781 seq_printf(m, "NIX_AF_TL3[%llu]_CIR =0x%llx\n", schq, 1782 rvu_read64(rvu, blkaddr, NIX_AF_TL3X_CIR(schq))); 1783 seq_printf(m, "NIX_AF_TL3[%llu]_PIR =0x%llx\n", schq, 1784 rvu_read64(rvu, blkaddr, NIX_AF_TL3X_PIR(schq))); 1785 seq_printf(m, "NIX_AF_TL3[%llu]_SW_XOFF =0x%llx\n", schq, 1786 rvu_read64(rvu, blkaddr, NIX_AF_TL3X_SW_XOFF(schq))); 1787 seq_printf(m, "NIX_AF_TL3[%llu]_TOPOLOGY =0x%llx\n", schq, 1788 rvu_read64(rvu, blkaddr, 1789 NIX_AF_TL3X_TOPOLOGY(schq))); 1790 seq_printf(m, "NIX_AF_TL3[%llu]_PARENT =0x%llx\n", schq, 1791 rvu_read64(rvu, blkaddr, NIX_AF_TL3X_PARENT(schq))); 1792 seq_printf(m, "NIX_AF_TL3[%llu]_MD_DEBUG0 =0x%llx\n", schq, 1793 rvu_read64(rvu, blkaddr, 1794 NIX_AF_TL3X_MD_DEBUG0(schq))); 1795 seq_printf(m, "NIX_AF_TL3[%llu]_MD_DEBUG1 =0x%llx\n", schq, 1796 rvu_read64(rvu, blkaddr, 1797 NIX_AF_TL3X_MD_DEBUG1(schq))); 1798 1799 link_level = rvu_read64(rvu, blkaddr, NIX_AF_PSE_CHANNEL_LEVEL) 1800 & 0x01 ? NIX_TXSCH_LVL_TL3 : NIX_TXSCH_LVL_TL2; 1801 if (lvl == link_level) { 1802 seq_printf(m, 1803 "NIX_AF_TL3_TL2[%llu]_BP_STATUS =0x%llx\n", 1804 schq, rvu_read64(rvu, blkaddr, 1805 NIX_AF_TL3_TL2X_BP_STATUS(schq))); 1806 for (link = 0; link < hw->cgx_links; link++) 1807 seq_printf(m, 1808 "NIX_AF_TL3_TL2[%llu]_LINK[%d]_CFG =0x%llx\n", 1809 schq, link, 1810 rvu_read64(rvu, blkaddr, 1811 NIX_AF_TL3_TL2X_LINKX_CFG(schq, link))); 1812 } 1813 seq_puts(m, "\n"); 1814 } 1815 1816 if (lvl == NIX_TXSCH_LVL_TL2) { 1817 seq_printf(m, "NIX_AF_TL2[%llu]_SHAPE =0x%llx\n", schq, 1818 rvu_read64(rvu, blkaddr, NIX_AF_TL2X_SHAPE(schq))); 1819 seq_printf(m, "NIX_AF_TL2[%llu]_CIR =0x%llx\n", schq, 1820 rvu_read64(rvu, blkaddr, NIX_AF_TL2X_CIR(schq))); 1821 seq_printf(m, "NIX_AF_TL2[%llu]_PIR =0x%llx\n", schq, 1822 rvu_read64(rvu, blkaddr, NIX_AF_TL2X_PIR(schq))); 1823 seq_printf(m, "NIX_AF_TL2[%llu]_SW_XOFF =0x%llx\n", schq, 1824 rvu_read64(rvu, blkaddr, NIX_AF_TL2X_SW_XOFF(schq))); 1825 seq_printf(m, "NIX_AF_TL2[%llu]_TOPOLOGY =0x%llx\n", schq, 1826 rvu_read64(rvu, blkaddr, 1827 NIX_AF_TL2X_TOPOLOGY(schq))); 1828 seq_printf(m, "NIX_AF_TL2[%llu]_PARENT =0x%llx\n", schq, 1829 rvu_read64(rvu, blkaddr, NIX_AF_TL2X_PARENT(schq))); 1830 seq_printf(m, "NIX_AF_TL2[%llu]_MD_DEBUG0 =0x%llx\n", schq, 1831 rvu_read64(rvu, blkaddr, 1832 NIX_AF_TL2X_MD_DEBUG0(schq))); 1833 seq_printf(m, "NIX_AF_TL2[%llu]_MD_DEBUG1 =0x%llx\n", schq, 1834 rvu_read64(rvu, blkaddr, 1835 NIX_AF_TL2X_MD_DEBUG1(schq))); 1836 1837 link_level = rvu_read64(rvu, blkaddr, NIX_AF_PSE_CHANNEL_LEVEL) 1838 & 0x01 ? NIX_TXSCH_LVL_TL3 : NIX_TXSCH_LVL_TL2; 1839 if (lvl == link_level) { 1840 seq_printf(m, 1841 "NIX_AF_TL3_TL2[%llu]_BP_STATUS =0x%llx\n", 1842 schq, rvu_read64(rvu, blkaddr, 1843 NIX_AF_TL3_TL2X_BP_STATUS(schq))); 1844 for (link = 0; link < hw->cgx_links; link++) 1845 seq_printf(m, 1846 "NIX_AF_TL3_TL2[%llu]_LINK[%d]_CFG =0x%llx\n", 1847 schq, link, rvu_read64(rvu, blkaddr, 1848 NIX_AF_TL3_TL2X_LINKX_CFG(schq, link))); 1849 } 1850 seq_puts(m, "\n"); 1851 } 1852 1853 if (lvl == NIX_TXSCH_LVL_TL1) { 1854 seq_printf(m, "NIX_AF_TX_LINK[%llu]_NORM_CREDIT =0x%llx\n", 1855 schq, 1856 rvu_read64(rvu, blkaddr, 1857 NIX_AF_TX_LINKX_NORM_CREDIT(schq))); 1858 seq_printf(m, "NIX_AF_TX_LINK[%llu]_HW_XOFF =0x%llx\n", schq, 1859 rvu_read64(rvu, blkaddr, 1860 NIX_AF_TX_LINKX_HW_XOFF(schq))); 1861 seq_printf(m, "NIX_AF_TL1[%llu]_SCHEDULE =0x%llx\n", schq, 1862 rvu_read64(rvu, blkaddr, 1863 NIX_AF_TL1X_SCHEDULE(schq))); 1864 seq_printf(m, "NIX_AF_TL1[%llu]_SHAPE =0x%llx\n", schq, 1865 rvu_read64(rvu, blkaddr, NIX_AF_TL1X_SHAPE(schq))); 1866 seq_printf(m, "NIX_AF_TL1[%llu]_CIR =0x%llx\n", schq, 1867 rvu_read64(rvu, blkaddr, NIX_AF_TL1X_CIR(schq))); 1868 seq_printf(m, "NIX_AF_TL1[%llu]_SW_XOFF =0x%llx\n", schq, 1869 rvu_read64(rvu, blkaddr, NIX_AF_TL1X_SW_XOFF(schq))); 1870 seq_printf(m, "NIX_AF_TL1[%llu]_TOPOLOGY =0x%llx\n", schq, 1871 rvu_read64(rvu, blkaddr, 1872 NIX_AF_TL1X_TOPOLOGY(schq))); 1873 seq_printf(m, "NIX_AF_TL1[%llu]_MD_DEBUG0 =0x%llx\n", schq, 1874 rvu_read64(rvu, blkaddr, 1875 NIX_AF_TL1X_MD_DEBUG0(schq))); 1876 seq_printf(m, "NIX_AF_TL1[%llu]_MD_DEBUG1 =0x%llx\n", schq, 1877 rvu_read64(rvu, blkaddr, 1878 NIX_AF_TL1X_MD_DEBUG1(schq))); 1879 seq_printf(m, "NIX_AF_TL1[%llu]_DROPPED_PACKETS =0x%llx\n", 1880 schq, 1881 rvu_read64(rvu, blkaddr, 1882 NIX_AF_TL1X_DROPPED_PACKETS(schq))); 1883 seq_printf(m, "NIX_AF_TL1[%llu]_DROPPED_BYTES =0x%llx\n", schq, 1884 rvu_read64(rvu, blkaddr, 1885 NIX_AF_TL1X_DROPPED_BYTES(schq))); 1886 seq_printf(m, "NIX_AF_TL1[%llu]_RED_PACKETS =0x%llx\n", schq, 1887 rvu_read64(rvu, blkaddr, 1888 NIX_AF_TL1X_RED_PACKETS(schq))); 1889 seq_printf(m, "NIX_AF_TL1[%llu]_RED_BYTES =0x%llx\n", schq, 1890 rvu_read64(rvu, blkaddr, 1891 NIX_AF_TL1X_RED_BYTES(schq))); 1892 seq_printf(m, "NIX_AF_TL1[%llu]_YELLOW_PACKETS =0x%llx\n", schq, 1893 rvu_read64(rvu, blkaddr, 1894 NIX_AF_TL1X_YELLOW_PACKETS(schq))); 1895 seq_printf(m, "NIX_AF_TL1[%llu]_YELLOW_BYTES =0x%llx\n", schq, 1896 rvu_read64(rvu, blkaddr, 1897 NIX_AF_TL1X_YELLOW_BYTES(schq))); 1898 seq_printf(m, "NIX_AF_TL1[%llu]_GREEN_PACKETS =0x%llx\n", schq, 1899 rvu_read64(rvu, blkaddr, 1900 NIX_AF_TL1X_GREEN_PACKETS(schq))); 1901 seq_printf(m, "NIX_AF_TL1[%llu]_GREEN_BYTES =0x%llx\n", schq, 1902 rvu_read64(rvu, blkaddr, 1903 NIX_AF_TL1X_GREEN_BYTES(schq))); 1904 seq_puts(m, "\n"); 1905 } 1906 } 1907 1908 /*dumps given tm_topo registers*/ 1909 static int rvu_dbg_nix_tm_topo_display(struct seq_file *m, void *unused) 1910 { 1911 struct nix_hw *nix_hw = m->private; 1912 struct rvu *rvu = nix_hw->rvu; 1913 struct nix_aq_enq_req aq_req; 1914 struct nix_txsch *txsch; 1915 int nixlf, lvl, schq; 1916 u16 pcifunc; 1917 1918 nixlf = rvu->rvu_dbg.nix_tm_ctx.lf; 1919 1920 if (!rvu_dbg_is_valid_lf(rvu, nix_hw->blkaddr, nixlf, &pcifunc)) 1921 return -EINVAL; 1922 1923 memset(&aq_req, 0, sizeof(struct nix_aq_enq_req)); 1924 aq_req.hdr.pcifunc = pcifunc; 1925 aq_req.ctype = NIX_AQ_CTYPE_SQ; 1926 aq_req.op = NIX_AQ_INSTOP_READ; 1927 seq_printf(m, "pcifunc is 0x%x\n", pcifunc); 1928 1929 for (lvl = 0; lvl < NIX_TXSCH_LVL_CNT; lvl++) { 1930 txsch = &nix_hw->txsch[lvl]; 1931 for (schq = 0; schq < txsch->schq.max; schq++) { 1932 if (TXSCH_MAP_FUNC(txsch->pfvf_map[schq]) == pcifunc) 1933 print_tm_topo(m, schq, lvl); 1934 } 1935 } 1936 return 0; 1937 } 1938 1939 static ssize_t rvu_dbg_nix_tm_topo_write(struct file *filp, 1940 const char __user *buffer, 1941 size_t count, loff_t *ppos) 1942 { 1943 struct seq_file *m = filp->private_data; 1944 struct nix_hw *nix_hw = m->private; 1945 struct rvu *rvu = nix_hw->rvu; 1946 struct rvu_pfvf *pfvf; 1947 u16 pcifunc; 1948 u64 nixlf; 1949 int ret; 1950 1951 ret = kstrtoull_from_user(buffer, count, 10, &nixlf); 1952 if (ret) 1953 return ret; 1954 1955 if (!rvu_dbg_is_valid_lf(rvu, nix_hw->blkaddr, nixlf, &pcifunc)) 1956 return -EINVAL; 1957 1958 pfvf = rvu_get_pfvf(rvu, pcifunc); 1959 if (!pfvf->sq_ctx) { 1960 dev_warn(rvu->dev, "SQ context is not initialized\n"); 1961 return -EINVAL; 1962 } 1963 1964 rvu->rvu_dbg.nix_tm_ctx.lf = nixlf; 1965 return count; 1966 } 1967 1968 RVU_DEBUG_SEQ_FOPS(nix_tm_topo, nix_tm_topo_display, nix_tm_topo_write); 1969 1970 /* Dumps given nix_sq's context */ 1971 static void print_nix_sq_ctx(struct seq_file *m, struct nix_aq_enq_rsp *rsp) 1972 { 1973 struct nix_sq_ctx_s *sq_ctx = &rsp->sq; 1974 struct nix_hw *nix_hw = m->private; 1975 struct rvu *rvu = nix_hw->rvu; 1976 1977 if (!is_rvu_otx2(rvu)) { 1978 print_nix_cn10k_sq_ctx(m, (struct nix_cn10k_sq_ctx_s *)sq_ctx); 1979 return; 1980 } 1981 seq_printf(m, "W0: sqe_way_mask \t\t%d\nW0: cq \t\t\t\t%d\n", 1982 sq_ctx->sqe_way_mask, sq_ctx->cq); 1983 seq_printf(m, "W0: sdp_mcast \t\t\t%d\nW0: substream \t\t\t0x%03x\n", 1984 sq_ctx->sdp_mcast, sq_ctx->substream); 1985 seq_printf(m, "W0: qint_idx \t\t\t%d\nW0: ena \t\t\t%d\n\n", 1986 sq_ctx->qint_idx, sq_ctx->ena); 1987 1988 seq_printf(m, "W1: sqb_count \t\t\t%d\nW1: default_chan \t\t%d\n", 1989 sq_ctx->sqb_count, sq_ctx->default_chan); 1990 seq_printf(m, "W1: smq_rr_quantum \t\t%d\nW1: sso_ena \t\t\t%d\n", 1991 sq_ctx->smq_rr_quantum, sq_ctx->sso_ena); 1992 seq_printf(m, "W1: xoff \t\t\t%d\nW1: cq_ena \t\t\t%d\nW1: smq\t\t\t\t%d\n\n", 1993 sq_ctx->xoff, sq_ctx->cq_ena, sq_ctx->smq); 1994 1995 seq_printf(m, "W2: sqe_stype \t\t\t%d\nW2: sq_int_ena \t\t\t%d\n", 1996 sq_ctx->sqe_stype, sq_ctx->sq_int_ena); 1997 seq_printf(m, "W2: sq_int \t\t\t%d\nW2: sqb_aura \t\t\t%d\n", 1998 sq_ctx->sq_int, sq_ctx->sqb_aura); 1999 seq_printf(m, "W2: smq_rr_count \t\t%d\n\n", sq_ctx->smq_rr_count); 2000 2001 seq_printf(m, "W3: smq_next_sq_vld\t\t%d\nW3: smq_pend\t\t\t%d\n", 2002 sq_ctx->smq_next_sq_vld, sq_ctx->smq_pend); 2003 seq_printf(m, "W3: smenq_next_sqb_vld \t\t%d\nW3: head_offset\t\t\t%d\n", 2004 sq_ctx->smenq_next_sqb_vld, sq_ctx->head_offset); 2005 seq_printf(m, "W3: smenq_offset\t\t%d\nW3: tail_offset\t\t\t%d\n", 2006 sq_ctx->smenq_offset, sq_ctx->tail_offset); 2007 seq_printf(m, "W3: smq_lso_segnum \t\t%d\nW3: smq_next_sq\t\t\t%d\n", 2008 sq_ctx->smq_lso_segnum, sq_ctx->smq_next_sq); 2009 seq_printf(m, "W3: mnq_dis \t\t\t%d\nW3: lmt_dis \t\t\t%d\n", 2010 sq_ctx->mnq_dis, sq_ctx->lmt_dis); 2011 seq_printf(m, "W3: cq_limit\t\t\t%d\nW3: max_sqe_size\t\t%d\n\n", 2012 sq_ctx->cq_limit, sq_ctx->max_sqe_size); 2013 2014 seq_printf(m, "W4: next_sqb \t\t\t%llx\n\n", sq_ctx->next_sqb); 2015 seq_printf(m, "W5: tail_sqb \t\t\t%llx\n\n", sq_ctx->tail_sqb); 2016 seq_printf(m, "W6: smenq_sqb \t\t\t%llx\n\n", sq_ctx->smenq_sqb); 2017 seq_printf(m, "W7: smenq_next_sqb \t\t%llx\n\n", 2018 sq_ctx->smenq_next_sqb); 2019 2020 seq_printf(m, "W8: head_sqb\t\t\t%llx\n\n", sq_ctx->head_sqb); 2021 2022 seq_printf(m, "W9: vfi_lso_vld\t\t\t%d\nW9: vfi_lso_vlan1_ins_ena\t%d\n", 2023 sq_ctx->vfi_lso_vld, sq_ctx->vfi_lso_vlan1_ins_ena); 2024 seq_printf(m, "W9: vfi_lso_vlan0_ins_ena\t%d\nW9: vfi_lso_mps\t\t\t%d\n", 2025 sq_ctx->vfi_lso_vlan0_ins_ena, sq_ctx->vfi_lso_mps); 2026 seq_printf(m, "W9: vfi_lso_sb\t\t\t%d\nW9: vfi_lso_sizem1\t\t%d\n", 2027 sq_ctx->vfi_lso_sb, sq_ctx->vfi_lso_sizem1); 2028 seq_printf(m, "W9: vfi_lso_total\t\t%d\n\n", sq_ctx->vfi_lso_total); 2029 2030 seq_printf(m, "W10: scm_lso_rem \t\t%llu\n\n", 2031 (u64)sq_ctx->scm_lso_rem); 2032 seq_printf(m, "W11: octs \t\t\t%llu\n\n", (u64)sq_ctx->octs); 2033 seq_printf(m, "W12: pkts \t\t\t%llu\n\n", (u64)sq_ctx->pkts); 2034 seq_printf(m, "W14: dropped_octs \t\t%llu\n\n", 2035 (u64)sq_ctx->dropped_octs); 2036 seq_printf(m, "W15: dropped_pkts \t\t%llu\n\n", 2037 (u64)sq_ctx->dropped_pkts); 2038 } 2039 2040 static void print_nix_cn10k_rq_ctx(struct seq_file *m, 2041 struct nix_cn10k_rq_ctx_s *rq_ctx) 2042 { 2043 seq_printf(m, "W0: ena \t\t\t%d\nW0: sso_ena \t\t\t%d\n", 2044 rq_ctx->ena, rq_ctx->sso_ena); 2045 seq_printf(m, "W0: ipsech_ena \t\t\t%d\nW0: ena_wqwd \t\t\t%d\n", 2046 rq_ctx->ipsech_ena, rq_ctx->ena_wqwd); 2047 seq_printf(m, "W0: cq \t\t\t\t%d\nW0: lenerr_dis \t\t\t%d\n", 2048 rq_ctx->cq, rq_ctx->lenerr_dis); 2049 seq_printf(m, "W0: csum_il4_dis \t\t%d\nW0: csum_ol4_dis \t\t%d\n", 2050 rq_ctx->csum_il4_dis, rq_ctx->csum_ol4_dis); 2051 seq_printf(m, "W0: len_il4_dis \t\t%d\nW0: len_il3_dis \t\t%d\n", 2052 rq_ctx->len_il4_dis, rq_ctx->len_il3_dis); 2053 seq_printf(m, "W0: len_ol4_dis \t\t%d\nW0: len_ol3_dis \t\t%d\n", 2054 rq_ctx->len_ol4_dis, rq_ctx->len_ol3_dis); 2055 seq_printf(m, "W0: wqe_aura \t\t\t%d\n\n", rq_ctx->wqe_aura); 2056 2057 seq_printf(m, "W1: spb_aura \t\t\t%d\nW1: lpb_aura \t\t\t%d\n", 2058 rq_ctx->spb_aura, rq_ctx->lpb_aura); 2059 seq_printf(m, "W1: spb_aura \t\t\t%d\n", rq_ctx->spb_aura); 2060 seq_printf(m, "W1: sso_grp \t\t\t%d\nW1: sso_tt \t\t\t%d\n", 2061 rq_ctx->sso_grp, rq_ctx->sso_tt); 2062 seq_printf(m, "W1: pb_caching \t\t\t%d\nW1: wqe_caching \t\t%d\n", 2063 rq_ctx->pb_caching, rq_ctx->wqe_caching); 2064 seq_printf(m, "W1: xqe_drop_ena \t\t%d\nW1: spb_drop_ena \t\t%d\n", 2065 rq_ctx->xqe_drop_ena, rq_ctx->spb_drop_ena); 2066 seq_printf(m, "W1: lpb_drop_ena \t\t%d\nW1: pb_stashing \t\t%d\n", 2067 rq_ctx->lpb_drop_ena, rq_ctx->pb_stashing); 2068 seq_printf(m, "W1: ipsecd_drop_ena \t\t%d\nW1: chi_ena \t\t\t%d\n\n", 2069 rq_ctx->ipsecd_drop_ena, rq_ctx->chi_ena); 2070 2071 seq_printf(m, "W2: band_prof_id \t\t%d\n", rq_ctx->band_prof_id); 2072 seq_printf(m, "W2: policer_ena \t\t%d\n", rq_ctx->policer_ena); 2073 seq_printf(m, "W2: spb_sizem1 \t\t\t%d\n", rq_ctx->spb_sizem1); 2074 seq_printf(m, "W2: wqe_skip \t\t\t%d\nW2: sqb_ena \t\t\t%d\n", 2075 rq_ctx->wqe_skip, rq_ctx->spb_ena); 2076 seq_printf(m, "W2: lpb_size1 \t\t\t%d\nW2: first_skip \t\t\t%d\n", 2077 rq_ctx->lpb_sizem1, rq_ctx->first_skip); 2078 seq_printf(m, "W2: later_skip\t\t\t%d\nW2: xqe_imm_size\t\t%d\n", 2079 rq_ctx->later_skip, rq_ctx->xqe_imm_size); 2080 seq_printf(m, "W2: xqe_imm_copy \t\t%d\nW2: xqe_hdr_split \t\t%d\n\n", 2081 rq_ctx->xqe_imm_copy, rq_ctx->xqe_hdr_split); 2082 2083 seq_printf(m, "W3: xqe_drop \t\t\t%d\nW3: xqe_pass \t\t\t%d\n", 2084 rq_ctx->xqe_drop, rq_ctx->xqe_pass); 2085 seq_printf(m, "W3: wqe_pool_drop \t\t%d\nW3: wqe_pool_pass \t\t%d\n", 2086 rq_ctx->wqe_pool_drop, rq_ctx->wqe_pool_pass); 2087 seq_printf(m, "W3: spb_pool_drop \t\t%d\nW3: spb_pool_pass \t\t%d\n", 2088 rq_ctx->spb_pool_drop, rq_ctx->spb_pool_pass); 2089 seq_printf(m, "W3: spb_aura_drop \t\t%d\nW3: spb_aura_pass \t\t%d\n\n", 2090 rq_ctx->spb_aura_pass, rq_ctx->spb_aura_drop); 2091 2092 seq_printf(m, "W4: lpb_aura_drop \t\t%d\nW3: lpb_aura_pass \t\t%d\n", 2093 rq_ctx->lpb_aura_pass, rq_ctx->lpb_aura_drop); 2094 seq_printf(m, "W4: lpb_pool_drop \t\t%d\nW3: lpb_pool_pass \t\t%d\n", 2095 rq_ctx->lpb_pool_drop, rq_ctx->lpb_pool_pass); 2096 seq_printf(m, "W4: rq_int \t\t\t%d\nW4: rq_int_ena\t\t\t%d\n", 2097 rq_ctx->rq_int, rq_ctx->rq_int_ena); 2098 seq_printf(m, "W4: qint_idx \t\t\t%d\n\n", rq_ctx->qint_idx); 2099 2100 seq_printf(m, "W5: ltag \t\t\t%d\nW5: good_utag \t\t\t%d\n", 2101 rq_ctx->ltag, rq_ctx->good_utag); 2102 seq_printf(m, "W5: bad_utag \t\t\t%d\nW5: flow_tagw \t\t\t%d\n", 2103 rq_ctx->bad_utag, rq_ctx->flow_tagw); 2104 seq_printf(m, "W5: ipsec_vwqe \t\t\t%d\nW5: vwqe_ena \t\t\t%d\n", 2105 rq_ctx->ipsec_vwqe, rq_ctx->vwqe_ena); 2106 seq_printf(m, "W5: vwqe_wait \t\t\t%d\nW5: max_vsize_exp\t\t%d\n", 2107 rq_ctx->vwqe_wait, rq_ctx->max_vsize_exp); 2108 seq_printf(m, "W5: vwqe_skip \t\t\t%d\n\n", rq_ctx->vwqe_skip); 2109 2110 seq_printf(m, "W6: octs \t\t\t%llu\n\n", (u64)rq_ctx->octs); 2111 seq_printf(m, "W7: pkts \t\t\t%llu\n\n", (u64)rq_ctx->pkts); 2112 seq_printf(m, "W8: drop_octs \t\t\t%llu\n\n", (u64)rq_ctx->drop_octs); 2113 seq_printf(m, "W9: drop_pkts \t\t\t%llu\n\n", (u64)rq_ctx->drop_pkts); 2114 seq_printf(m, "W10: re_pkts \t\t\t%llu\n", (u64)rq_ctx->re_pkts); 2115 } 2116 2117 /* Dumps given nix_rq's context */ 2118 static void print_nix_rq_ctx(struct seq_file *m, struct nix_aq_enq_rsp *rsp) 2119 { 2120 struct nix_rq_ctx_s *rq_ctx = &rsp->rq; 2121 struct nix_hw *nix_hw = m->private; 2122 struct rvu *rvu = nix_hw->rvu; 2123 2124 if (!is_rvu_otx2(rvu)) { 2125 print_nix_cn10k_rq_ctx(m, (struct nix_cn10k_rq_ctx_s *)rq_ctx); 2126 return; 2127 } 2128 2129 seq_printf(m, "W0: wqe_aura \t\t\t%d\nW0: substream \t\t\t0x%03x\n", 2130 rq_ctx->wqe_aura, rq_ctx->substream); 2131 seq_printf(m, "W0: cq \t\t\t\t%d\nW0: ena_wqwd \t\t\t%d\n", 2132 rq_ctx->cq, rq_ctx->ena_wqwd); 2133 seq_printf(m, "W0: ipsech_ena \t\t\t%d\nW0: sso_ena \t\t\t%d\n", 2134 rq_ctx->ipsech_ena, rq_ctx->sso_ena); 2135 seq_printf(m, "W0: ena \t\t\t%d\n\n", rq_ctx->ena); 2136 2137 seq_printf(m, "W1: lpb_drop_ena \t\t%d\nW1: spb_drop_ena \t\t%d\n", 2138 rq_ctx->lpb_drop_ena, rq_ctx->spb_drop_ena); 2139 seq_printf(m, "W1: xqe_drop_ena \t\t%d\nW1: wqe_caching \t\t%d\n", 2140 rq_ctx->xqe_drop_ena, rq_ctx->wqe_caching); 2141 seq_printf(m, "W1: pb_caching \t\t\t%d\nW1: sso_tt \t\t\t%d\n", 2142 rq_ctx->pb_caching, rq_ctx->sso_tt); 2143 seq_printf(m, "W1: sso_grp \t\t\t%d\nW1: lpb_aura \t\t\t%d\n", 2144 rq_ctx->sso_grp, rq_ctx->lpb_aura); 2145 seq_printf(m, "W1: spb_aura \t\t\t%d\n\n", rq_ctx->spb_aura); 2146 2147 seq_printf(m, "W2: xqe_hdr_split \t\t%d\nW2: xqe_imm_copy \t\t%d\n", 2148 rq_ctx->xqe_hdr_split, rq_ctx->xqe_imm_copy); 2149 seq_printf(m, "W2: xqe_imm_size \t\t%d\nW2: later_skip \t\t\t%d\n", 2150 rq_ctx->xqe_imm_size, rq_ctx->later_skip); 2151 seq_printf(m, "W2: first_skip \t\t\t%d\nW2: lpb_sizem1 \t\t\t%d\n", 2152 rq_ctx->first_skip, rq_ctx->lpb_sizem1); 2153 seq_printf(m, "W2: spb_ena \t\t\t%d\nW2: wqe_skip \t\t\t%d\n", 2154 rq_ctx->spb_ena, rq_ctx->wqe_skip); 2155 seq_printf(m, "W2: spb_sizem1 \t\t\t%d\n\n", rq_ctx->spb_sizem1); 2156 2157 seq_printf(m, "W3: spb_pool_pass \t\t%d\nW3: spb_pool_drop \t\t%d\n", 2158 rq_ctx->spb_pool_pass, rq_ctx->spb_pool_drop); 2159 seq_printf(m, "W3: spb_aura_pass \t\t%d\nW3: spb_aura_drop \t\t%d\n", 2160 rq_ctx->spb_aura_pass, rq_ctx->spb_aura_drop); 2161 seq_printf(m, "W3: wqe_pool_pass \t\t%d\nW3: wqe_pool_drop \t\t%d\n", 2162 rq_ctx->wqe_pool_pass, rq_ctx->wqe_pool_drop); 2163 seq_printf(m, "W3: xqe_pass \t\t\t%d\nW3: xqe_drop \t\t\t%d\n\n", 2164 rq_ctx->xqe_pass, rq_ctx->xqe_drop); 2165 2166 seq_printf(m, "W4: qint_idx \t\t\t%d\nW4: rq_int_ena \t\t\t%d\n", 2167 rq_ctx->qint_idx, rq_ctx->rq_int_ena); 2168 seq_printf(m, "W4: rq_int \t\t\t%d\nW4: lpb_pool_pass \t\t%d\n", 2169 rq_ctx->rq_int, rq_ctx->lpb_pool_pass); 2170 seq_printf(m, "W4: lpb_pool_drop \t\t%d\nW4: lpb_aura_pass \t\t%d\n", 2171 rq_ctx->lpb_pool_drop, rq_ctx->lpb_aura_pass); 2172 seq_printf(m, "W4: lpb_aura_drop \t\t%d\n\n", rq_ctx->lpb_aura_drop); 2173 2174 seq_printf(m, "W5: flow_tagw \t\t\t%d\nW5: bad_utag \t\t\t%d\n", 2175 rq_ctx->flow_tagw, rq_ctx->bad_utag); 2176 seq_printf(m, "W5: good_utag \t\t\t%d\nW5: ltag \t\t\t%d\n\n", 2177 rq_ctx->good_utag, rq_ctx->ltag); 2178 2179 seq_printf(m, "W6: octs \t\t\t%llu\n\n", (u64)rq_ctx->octs); 2180 seq_printf(m, "W7: pkts \t\t\t%llu\n\n", (u64)rq_ctx->pkts); 2181 seq_printf(m, "W8: drop_octs \t\t\t%llu\n\n", (u64)rq_ctx->drop_octs); 2182 seq_printf(m, "W9: drop_pkts \t\t\t%llu\n\n", (u64)rq_ctx->drop_pkts); 2183 seq_printf(m, "W10: re_pkts \t\t\t%llu\n", (u64)rq_ctx->re_pkts); 2184 } 2185 2186 /* Dumps given nix_cq's context */ 2187 static void print_nix_cq_ctx(struct seq_file *m, struct nix_aq_enq_rsp *rsp) 2188 { 2189 struct nix_cq_ctx_s *cq_ctx = &rsp->cq; 2190 struct nix_hw *nix_hw = m->private; 2191 struct rvu *rvu = nix_hw->rvu; 2192 2193 seq_printf(m, "W0: base \t\t\t%llx\n\n", cq_ctx->base); 2194 2195 seq_printf(m, "W1: wrptr \t\t\t%llx\n", (u64)cq_ctx->wrptr); 2196 seq_printf(m, "W1: avg_con \t\t\t%d\nW1: cint_idx \t\t\t%d\n", 2197 cq_ctx->avg_con, cq_ctx->cint_idx); 2198 seq_printf(m, "W1: cq_err \t\t\t%d\nW1: qint_idx \t\t\t%d\n", 2199 cq_ctx->cq_err, cq_ctx->qint_idx); 2200 seq_printf(m, "W1: bpid \t\t\t%d\nW1: bp_ena \t\t\t%d\n\n", 2201 cq_ctx->bpid, cq_ctx->bp_ena); 2202 2203 if (!is_rvu_otx2(rvu)) { 2204 seq_printf(m, "W1: lbpid_high \t\t\t0x%03x\n", cq_ctx->lbpid_high); 2205 seq_printf(m, "W1: lbpid_med \t\t\t0x%03x\n", cq_ctx->lbpid_med); 2206 seq_printf(m, "W1: lbpid_low \t\t\t0x%03x\n", cq_ctx->lbpid_low); 2207 seq_printf(m, "(W1: lbpid) \t\t\t0x%03x\n", 2208 cq_ctx->lbpid_high << 6 | cq_ctx->lbpid_med << 3 | 2209 cq_ctx->lbpid_low); 2210 seq_printf(m, "W1: lbp_ena \t\t\t\t%d\n\n", cq_ctx->lbp_ena); 2211 } 2212 2213 seq_printf(m, "W2: update_time \t\t%d\nW2:avg_level \t\t\t%d\n", 2214 cq_ctx->update_time, cq_ctx->avg_level); 2215 seq_printf(m, "W2: head \t\t\t%d\nW2:tail \t\t\t%d\n\n", 2216 cq_ctx->head, cq_ctx->tail); 2217 2218 seq_printf(m, "W3: cq_err_int_ena \t\t%d\nW3:cq_err_int \t\t\t%d\n", 2219 cq_ctx->cq_err_int_ena, cq_ctx->cq_err_int); 2220 seq_printf(m, "W3: qsize \t\t\t%d\nW3:caching \t\t\t%d\n", 2221 cq_ctx->qsize, cq_ctx->caching); 2222 seq_printf(m, "W3: substream \t\t\t0x%03x\nW3: ena \t\t\t%d\n", 2223 cq_ctx->substream, cq_ctx->ena); 2224 if (!is_rvu_otx2(rvu)) { 2225 seq_printf(m, "W3: lbp_frac \t\t\t%d\n", cq_ctx->lbp_frac); 2226 seq_printf(m, "W3: cpt_drop_err_en \t\t\t%d\n", 2227 cq_ctx->cpt_drop_err_en); 2228 } 2229 seq_printf(m, "W3: drop_ena \t\t\t%d\nW3: drop \t\t\t%d\n", 2230 cq_ctx->drop_ena, cq_ctx->drop); 2231 seq_printf(m, "W3: bp \t\t\t\t%d\n\n", cq_ctx->bp); 2232 } 2233 2234 static int rvu_dbg_nix_queue_ctx_display(struct seq_file *filp, 2235 void *unused, int ctype) 2236 { 2237 void (*print_nix_ctx)(struct seq_file *filp, 2238 struct nix_aq_enq_rsp *rsp) = NULL; 2239 struct nix_hw *nix_hw = filp->private; 2240 struct rvu *rvu = nix_hw->rvu; 2241 struct nix_aq_enq_req aq_req; 2242 struct nix_aq_enq_rsp rsp; 2243 char *ctype_string = NULL; 2244 int qidx, rc, max_id = 0; 2245 struct rvu_pfvf *pfvf; 2246 int nixlf, id, all; 2247 u16 pcifunc; 2248 2249 switch (ctype) { 2250 case NIX_AQ_CTYPE_CQ: 2251 nixlf = rvu->rvu_dbg.nix_cq_ctx.lf; 2252 id = rvu->rvu_dbg.nix_cq_ctx.id; 2253 all = rvu->rvu_dbg.nix_cq_ctx.all; 2254 break; 2255 2256 case NIX_AQ_CTYPE_SQ: 2257 nixlf = rvu->rvu_dbg.nix_sq_ctx.lf; 2258 id = rvu->rvu_dbg.nix_sq_ctx.id; 2259 all = rvu->rvu_dbg.nix_sq_ctx.all; 2260 break; 2261 2262 case NIX_AQ_CTYPE_RQ: 2263 nixlf = rvu->rvu_dbg.nix_rq_ctx.lf; 2264 id = rvu->rvu_dbg.nix_rq_ctx.id; 2265 all = rvu->rvu_dbg.nix_rq_ctx.all; 2266 break; 2267 2268 default: 2269 return -EINVAL; 2270 } 2271 2272 if (!rvu_dbg_is_valid_lf(rvu, nix_hw->blkaddr, nixlf, &pcifunc)) 2273 return -EINVAL; 2274 2275 pfvf = rvu_get_pfvf(rvu, pcifunc); 2276 if (ctype == NIX_AQ_CTYPE_SQ && !pfvf->sq_ctx) { 2277 seq_puts(filp, "SQ context is not initialized\n"); 2278 return -EINVAL; 2279 } else if (ctype == NIX_AQ_CTYPE_RQ && !pfvf->rq_ctx) { 2280 seq_puts(filp, "RQ context is not initialized\n"); 2281 return -EINVAL; 2282 } else if (ctype == NIX_AQ_CTYPE_CQ && !pfvf->cq_ctx) { 2283 seq_puts(filp, "CQ context is not initialized\n"); 2284 return -EINVAL; 2285 } 2286 2287 if (ctype == NIX_AQ_CTYPE_SQ) { 2288 max_id = pfvf->sq_ctx->qsize; 2289 ctype_string = "sq"; 2290 print_nix_ctx = print_nix_sq_ctx; 2291 } else if (ctype == NIX_AQ_CTYPE_RQ) { 2292 max_id = pfvf->rq_ctx->qsize; 2293 ctype_string = "rq"; 2294 print_nix_ctx = print_nix_rq_ctx; 2295 } else if (ctype == NIX_AQ_CTYPE_CQ) { 2296 max_id = pfvf->cq_ctx->qsize; 2297 ctype_string = "cq"; 2298 print_nix_ctx = print_nix_cq_ctx; 2299 } 2300 2301 memset(&aq_req, 0, sizeof(struct nix_aq_enq_req)); 2302 aq_req.hdr.pcifunc = pcifunc; 2303 aq_req.ctype = ctype; 2304 aq_req.op = NIX_AQ_INSTOP_READ; 2305 if (all) 2306 id = 0; 2307 else 2308 max_id = id + 1; 2309 for (qidx = id; qidx < max_id; qidx++) { 2310 aq_req.qidx = qidx; 2311 seq_printf(filp, "=====%s_ctx for nixlf:%d and qidx:%d is=====\n", 2312 ctype_string, nixlf, aq_req.qidx); 2313 rc = rvu_mbox_handler_nix_aq_enq(rvu, &aq_req, &rsp); 2314 if (rc) { 2315 seq_puts(filp, "Failed to read the context\n"); 2316 return -EINVAL; 2317 } 2318 print_nix_ctx(filp, &rsp); 2319 } 2320 return 0; 2321 } 2322 2323 static int write_nix_queue_ctx(struct rvu *rvu, bool all, int nixlf, 2324 int id, int ctype, char *ctype_string, 2325 struct seq_file *m) 2326 { 2327 struct nix_hw *nix_hw = m->private; 2328 struct rvu_pfvf *pfvf; 2329 int max_id = 0; 2330 u16 pcifunc; 2331 2332 if (!rvu_dbg_is_valid_lf(rvu, nix_hw->blkaddr, nixlf, &pcifunc)) 2333 return -EINVAL; 2334 2335 pfvf = rvu_get_pfvf(rvu, pcifunc); 2336 2337 if (ctype == NIX_AQ_CTYPE_SQ) { 2338 if (!pfvf->sq_ctx) { 2339 dev_warn(rvu->dev, "SQ context is not initialized\n"); 2340 return -EINVAL; 2341 } 2342 max_id = pfvf->sq_ctx->qsize; 2343 } else if (ctype == NIX_AQ_CTYPE_RQ) { 2344 if (!pfvf->rq_ctx) { 2345 dev_warn(rvu->dev, "RQ context is not initialized\n"); 2346 return -EINVAL; 2347 } 2348 max_id = pfvf->rq_ctx->qsize; 2349 } else if (ctype == NIX_AQ_CTYPE_CQ) { 2350 if (!pfvf->cq_ctx) { 2351 dev_warn(rvu->dev, "CQ context is not initialized\n"); 2352 return -EINVAL; 2353 } 2354 max_id = pfvf->cq_ctx->qsize; 2355 } 2356 2357 if (id < 0 || id >= max_id) { 2358 dev_warn(rvu->dev, "Invalid %s_ctx valid range 0-%d\n", 2359 ctype_string, max_id - 1); 2360 return -EINVAL; 2361 } 2362 switch (ctype) { 2363 case NIX_AQ_CTYPE_CQ: 2364 rvu->rvu_dbg.nix_cq_ctx.lf = nixlf; 2365 rvu->rvu_dbg.nix_cq_ctx.id = id; 2366 rvu->rvu_dbg.nix_cq_ctx.all = all; 2367 break; 2368 2369 case NIX_AQ_CTYPE_SQ: 2370 rvu->rvu_dbg.nix_sq_ctx.lf = nixlf; 2371 rvu->rvu_dbg.nix_sq_ctx.id = id; 2372 rvu->rvu_dbg.nix_sq_ctx.all = all; 2373 break; 2374 2375 case NIX_AQ_CTYPE_RQ: 2376 rvu->rvu_dbg.nix_rq_ctx.lf = nixlf; 2377 rvu->rvu_dbg.nix_rq_ctx.id = id; 2378 rvu->rvu_dbg.nix_rq_ctx.all = all; 2379 break; 2380 default: 2381 return -EINVAL; 2382 } 2383 return 0; 2384 } 2385 2386 static ssize_t rvu_dbg_nix_queue_ctx_write(struct file *filp, 2387 const char __user *buffer, 2388 size_t count, loff_t *ppos, 2389 int ctype) 2390 { 2391 struct seq_file *m = filp->private_data; 2392 struct nix_hw *nix_hw = m->private; 2393 struct rvu *rvu = nix_hw->rvu; 2394 char *cmd_buf, *ctype_string; 2395 int nixlf, id = 0, ret; 2396 bool all = false; 2397 2398 if ((*ppos != 0) || !count) 2399 return -EINVAL; 2400 2401 switch (ctype) { 2402 case NIX_AQ_CTYPE_SQ: 2403 ctype_string = "sq"; 2404 break; 2405 case NIX_AQ_CTYPE_RQ: 2406 ctype_string = "rq"; 2407 break; 2408 case NIX_AQ_CTYPE_CQ: 2409 ctype_string = "cq"; 2410 break; 2411 default: 2412 return -EINVAL; 2413 } 2414 2415 cmd_buf = kzalloc(count + 1, GFP_KERNEL); 2416 2417 if (!cmd_buf) 2418 return count; 2419 2420 ret = parse_cmd_buffer_ctx(cmd_buf, &count, buffer, 2421 &nixlf, &id, &all); 2422 if (ret < 0) { 2423 dev_info(rvu->dev, 2424 "Usage: echo <nixlf> [%s number/all] > %s_ctx\n", 2425 ctype_string, ctype_string); 2426 goto done; 2427 } else { 2428 ret = write_nix_queue_ctx(rvu, all, nixlf, id, ctype, 2429 ctype_string, m); 2430 } 2431 done: 2432 kfree(cmd_buf); 2433 return ret ? ret : count; 2434 } 2435 2436 static ssize_t rvu_dbg_nix_sq_ctx_write(struct file *filp, 2437 const char __user *buffer, 2438 size_t count, loff_t *ppos) 2439 { 2440 return rvu_dbg_nix_queue_ctx_write(filp, buffer, count, ppos, 2441 NIX_AQ_CTYPE_SQ); 2442 } 2443 2444 static int rvu_dbg_nix_sq_ctx_display(struct seq_file *filp, void *unused) 2445 { 2446 return rvu_dbg_nix_queue_ctx_display(filp, unused, NIX_AQ_CTYPE_SQ); 2447 } 2448 2449 RVU_DEBUG_SEQ_FOPS(nix_sq_ctx, nix_sq_ctx_display, nix_sq_ctx_write); 2450 2451 static ssize_t rvu_dbg_nix_rq_ctx_write(struct file *filp, 2452 const char __user *buffer, 2453 size_t count, loff_t *ppos) 2454 { 2455 return rvu_dbg_nix_queue_ctx_write(filp, buffer, count, ppos, 2456 NIX_AQ_CTYPE_RQ); 2457 } 2458 2459 static int rvu_dbg_nix_rq_ctx_display(struct seq_file *filp, void *unused) 2460 { 2461 return rvu_dbg_nix_queue_ctx_display(filp, unused, NIX_AQ_CTYPE_RQ); 2462 } 2463 2464 RVU_DEBUG_SEQ_FOPS(nix_rq_ctx, nix_rq_ctx_display, nix_rq_ctx_write); 2465 2466 static ssize_t rvu_dbg_nix_cq_ctx_write(struct file *filp, 2467 const char __user *buffer, 2468 size_t count, loff_t *ppos) 2469 { 2470 return rvu_dbg_nix_queue_ctx_write(filp, buffer, count, ppos, 2471 NIX_AQ_CTYPE_CQ); 2472 } 2473 2474 static int rvu_dbg_nix_cq_ctx_display(struct seq_file *filp, void *unused) 2475 { 2476 return rvu_dbg_nix_queue_ctx_display(filp, unused, NIX_AQ_CTYPE_CQ); 2477 } 2478 2479 RVU_DEBUG_SEQ_FOPS(nix_cq_ctx, nix_cq_ctx_display, nix_cq_ctx_write); 2480 2481 static void print_nix_qctx_qsize(struct seq_file *filp, int qsize, 2482 unsigned long *bmap, char *qtype) 2483 { 2484 char *buf; 2485 2486 buf = kmalloc(PAGE_SIZE, GFP_KERNEL); 2487 if (!buf) 2488 return; 2489 2490 bitmap_print_to_pagebuf(false, buf, bmap, qsize); 2491 seq_printf(filp, "%s context count : %d\n", qtype, qsize); 2492 seq_printf(filp, "%s context ena/dis bitmap : %s\n", 2493 qtype, buf); 2494 kfree(buf); 2495 } 2496 2497 static void print_nix_qsize(struct seq_file *filp, struct rvu_pfvf *pfvf) 2498 { 2499 if (!pfvf->cq_ctx) 2500 seq_puts(filp, "cq context is not initialized\n"); 2501 else 2502 print_nix_qctx_qsize(filp, pfvf->cq_ctx->qsize, pfvf->cq_bmap, 2503 "cq"); 2504 2505 if (!pfvf->rq_ctx) 2506 seq_puts(filp, "rq context is not initialized\n"); 2507 else 2508 print_nix_qctx_qsize(filp, pfvf->rq_ctx->qsize, pfvf->rq_bmap, 2509 "rq"); 2510 2511 if (!pfvf->sq_ctx) 2512 seq_puts(filp, "sq context is not initialized\n"); 2513 else 2514 print_nix_qctx_qsize(filp, pfvf->sq_ctx->qsize, pfvf->sq_bmap, 2515 "sq"); 2516 } 2517 2518 static ssize_t rvu_dbg_nix_qsize_write(struct file *filp, 2519 const char __user *buffer, 2520 size_t count, loff_t *ppos) 2521 { 2522 return rvu_dbg_qsize_write(filp, buffer, count, ppos, 2523 BLKTYPE_NIX); 2524 } 2525 2526 static int rvu_dbg_nix_qsize_display(struct seq_file *filp, void *unused) 2527 { 2528 return rvu_dbg_qsize_display(filp, unused, BLKTYPE_NIX); 2529 } 2530 2531 RVU_DEBUG_SEQ_FOPS(nix_qsize, nix_qsize_display, nix_qsize_write); 2532 2533 static void print_band_prof_ctx(struct seq_file *m, 2534 struct nix_bandprof_s *prof) 2535 { 2536 char *str; 2537 2538 switch (prof->pc_mode) { 2539 case NIX_RX_PC_MODE_VLAN: 2540 str = "VLAN"; 2541 break; 2542 case NIX_RX_PC_MODE_DSCP: 2543 str = "DSCP"; 2544 break; 2545 case NIX_RX_PC_MODE_GEN: 2546 str = "Generic"; 2547 break; 2548 case NIX_RX_PC_MODE_RSVD: 2549 str = "Reserved"; 2550 break; 2551 } 2552 seq_printf(m, "W0: pc_mode\t\t%s\n", str); 2553 str = (prof->icolor == 3) ? "Color blind" : 2554 (prof->icolor == 0) ? "Green" : 2555 (prof->icolor == 1) ? "Yellow" : "Red"; 2556 seq_printf(m, "W0: icolor\t\t%s\n", str); 2557 seq_printf(m, "W0: tnl_ena\t\t%d\n", prof->tnl_ena); 2558 seq_printf(m, "W0: peir_exponent\t%d\n", prof->peir_exponent); 2559 seq_printf(m, "W0: pebs_exponent\t%d\n", prof->pebs_exponent); 2560 seq_printf(m, "W0: cir_exponent\t%d\n", prof->cir_exponent); 2561 seq_printf(m, "W0: cbs_exponent\t%d\n", prof->cbs_exponent); 2562 seq_printf(m, "W0: peir_mantissa\t%d\n", prof->peir_mantissa); 2563 seq_printf(m, "W0: pebs_mantissa\t%d\n", prof->pebs_mantissa); 2564 seq_printf(m, "W0: cir_mantissa\t%d\n", prof->cir_mantissa); 2565 2566 seq_printf(m, "W1: cbs_mantissa\t%d\n", prof->cbs_mantissa); 2567 str = (prof->lmode == 0) ? "byte" : "packet"; 2568 seq_printf(m, "W1: lmode\t\t%s\n", str); 2569 seq_printf(m, "W1: l_select\t\t%d\n", prof->l_sellect); 2570 seq_printf(m, "W1: rdiv\t\t%d\n", prof->rdiv); 2571 seq_printf(m, "W1: adjust_exponent\t%d\n", prof->adjust_exponent); 2572 seq_printf(m, "W1: adjust_mantissa\t%d\n", prof->adjust_mantissa); 2573 str = (prof->gc_action == 0) ? "PASS" : 2574 (prof->gc_action == 1) ? "DROP" : "RED"; 2575 seq_printf(m, "W1: gc_action\t\t%s\n", str); 2576 str = (prof->yc_action == 0) ? "PASS" : 2577 (prof->yc_action == 1) ? "DROP" : "RED"; 2578 seq_printf(m, "W1: yc_action\t\t%s\n", str); 2579 str = (prof->rc_action == 0) ? "PASS" : 2580 (prof->rc_action == 1) ? "DROP" : "RED"; 2581 seq_printf(m, "W1: rc_action\t\t%s\n", str); 2582 seq_printf(m, "W1: meter_algo\t\t%d\n", prof->meter_algo); 2583 seq_printf(m, "W1: band_prof_id\t%d\n", prof->band_prof_id); 2584 seq_printf(m, "W1: hl_en\t\t%d\n", prof->hl_en); 2585 2586 seq_printf(m, "W2: ts\t\t\t%lld\n", (u64)prof->ts); 2587 seq_printf(m, "W3: pe_accum\t\t%d\n", prof->pe_accum); 2588 seq_printf(m, "W3: c_accum\t\t%d\n", prof->c_accum); 2589 seq_printf(m, "W4: green_pkt_pass\t%lld\n", 2590 (u64)prof->green_pkt_pass); 2591 seq_printf(m, "W5: yellow_pkt_pass\t%lld\n", 2592 (u64)prof->yellow_pkt_pass); 2593 seq_printf(m, "W6: red_pkt_pass\t%lld\n", (u64)prof->red_pkt_pass); 2594 seq_printf(m, "W7: green_octs_pass\t%lld\n", 2595 (u64)prof->green_octs_pass); 2596 seq_printf(m, "W8: yellow_octs_pass\t%lld\n", 2597 (u64)prof->yellow_octs_pass); 2598 seq_printf(m, "W9: red_octs_pass\t%lld\n", (u64)prof->red_octs_pass); 2599 seq_printf(m, "W10: green_pkt_drop\t%lld\n", 2600 (u64)prof->green_pkt_drop); 2601 seq_printf(m, "W11: yellow_pkt_drop\t%lld\n", 2602 (u64)prof->yellow_pkt_drop); 2603 seq_printf(m, "W12: red_pkt_drop\t%lld\n", (u64)prof->red_pkt_drop); 2604 seq_printf(m, "W13: green_octs_drop\t%lld\n", 2605 (u64)prof->green_octs_drop); 2606 seq_printf(m, "W14: yellow_octs_drop\t%lld\n", 2607 (u64)prof->yellow_octs_drop); 2608 seq_printf(m, "W15: red_octs_drop\t%lld\n", (u64)prof->red_octs_drop); 2609 seq_puts(m, "==============================\n"); 2610 } 2611 2612 static int rvu_dbg_nix_band_prof_ctx_display(struct seq_file *m, void *unused) 2613 { 2614 struct nix_hw *nix_hw = m->private; 2615 struct nix_cn10k_aq_enq_req aq_req; 2616 struct nix_cn10k_aq_enq_rsp aq_rsp; 2617 struct rvu *rvu = nix_hw->rvu; 2618 struct nix_ipolicer *ipolicer; 2619 int layer, prof_idx, idx, rc; 2620 u16 pcifunc; 2621 char *str; 2622 2623 /* Ingress policers do not exist on all platforms */ 2624 if (!nix_hw->ipolicer) 2625 return 0; 2626 2627 for (layer = 0; layer < BAND_PROF_NUM_LAYERS; layer++) { 2628 if (layer == BAND_PROF_INVAL_LAYER) 2629 continue; 2630 str = (layer == BAND_PROF_LEAF_LAYER) ? "Leaf" : 2631 (layer == BAND_PROF_MID_LAYER) ? "Mid" : "Top"; 2632 2633 seq_printf(m, "\n%s bandwidth profiles\n", str); 2634 seq_puts(m, "=======================\n"); 2635 2636 ipolicer = &nix_hw->ipolicer[layer]; 2637 2638 for (idx = 0; idx < ipolicer->band_prof.max; idx++) { 2639 if (is_rsrc_free(&ipolicer->band_prof, idx)) 2640 continue; 2641 2642 prof_idx = (idx & 0x3FFF) | (layer << 14); 2643 rc = nix_aq_context_read(rvu, nix_hw, &aq_req, &aq_rsp, 2644 0x00, NIX_AQ_CTYPE_BANDPROF, 2645 prof_idx); 2646 if (rc) { 2647 dev_err(rvu->dev, 2648 "%s: Failed to fetch context of %s profile %d, err %d\n", 2649 __func__, str, idx, rc); 2650 return 0; 2651 } 2652 seq_printf(m, "\n%s bandwidth profile:: %d\n", str, idx); 2653 pcifunc = ipolicer->pfvf_map[idx]; 2654 if (!(pcifunc & RVU_PFVF_FUNC_MASK)) 2655 seq_printf(m, "Allocated to :: PF %d\n", 2656 rvu_get_pf(pcifunc)); 2657 else 2658 seq_printf(m, "Allocated to :: PF %d VF %d\n", 2659 rvu_get_pf(pcifunc), 2660 (pcifunc & RVU_PFVF_FUNC_MASK) - 1); 2661 print_band_prof_ctx(m, &aq_rsp.prof); 2662 } 2663 } 2664 return 0; 2665 } 2666 2667 RVU_DEBUG_SEQ_FOPS(nix_band_prof_ctx, nix_band_prof_ctx_display, NULL); 2668 2669 static int rvu_dbg_nix_band_prof_rsrc_display(struct seq_file *m, void *unused) 2670 { 2671 struct nix_hw *nix_hw = m->private; 2672 struct nix_ipolicer *ipolicer; 2673 int layer; 2674 char *str; 2675 2676 /* Ingress policers do not exist on all platforms */ 2677 if (!nix_hw->ipolicer) 2678 return 0; 2679 2680 seq_puts(m, "\nBandwidth profile resource free count\n"); 2681 seq_puts(m, "=====================================\n"); 2682 for (layer = 0; layer < BAND_PROF_NUM_LAYERS; layer++) { 2683 if (layer == BAND_PROF_INVAL_LAYER) 2684 continue; 2685 str = (layer == BAND_PROF_LEAF_LAYER) ? "Leaf" : 2686 (layer == BAND_PROF_MID_LAYER) ? "Mid " : "Top "; 2687 2688 ipolicer = &nix_hw->ipolicer[layer]; 2689 seq_printf(m, "%s :: Max: %4d Free: %4d\n", str, 2690 ipolicer->band_prof.max, 2691 rvu_rsrc_free_count(&ipolicer->band_prof)); 2692 } 2693 seq_puts(m, "=====================================\n"); 2694 2695 return 0; 2696 } 2697 2698 RVU_DEBUG_SEQ_FOPS(nix_band_prof_rsrc, nix_band_prof_rsrc_display, NULL); 2699 2700 static void rvu_dbg_nix_init(struct rvu *rvu, int blkaddr) 2701 { 2702 struct nix_hw *nix_hw; 2703 2704 if (!is_block_implemented(rvu->hw, blkaddr)) 2705 return; 2706 2707 if (blkaddr == BLKADDR_NIX0) { 2708 rvu->rvu_dbg.nix = debugfs_create_dir("nix", rvu->rvu_dbg.root); 2709 nix_hw = &rvu->hw->nix[0]; 2710 } else { 2711 rvu->rvu_dbg.nix = debugfs_create_dir("nix1", 2712 rvu->rvu_dbg.root); 2713 nix_hw = &rvu->hw->nix[1]; 2714 } 2715 2716 debugfs_create_file("tm_tree", 0600, rvu->rvu_dbg.nix, nix_hw, 2717 &rvu_dbg_nix_tm_tree_fops); 2718 debugfs_create_file("tm_topo", 0600, rvu->rvu_dbg.nix, nix_hw, 2719 &rvu_dbg_nix_tm_topo_fops); 2720 debugfs_create_file("sq_ctx", 0600, rvu->rvu_dbg.nix, nix_hw, 2721 &rvu_dbg_nix_sq_ctx_fops); 2722 debugfs_create_file("rq_ctx", 0600, rvu->rvu_dbg.nix, nix_hw, 2723 &rvu_dbg_nix_rq_ctx_fops); 2724 debugfs_create_file("cq_ctx", 0600, rvu->rvu_dbg.nix, nix_hw, 2725 &rvu_dbg_nix_cq_ctx_fops); 2726 debugfs_create_file("ndc_tx_cache", 0600, rvu->rvu_dbg.nix, nix_hw, 2727 &rvu_dbg_nix_ndc_tx_cache_fops); 2728 debugfs_create_file("ndc_rx_cache", 0600, rvu->rvu_dbg.nix, nix_hw, 2729 &rvu_dbg_nix_ndc_rx_cache_fops); 2730 debugfs_create_file("ndc_tx_hits_miss", 0600, rvu->rvu_dbg.nix, nix_hw, 2731 &rvu_dbg_nix_ndc_tx_hits_miss_fops); 2732 debugfs_create_file("ndc_rx_hits_miss", 0600, rvu->rvu_dbg.nix, nix_hw, 2733 &rvu_dbg_nix_ndc_rx_hits_miss_fops); 2734 debugfs_create_file("qsize", 0600, rvu->rvu_dbg.nix, rvu, 2735 &rvu_dbg_nix_qsize_fops); 2736 debugfs_create_file("ingress_policer_ctx", 0600, rvu->rvu_dbg.nix, nix_hw, 2737 &rvu_dbg_nix_band_prof_ctx_fops); 2738 debugfs_create_file("ingress_policer_rsrc", 0600, rvu->rvu_dbg.nix, nix_hw, 2739 &rvu_dbg_nix_band_prof_rsrc_fops); 2740 } 2741 2742 static void rvu_dbg_npa_init(struct rvu *rvu) 2743 { 2744 rvu->rvu_dbg.npa = debugfs_create_dir("npa", rvu->rvu_dbg.root); 2745 2746 debugfs_create_file("qsize", 0600, rvu->rvu_dbg.npa, rvu, 2747 &rvu_dbg_npa_qsize_fops); 2748 debugfs_create_file("aura_ctx", 0600, rvu->rvu_dbg.npa, rvu, 2749 &rvu_dbg_npa_aura_ctx_fops); 2750 debugfs_create_file("pool_ctx", 0600, rvu->rvu_dbg.npa, rvu, 2751 &rvu_dbg_npa_pool_ctx_fops); 2752 debugfs_create_file("ndc_cache", 0600, rvu->rvu_dbg.npa, rvu, 2753 &rvu_dbg_npa_ndc_cache_fops); 2754 debugfs_create_file("ndc_hits_miss", 0600, rvu->rvu_dbg.npa, rvu, 2755 &rvu_dbg_npa_ndc_hits_miss_fops); 2756 } 2757 2758 #define PRINT_CGX_CUML_NIXRX_STATUS(idx, name) \ 2759 ({ \ 2760 u64 cnt; \ 2761 err = rvu_cgx_nix_cuml_stats(rvu, cgxd, lmac_id, (idx), \ 2762 NIX_STATS_RX, &(cnt)); \ 2763 if (!err) \ 2764 seq_printf(s, "%s: %llu\n", name, cnt); \ 2765 cnt; \ 2766 }) 2767 2768 #define PRINT_CGX_CUML_NIXTX_STATUS(idx, name) \ 2769 ({ \ 2770 u64 cnt; \ 2771 err = rvu_cgx_nix_cuml_stats(rvu, cgxd, lmac_id, (idx), \ 2772 NIX_STATS_TX, &(cnt)); \ 2773 if (!err) \ 2774 seq_printf(s, "%s: %llu\n", name, cnt); \ 2775 cnt; \ 2776 }) 2777 2778 static int cgx_print_stats(struct seq_file *s, int lmac_id) 2779 { 2780 struct cgx_link_user_info linfo; 2781 struct mac_ops *mac_ops; 2782 void *cgxd = s->private; 2783 u64 ucast, mcast, bcast; 2784 int stat = 0, err = 0; 2785 u64 tx_stat, rx_stat; 2786 struct rvu *rvu; 2787 2788 rvu = pci_get_drvdata(pci_get_device(PCI_VENDOR_ID_CAVIUM, 2789 PCI_DEVID_OCTEONTX2_RVU_AF, NULL)); 2790 if (!rvu) 2791 return -ENODEV; 2792 2793 mac_ops = get_mac_ops(cgxd); 2794 /* There can be no CGX devices at all */ 2795 if (!mac_ops) 2796 return 0; 2797 2798 /* Link status */ 2799 seq_puts(s, "\n=======Link Status======\n\n"); 2800 err = cgx_get_link_info(cgxd, lmac_id, &linfo); 2801 if (err) 2802 seq_puts(s, "Failed to read link status\n"); 2803 seq_printf(s, "\nLink is %s %d Mbps\n\n", 2804 linfo.link_up ? "UP" : "DOWN", linfo.speed); 2805 2806 /* Rx stats */ 2807 seq_printf(s, "\n=======NIX RX_STATS(%s port level)======\n\n", 2808 mac_ops->name); 2809 ucast = PRINT_CGX_CUML_NIXRX_STATUS(RX_UCAST, "rx_ucast_frames"); 2810 if (err) 2811 return err; 2812 mcast = PRINT_CGX_CUML_NIXRX_STATUS(RX_MCAST, "rx_mcast_frames"); 2813 if (err) 2814 return err; 2815 bcast = PRINT_CGX_CUML_NIXRX_STATUS(RX_BCAST, "rx_bcast_frames"); 2816 if (err) 2817 return err; 2818 seq_printf(s, "rx_frames: %llu\n", ucast + mcast + bcast); 2819 PRINT_CGX_CUML_NIXRX_STATUS(RX_OCTS, "rx_bytes"); 2820 if (err) 2821 return err; 2822 PRINT_CGX_CUML_NIXRX_STATUS(RX_DROP, "rx_drops"); 2823 if (err) 2824 return err; 2825 PRINT_CGX_CUML_NIXRX_STATUS(RX_ERR, "rx_errors"); 2826 if (err) 2827 return err; 2828 2829 /* Tx stats */ 2830 seq_printf(s, "\n=======NIX TX_STATS(%s port level)======\n\n", 2831 mac_ops->name); 2832 ucast = PRINT_CGX_CUML_NIXTX_STATUS(TX_UCAST, "tx_ucast_frames"); 2833 if (err) 2834 return err; 2835 mcast = PRINT_CGX_CUML_NIXTX_STATUS(TX_MCAST, "tx_mcast_frames"); 2836 if (err) 2837 return err; 2838 bcast = PRINT_CGX_CUML_NIXTX_STATUS(TX_BCAST, "tx_bcast_frames"); 2839 if (err) 2840 return err; 2841 seq_printf(s, "tx_frames: %llu\n", ucast + mcast + bcast); 2842 PRINT_CGX_CUML_NIXTX_STATUS(TX_OCTS, "tx_bytes"); 2843 if (err) 2844 return err; 2845 PRINT_CGX_CUML_NIXTX_STATUS(TX_DROP, "tx_drops"); 2846 if (err) 2847 return err; 2848 2849 /* Rx stats */ 2850 seq_printf(s, "\n=======%s RX_STATS======\n\n", mac_ops->name); 2851 while (stat < mac_ops->rx_stats_cnt) { 2852 err = mac_ops->mac_get_rx_stats(cgxd, lmac_id, stat, &rx_stat); 2853 if (err) 2854 return err; 2855 if (is_rvu_otx2(rvu)) 2856 seq_printf(s, "%s: %llu\n", cgx_rx_stats_fields[stat], 2857 rx_stat); 2858 else 2859 seq_printf(s, "%s: %llu\n", rpm_rx_stats_fields[stat], 2860 rx_stat); 2861 stat++; 2862 } 2863 2864 /* Tx stats */ 2865 stat = 0; 2866 seq_printf(s, "\n=======%s TX_STATS======\n\n", mac_ops->name); 2867 while (stat < mac_ops->tx_stats_cnt) { 2868 err = mac_ops->mac_get_tx_stats(cgxd, lmac_id, stat, &tx_stat); 2869 if (err) 2870 return err; 2871 2872 if (is_rvu_otx2(rvu)) 2873 seq_printf(s, "%s: %llu\n", cgx_tx_stats_fields[stat], 2874 tx_stat); 2875 else 2876 seq_printf(s, "%s: %llu\n", rpm_tx_stats_fields[stat], 2877 tx_stat); 2878 stat++; 2879 } 2880 2881 return err; 2882 } 2883 2884 static int rvu_dbg_derive_lmacid(struct seq_file *filp, int *lmac_id) 2885 { 2886 struct dentry *current_dir; 2887 char *buf; 2888 2889 current_dir = filp->file->f_path.dentry->d_parent; 2890 buf = strrchr(current_dir->d_name.name, 'c'); 2891 if (!buf) 2892 return -EINVAL; 2893 2894 return kstrtoint(buf + 1, 10, lmac_id); 2895 } 2896 2897 static int rvu_dbg_cgx_stat_display(struct seq_file *filp, void *unused) 2898 { 2899 int lmac_id, err; 2900 2901 err = rvu_dbg_derive_lmacid(filp, &lmac_id); 2902 if (!err) 2903 return cgx_print_stats(filp, lmac_id); 2904 2905 return err; 2906 } 2907 2908 RVU_DEBUG_SEQ_FOPS(cgx_stat, cgx_stat_display, NULL); 2909 2910 static int cgx_print_dmac_flt(struct seq_file *s, int lmac_id) 2911 { 2912 struct pci_dev *pdev = NULL; 2913 void *cgxd = s->private; 2914 char *bcast, *mcast; 2915 u16 index, domain; 2916 u8 dmac[ETH_ALEN]; 2917 struct rvu *rvu; 2918 u64 cfg, mac; 2919 int pf; 2920 2921 rvu = pci_get_drvdata(pci_get_device(PCI_VENDOR_ID_CAVIUM, 2922 PCI_DEVID_OCTEONTX2_RVU_AF, NULL)); 2923 if (!rvu) 2924 return -ENODEV; 2925 2926 pf = cgxlmac_to_pf(rvu, cgx_get_cgxid(cgxd), lmac_id); 2927 domain = 2; 2928 2929 pdev = pci_get_domain_bus_and_slot(domain, pf + 1, 0); 2930 if (!pdev) 2931 return 0; 2932 2933 cfg = cgx_read_dmac_ctrl(cgxd, lmac_id); 2934 bcast = cfg & CGX_DMAC_BCAST_MODE ? "ACCEPT" : "REJECT"; 2935 mcast = cfg & CGX_DMAC_MCAST_MODE ? "ACCEPT" : "REJECT"; 2936 2937 seq_puts(s, 2938 "PCI dev RVUPF BROADCAST MULTICAST FILTER-MODE\n"); 2939 seq_printf(s, "%s PF%d %9s %9s", 2940 dev_name(&pdev->dev), pf, bcast, mcast); 2941 if (cfg & CGX_DMAC_CAM_ACCEPT) 2942 seq_printf(s, "%12s\n\n", "UNICAST"); 2943 else 2944 seq_printf(s, "%16s\n\n", "PROMISCUOUS"); 2945 2946 seq_puts(s, "\nDMAC-INDEX ADDRESS\n"); 2947 2948 for (index = 0 ; index < 32 ; index++) { 2949 cfg = cgx_read_dmac_entry(cgxd, index); 2950 /* Display enabled dmac entries associated with current lmac */ 2951 if (lmac_id == FIELD_GET(CGX_DMAC_CAM_ENTRY_LMACID, cfg) && 2952 FIELD_GET(CGX_DMAC_CAM_ADDR_ENABLE, cfg)) { 2953 mac = FIELD_GET(CGX_RX_DMAC_ADR_MASK, cfg); 2954 u64_to_ether_addr(mac, dmac); 2955 seq_printf(s, "%7d %pM\n", index, dmac); 2956 } 2957 } 2958 2959 pci_dev_put(pdev); 2960 return 0; 2961 } 2962 2963 static int rvu_dbg_cgx_dmac_flt_display(struct seq_file *filp, void *unused) 2964 { 2965 int err, lmac_id; 2966 2967 err = rvu_dbg_derive_lmacid(filp, &lmac_id); 2968 if (!err) 2969 return cgx_print_dmac_flt(filp, lmac_id); 2970 2971 return err; 2972 } 2973 2974 RVU_DEBUG_SEQ_FOPS(cgx_dmac_flt, cgx_dmac_flt_display, NULL); 2975 2976 static void rvu_dbg_cgx_init(struct rvu *rvu) 2977 { 2978 struct mac_ops *mac_ops; 2979 unsigned long lmac_bmap; 2980 int i, lmac_id; 2981 char dname[20]; 2982 void *cgx; 2983 2984 if (!cgx_get_cgxcnt_max()) 2985 return; 2986 2987 mac_ops = get_mac_ops(rvu_first_cgx_pdata(rvu)); 2988 if (!mac_ops) 2989 return; 2990 2991 rvu->rvu_dbg.cgx_root = debugfs_create_dir(mac_ops->name, 2992 rvu->rvu_dbg.root); 2993 2994 for (i = 0; i < cgx_get_cgxcnt_max(); i++) { 2995 cgx = rvu_cgx_pdata(i, rvu); 2996 if (!cgx) 2997 continue; 2998 lmac_bmap = cgx_get_lmac_bmap(cgx); 2999 /* cgx debugfs dir */ 3000 sprintf(dname, "%s%d", mac_ops->name, i); 3001 rvu->rvu_dbg.cgx = debugfs_create_dir(dname, 3002 rvu->rvu_dbg.cgx_root); 3003 3004 for_each_set_bit(lmac_id, &lmac_bmap, rvu->hw->lmac_per_cgx) { 3005 /* lmac debugfs dir */ 3006 sprintf(dname, "lmac%d", lmac_id); 3007 rvu->rvu_dbg.lmac = 3008 debugfs_create_dir(dname, rvu->rvu_dbg.cgx); 3009 3010 debugfs_create_file("stats", 0600, rvu->rvu_dbg.lmac, 3011 cgx, &rvu_dbg_cgx_stat_fops); 3012 debugfs_create_file("mac_filter", 0600, 3013 rvu->rvu_dbg.lmac, cgx, 3014 &rvu_dbg_cgx_dmac_flt_fops); 3015 } 3016 } 3017 } 3018 3019 /* NPC debugfs APIs */ 3020 static void rvu_print_npc_mcam_info(struct seq_file *s, 3021 u16 pcifunc, int blkaddr) 3022 { 3023 struct rvu *rvu = s->private; 3024 int entry_acnt, entry_ecnt; 3025 int cntr_acnt, cntr_ecnt; 3026 3027 rvu_npc_get_mcam_entry_alloc_info(rvu, pcifunc, blkaddr, 3028 &entry_acnt, &entry_ecnt); 3029 rvu_npc_get_mcam_counter_alloc_info(rvu, pcifunc, blkaddr, 3030 &cntr_acnt, &cntr_ecnt); 3031 if (!entry_acnt && !cntr_acnt) 3032 return; 3033 3034 if (!(pcifunc & RVU_PFVF_FUNC_MASK)) 3035 seq_printf(s, "\n\t\t Device \t\t: PF%d\n", 3036 rvu_get_pf(pcifunc)); 3037 else 3038 seq_printf(s, "\n\t\t Device \t\t: PF%d VF%d\n", 3039 rvu_get_pf(pcifunc), 3040 (pcifunc & RVU_PFVF_FUNC_MASK) - 1); 3041 3042 if (entry_acnt) { 3043 seq_printf(s, "\t\t Entries allocated \t: %d\n", entry_acnt); 3044 seq_printf(s, "\t\t Entries enabled \t: %d\n", entry_ecnt); 3045 } 3046 if (cntr_acnt) { 3047 seq_printf(s, "\t\t Counters allocated \t: %d\n", cntr_acnt); 3048 seq_printf(s, "\t\t Counters enabled \t: %d\n", cntr_ecnt); 3049 } 3050 } 3051 3052 static int rvu_dbg_npc_mcam_info_display(struct seq_file *filp, void *unsued) 3053 { 3054 struct rvu *rvu = filp->private; 3055 int pf, vf, numvfs, blkaddr; 3056 struct npc_mcam *mcam; 3057 u16 pcifunc, counters; 3058 u64 cfg; 3059 3060 blkaddr = rvu_get_blkaddr(rvu, BLKTYPE_NPC, 0); 3061 if (blkaddr < 0) 3062 return -ENODEV; 3063 3064 mcam = &rvu->hw->mcam; 3065 counters = rvu->hw->npc_counters; 3066 3067 seq_puts(filp, "\nNPC MCAM info:\n"); 3068 /* MCAM keywidth on receive and transmit sides */ 3069 cfg = rvu_read64(rvu, blkaddr, NPC_AF_INTFX_KEX_CFG(NIX_INTF_RX)); 3070 cfg = (cfg >> 32) & 0x07; 3071 seq_printf(filp, "\t\t RX keywidth \t: %s\n", (cfg == NPC_MCAM_KEY_X1) ? 3072 "112bits" : ((cfg == NPC_MCAM_KEY_X2) ? 3073 "224bits" : "448bits")); 3074 cfg = rvu_read64(rvu, blkaddr, NPC_AF_INTFX_KEX_CFG(NIX_INTF_TX)); 3075 cfg = (cfg >> 32) & 0x07; 3076 seq_printf(filp, "\t\t TX keywidth \t: %s\n", (cfg == NPC_MCAM_KEY_X1) ? 3077 "112bits" : ((cfg == NPC_MCAM_KEY_X2) ? 3078 "224bits" : "448bits")); 3079 3080 mutex_lock(&mcam->lock); 3081 /* MCAM entries */ 3082 seq_printf(filp, "\n\t\t MCAM entries \t: %d\n", mcam->total_entries); 3083 seq_printf(filp, "\t\t Reserved \t: %d\n", 3084 mcam->total_entries - mcam->bmap_entries); 3085 seq_printf(filp, "\t\t Available \t: %d\n", mcam->bmap_fcnt); 3086 3087 /* MCAM counters */ 3088 seq_printf(filp, "\n\t\t MCAM counters \t: %d\n", counters); 3089 seq_printf(filp, "\t\t Reserved \t: %d\n", 3090 counters - mcam->counters.max); 3091 seq_printf(filp, "\t\t Available \t: %d\n", 3092 rvu_rsrc_free_count(&mcam->counters)); 3093 3094 if (mcam->bmap_entries == mcam->bmap_fcnt) { 3095 mutex_unlock(&mcam->lock); 3096 return 0; 3097 } 3098 3099 seq_puts(filp, "\n\t\t Current allocation\n"); 3100 seq_puts(filp, "\t\t====================\n"); 3101 for (pf = 0; pf < rvu->hw->total_pfs; pf++) { 3102 pcifunc = (pf << RVU_PFVF_PF_SHIFT); 3103 rvu_print_npc_mcam_info(filp, pcifunc, blkaddr); 3104 3105 cfg = rvu_read64(rvu, BLKADDR_RVUM, RVU_PRIV_PFX_CFG(pf)); 3106 numvfs = (cfg >> 12) & 0xFF; 3107 for (vf = 0; vf < numvfs; vf++) { 3108 pcifunc = (pf << RVU_PFVF_PF_SHIFT) | (vf + 1); 3109 rvu_print_npc_mcam_info(filp, pcifunc, blkaddr); 3110 } 3111 } 3112 3113 mutex_unlock(&mcam->lock); 3114 return 0; 3115 } 3116 3117 RVU_DEBUG_SEQ_FOPS(npc_mcam_info, npc_mcam_info_display, NULL); 3118 3119 static int rvu_dbg_npc_rx_miss_stats_display(struct seq_file *filp, 3120 void *unused) 3121 { 3122 struct rvu *rvu = filp->private; 3123 struct npc_mcam *mcam; 3124 int blkaddr; 3125 3126 blkaddr = rvu_get_blkaddr(rvu, BLKTYPE_NPC, 0); 3127 if (blkaddr < 0) 3128 return -ENODEV; 3129 3130 mcam = &rvu->hw->mcam; 3131 3132 seq_puts(filp, "\nNPC MCAM RX miss action stats\n"); 3133 seq_printf(filp, "\t\tStat %d: \t%lld\n", mcam->rx_miss_act_cntr, 3134 rvu_read64(rvu, blkaddr, 3135 NPC_AF_MATCH_STATX(mcam->rx_miss_act_cntr))); 3136 3137 return 0; 3138 } 3139 3140 RVU_DEBUG_SEQ_FOPS(npc_rx_miss_act, npc_rx_miss_stats_display, NULL); 3141 3142 #define RVU_DBG_PRINT_MPLS_TTL(pkt, mask) \ 3143 do { \ 3144 seq_printf(s, "%ld ", FIELD_GET(OTX2_FLOWER_MASK_MPLS_TTL, pkt)); \ 3145 seq_printf(s, "mask 0x%lx\n", \ 3146 FIELD_GET(OTX2_FLOWER_MASK_MPLS_TTL, mask)); \ 3147 } while (0) \ 3148 3149 #define RVU_DBG_PRINT_MPLS_LBTCBOS(_pkt, _mask) \ 3150 do { \ 3151 typeof(_pkt) (pkt) = (_pkt); \ 3152 typeof(_mask) (mask) = (_mask); \ 3153 seq_printf(s, "%ld %ld %ld\n", \ 3154 FIELD_GET(OTX2_FLOWER_MASK_MPLS_LB, pkt), \ 3155 FIELD_GET(OTX2_FLOWER_MASK_MPLS_TC, pkt), \ 3156 FIELD_GET(OTX2_FLOWER_MASK_MPLS_BOS, pkt)); \ 3157 seq_printf(s, "\tmask 0x%lx 0x%lx 0x%lx\n", \ 3158 FIELD_GET(OTX2_FLOWER_MASK_MPLS_LB, mask), \ 3159 FIELD_GET(OTX2_FLOWER_MASK_MPLS_TC, mask), \ 3160 FIELD_GET(OTX2_FLOWER_MASK_MPLS_BOS, mask)); \ 3161 } while (0) \ 3162 3163 static void rvu_dbg_npc_mcam_show_flows(struct seq_file *s, 3164 struct rvu_npc_mcam_rule *rule) 3165 { 3166 u8 bit; 3167 3168 for_each_set_bit(bit, (unsigned long *)&rule->features, 64) { 3169 seq_printf(s, "\t%s ", npc_get_field_name(bit)); 3170 switch (bit) { 3171 case NPC_LXMB: 3172 if (rule->lxmb == 1) 3173 seq_puts(s, "\tL2M nibble is set\n"); 3174 else 3175 seq_puts(s, "\tL2B nibble is set\n"); 3176 break; 3177 case NPC_DMAC: 3178 seq_printf(s, "%pM ", rule->packet.dmac); 3179 seq_printf(s, "mask %pM\n", rule->mask.dmac); 3180 break; 3181 case NPC_SMAC: 3182 seq_printf(s, "%pM ", rule->packet.smac); 3183 seq_printf(s, "mask %pM\n", rule->mask.smac); 3184 break; 3185 case NPC_ETYPE: 3186 seq_printf(s, "0x%x ", ntohs(rule->packet.etype)); 3187 seq_printf(s, "mask 0x%x\n", ntohs(rule->mask.etype)); 3188 break; 3189 case NPC_OUTER_VID: 3190 seq_printf(s, "0x%x ", ntohs(rule->packet.vlan_tci)); 3191 seq_printf(s, "mask 0x%x\n", 3192 ntohs(rule->mask.vlan_tci)); 3193 break; 3194 case NPC_INNER_VID: 3195 seq_printf(s, "0x%x ", ntohs(rule->packet.vlan_itci)); 3196 seq_printf(s, "mask 0x%x\n", 3197 ntohs(rule->mask.vlan_itci)); 3198 break; 3199 case NPC_TOS: 3200 seq_printf(s, "%d ", rule->packet.tos); 3201 seq_printf(s, "mask 0x%x\n", rule->mask.tos); 3202 break; 3203 case NPC_SIP_IPV4: 3204 seq_printf(s, "%pI4 ", &rule->packet.ip4src); 3205 seq_printf(s, "mask %pI4\n", &rule->mask.ip4src); 3206 break; 3207 case NPC_DIP_IPV4: 3208 seq_printf(s, "%pI4 ", &rule->packet.ip4dst); 3209 seq_printf(s, "mask %pI4\n", &rule->mask.ip4dst); 3210 break; 3211 case NPC_SIP_IPV6: 3212 seq_printf(s, "%pI6 ", rule->packet.ip6src); 3213 seq_printf(s, "mask %pI6\n", rule->mask.ip6src); 3214 break; 3215 case NPC_DIP_IPV6: 3216 seq_printf(s, "%pI6 ", rule->packet.ip6dst); 3217 seq_printf(s, "mask %pI6\n", rule->mask.ip6dst); 3218 break; 3219 case NPC_IPFRAG_IPV6: 3220 seq_printf(s, "0x%x ", rule->packet.next_header); 3221 seq_printf(s, "mask 0x%x\n", rule->mask.next_header); 3222 break; 3223 case NPC_IPFRAG_IPV4: 3224 seq_printf(s, "0x%x ", rule->packet.ip_flag); 3225 seq_printf(s, "mask 0x%x\n", rule->mask.ip_flag); 3226 break; 3227 case NPC_SPORT_TCP: 3228 case NPC_SPORT_UDP: 3229 case NPC_SPORT_SCTP: 3230 seq_printf(s, "%d ", ntohs(rule->packet.sport)); 3231 seq_printf(s, "mask 0x%x\n", ntohs(rule->mask.sport)); 3232 break; 3233 case NPC_DPORT_TCP: 3234 case NPC_DPORT_UDP: 3235 case NPC_DPORT_SCTP: 3236 seq_printf(s, "%d ", ntohs(rule->packet.dport)); 3237 seq_printf(s, "mask 0x%x\n", ntohs(rule->mask.dport)); 3238 break; 3239 case NPC_TCP_FLAGS: 3240 seq_printf(s, "%d ", rule->packet.tcp_flags); 3241 seq_printf(s, "mask 0x%x\n", rule->mask.tcp_flags); 3242 break; 3243 case NPC_IPSEC_SPI: 3244 seq_printf(s, "0x%x ", ntohl(rule->packet.spi)); 3245 seq_printf(s, "mask 0x%x\n", ntohl(rule->mask.spi)); 3246 break; 3247 case NPC_MPLS1_LBTCBOS: 3248 RVU_DBG_PRINT_MPLS_LBTCBOS(rule->packet.mpls_lse[0], 3249 rule->mask.mpls_lse[0]); 3250 break; 3251 case NPC_MPLS1_TTL: 3252 RVU_DBG_PRINT_MPLS_TTL(rule->packet.mpls_lse[0], 3253 rule->mask.mpls_lse[0]); 3254 break; 3255 case NPC_MPLS2_LBTCBOS: 3256 RVU_DBG_PRINT_MPLS_LBTCBOS(rule->packet.mpls_lse[1], 3257 rule->mask.mpls_lse[1]); 3258 break; 3259 case NPC_MPLS2_TTL: 3260 RVU_DBG_PRINT_MPLS_TTL(rule->packet.mpls_lse[1], 3261 rule->mask.mpls_lse[1]); 3262 break; 3263 case NPC_MPLS3_LBTCBOS: 3264 RVU_DBG_PRINT_MPLS_LBTCBOS(rule->packet.mpls_lse[2], 3265 rule->mask.mpls_lse[2]); 3266 break; 3267 case NPC_MPLS3_TTL: 3268 RVU_DBG_PRINT_MPLS_TTL(rule->packet.mpls_lse[2], 3269 rule->mask.mpls_lse[2]); 3270 break; 3271 case NPC_MPLS4_LBTCBOS: 3272 RVU_DBG_PRINT_MPLS_LBTCBOS(rule->packet.mpls_lse[3], 3273 rule->mask.mpls_lse[3]); 3274 break; 3275 case NPC_MPLS4_TTL: 3276 RVU_DBG_PRINT_MPLS_TTL(rule->packet.mpls_lse[3], 3277 rule->mask.mpls_lse[3]); 3278 break; 3279 case NPC_TYPE_ICMP: 3280 seq_printf(s, "%d ", rule->packet.icmp_type); 3281 seq_printf(s, "mask 0x%x\n", rule->mask.icmp_type); 3282 break; 3283 case NPC_CODE_ICMP: 3284 seq_printf(s, "%d ", rule->packet.icmp_code); 3285 seq_printf(s, "mask 0x%x\n", rule->mask.icmp_code); 3286 break; 3287 default: 3288 seq_puts(s, "\n"); 3289 break; 3290 } 3291 } 3292 } 3293 3294 static void rvu_dbg_npc_mcam_show_action(struct seq_file *s, 3295 struct rvu_npc_mcam_rule *rule) 3296 { 3297 if (is_npc_intf_tx(rule->intf)) { 3298 switch (rule->tx_action.op) { 3299 case NIX_TX_ACTIONOP_DROP: 3300 seq_puts(s, "\taction: Drop\n"); 3301 break; 3302 case NIX_TX_ACTIONOP_UCAST_DEFAULT: 3303 seq_puts(s, "\taction: Unicast to default channel\n"); 3304 break; 3305 case NIX_TX_ACTIONOP_UCAST_CHAN: 3306 seq_printf(s, "\taction: Unicast to channel %d\n", 3307 rule->tx_action.index); 3308 break; 3309 case NIX_TX_ACTIONOP_MCAST: 3310 seq_puts(s, "\taction: Multicast\n"); 3311 break; 3312 case NIX_TX_ACTIONOP_DROP_VIOL: 3313 seq_puts(s, "\taction: Lockdown Violation Drop\n"); 3314 break; 3315 default: 3316 break; 3317 } 3318 } else { 3319 switch (rule->rx_action.op) { 3320 case NIX_RX_ACTIONOP_DROP: 3321 seq_puts(s, "\taction: Drop\n"); 3322 break; 3323 case NIX_RX_ACTIONOP_UCAST: 3324 seq_printf(s, "\taction: Direct to queue %d\n", 3325 rule->rx_action.index); 3326 break; 3327 case NIX_RX_ACTIONOP_RSS: 3328 seq_puts(s, "\taction: RSS\n"); 3329 break; 3330 case NIX_RX_ACTIONOP_UCAST_IPSEC: 3331 seq_puts(s, "\taction: Unicast ipsec\n"); 3332 break; 3333 case NIX_RX_ACTIONOP_MCAST: 3334 seq_puts(s, "\taction: Multicast\n"); 3335 break; 3336 default: 3337 break; 3338 } 3339 } 3340 } 3341 3342 static const char *rvu_dbg_get_intf_name(int intf) 3343 { 3344 switch (intf) { 3345 case NIX_INTFX_RX(0): 3346 return "NIX0_RX"; 3347 case NIX_INTFX_RX(1): 3348 return "NIX1_RX"; 3349 case NIX_INTFX_TX(0): 3350 return "NIX0_TX"; 3351 case NIX_INTFX_TX(1): 3352 return "NIX1_TX"; 3353 default: 3354 break; 3355 } 3356 3357 return "unknown"; 3358 } 3359 3360 static int rvu_dbg_npc_mcam_show_rules(struct seq_file *s, void *unused) 3361 { 3362 struct rvu_npc_mcam_rule *iter; 3363 struct rvu *rvu = s->private; 3364 struct npc_mcam *mcam; 3365 int pf, vf = -1; 3366 bool enabled; 3367 int blkaddr; 3368 u16 target; 3369 u64 hits; 3370 3371 blkaddr = rvu_get_blkaddr(rvu, BLKTYPE_NPC, 0); 3372 if (blkaddr < 0) 3373 return 0; 3374 3375 mcam = &rvu->hw->mcam; 3376 3377 mutex_lock(&mcam->lock); 3378 list_for_each_entry(iter, &mcam->mcam_rules, list) { 3379 pf = (iter->owner >> RVU_PFVF_PF_SHIFT) & RVU_PFVF_PF_MASK; 3380 seq_printf(s, "\n\tInstalled by: PF%d ", pf); 3381 3382 if (iter->owner & RVU_PFVF_FUNC_MASK) { 3383 vf = (iter->owner & RVU_PFVF_FUNC_MASK) - 1; 3384 seq_printf(s, "VF%d", vf); 3385 } 3386 seq_puts(s, "\n"); 3387 3388 seq_printf(s, "\tdirection: %s\n", is_npc_intf_rx(iter->intf) ? 3389 "RX" : "TX"); 3390 seq_printf(s, "\tinterface: %s\n", 3391 rvu_dbg_get_intf_name(iter->intf)); 3392 seq_printf(s, "\tmcam entry: %d\n", iter->entry); 3393 3394 rvu_dbg_npc_mcam_show_flows(s, iter); 3395 if (is_npc_intf_rx(iter->intf)) { 3396 target = iter->rx_action.pf_func; 3397 pf = (target >> RVU_PFVF_PF_SHIFT) & RVU_PFVF_PF_MASK; 3398 seq_printf(s, "\tForward to: PF%d ", pf); 3399 3400 if (target & RVU_PFVF_FUNC_MASK) { 3401 vf = (target & RVU_PFVF_FUNC_MASK) - 1; 3402 seq_printf(s, "VF%d", vf); 3403 } 3404 seq_puts(s, "\n"); 3405 seq_printf(s, "\tchannel: 0x%x\n", iter->chan); 3406 seq_printf(s, "\tchannel_mask: 0x%x\n", iter->chan_mask); 3407 } 3408 3409 rvu_dbg_npc_mcam_show_action(s, iter); 3410 3411 enabled = is_mcam_entry_enabled(rvu, mcam, blkaddr, iter->entry); 3412 seq_printf(s, "\tenabled: %s\n", enabled ? "yes" : "no"); 3413 3414 if (!iter->has_cntr) 3415 continue; 3416 seq_printf(s, "\tcounter: %d\n", iter->cntr); 3417 3418 hits = rvu_read64(rvu, blkaddr, NPC_AF_MATCH_STATX(iter->cntr)); 3419 seq_printf(s, "\thits: %lld\n", hits); 3420 } 3421 mutex_unlock(&mcam->lock); 3422 3423 return 0; 3424 } 3425 3426 RVU_DEBUG_SEQ_FOPS(npc_mcam_rules, npc_mcam_show_rules, NULL); 3427 3428 static int rvu_dbg_npc_exact_show_entries(struct seq_file *s, void *unused) 3429 { 3430 struct npc_exact_table_entry *mem_entry[NPC_EXACT_TBL_MAX_WAYS] = { 0 }; 3431 struct npc_exact_table_entry *cam_entry; 3432 struct npc_exact_table *table; 3433 struct rvu *rvu = s->private; 3434 int i, j; 3435 3436 u8 bitmap = 0; 3437 3438 table = rvu->hw->table; 3439 3440 mutex_lock(&table->lock); 3441 3442 /* Check if there is at least one entry in mem table */ 3443 if (!table->mem_tbl_entry_cnt) 3444 goto dump_cam_table; 3445 3446 /* Print table headers */ 3447 seq_puts(s, "\n\tExact Match MEM Table\n"); 3448 seq_puts(s, "Index\t"); 3449 3450 for (i = 0; i < table->mem_table.ways; i++) { 3451 mem_entry[i] = list_first_entry_or_null(&table->lhead_mem_tbl_entry[i], 3452 struct npc_exact_table_entry, list); 3453 3454 seq_printf(s, "Way-%d\t\t\t\t\t", i); 3455 } 3456 3457 seq_puts(s, "\n"); 3458 for (i = 0; i < table->mem_table.ways; i++) 3459 seq_puts(s, "\tChan MAC \t"); 3460 3461 seq_puts(s, "\n\n"); 3462 3463 /* Print mem table entries */ 3464 for (i = 0; i < table->mem_table.depth; i++) { 3465 bitmap = 0; 3466 for (j = 0; j < table->mem_table.ways; j++) { 3467 if (!mem_entry[j]) 3468 continue; 3469 3470 if (mem_entry[j]->index != i) 3471 continue; 3472 3473 bitmap |= BIT(j); 3474 } 3475 3476 /* No valid entries */ 3477 if (!bitmap) 3478 continue; 3479 3480 seq_printf(s, "%d\t", i); 3481 for (j = 0; j < table->mem_table.ways; j++) { 3482 if (!(bitmap & BIT(j))) { 3483 seq_puts(s, "nil\t\t\t\t\t"); 3484 continue; 3485 } 3486 3487 seq_printf(s, "0x%x %pM\t\t\t", mem_entry[j]->chan, 3488 mem_entry[j]->mac); 3489 mem_entry[j] = list_next_entry(mem_entry[j], list); 3490 } 3491 seq_puts(s, "\n"); 3492 } 3493 3494 dump_cam_table: 3495 3496 if (!table->cam_tbl_entry_cnt) 3497 goto done; 3498 3499 seq_puts(s, "\n\tExact Match CAM Table\n"); 3500 seq_puts(s, "index\tchan\tMAC\n"); 3501 3502 /* Traverse cam table entries */ 3503 list_for_each_entry(cam_entry, &table->lhead_cam_tbl_entry, list) { 3504 seq_printf(s, "%d\t0x%x\t%pM\n", cam_entry->index, cam_entry->chan, 3505 cam_entry->mac); 3506 } 3507 3508 done: 3509 mutex_unlock(&table->lock); 3510 return 0; 3511 } 3512 3513 RVU_DEBUG_SEQ_FOPS(npc_exact_entries, npc_exact_show_entries, NULL); 3514 3515 static int rvu_dbg_npc_exact_show_info(struct seq_file *s, void *unused) 3516 { 3517 struct npc_exact_table *table; 3518 struct rvu *rvu = s->private; 3519 int i; 3520 3521 table = rvu->hw->table; 3522 3523 seq_puts(s, "\n\tExact Table Info\n"); 3524 seq_printf(s, "Exact Match Feature : %s\n", 3525 rvu->hw->cap.npc_exact_match_enabled ? "enabled" : "disable"); 3526 if (!rvu->hw->cap.npc_exact_match_enabled) 3527 return 0; 3528 3529 seq_puts(s, "\nMCAM Index\tMAC Filter Rules Count\n"); 3530 for (i = 0; i < table->num_drop_rules; i++) 3531 seq_printf(s, "%d\t\t%d\n", i, table->cnt_cmd_rules[i]); 3532 3533 seq_puts(s, "\nMcam Index\tPromisc Mode Status\n"); 3534 for (i = 0; i < table->num_drop_rules; i++) 3535 seq_printf(s, "%d\t\t%s\n", i, table->promisc_mode[i] ? "on" : "off"); 3536 3537 seq_puts(s, "\n\tMEM Table Info\n"); 3538 seq_printf(s, "Ways : %d\n", table->mem_table.ways); 3539 seq_printf(s, "Depth : %d\n", table->mem_table.depth); 3540 seq_printf(s, "Mask : 0x%llx\n", table->mem_table.mask); 3541 seq_printf(s, "Hash Mask : 0x%x\n", table->mem_table.hash_mask); 3542 seq_printf(s, "Hash Offset : 0x%x\n", table->mem_table.hash_offset); 3543 3544 seq_puts(s, "\n\tCAM Table Info\n"); 3545 seq_printf(s, "Depth : %d\n", table->cam_table.depth); 3546 3547 return 0; 3548 } 3549 3550 RVU_DEBUG_SEQ_FOPS(npc_exact_info, npc_exact_show_info, NULL); 3551 3552 static int rvu_dbg_npc_exact_drop_cnt(struct seq_file *s, void *unused) 3553 { 3554 struct npc_exact_table *table; 3555 struct rvu *rvu = s->private; 3556 struct npc_key_field *field; 3557 u16 chan, pcifunc; 3558 int blkaddr, i; 3559 u64 cfg, cam1; 3560 char *str; 3561 3562 blkaddr = rvu_get_blkaddr(rvu, BLKTYPE_NPC, 0); 3563 table = rvu->hw->table; 3564 3565 field = &rvu->hw->mcam.rx_key_fields[NPC_CHAN]; 3566 3567 seq_puts(s, "\n\t Exact Hit on drop status\n"); 3568 seq_puts(s, "\npcifunc\tmcam_idx\tHits\tchan\tstatus\n"); 3569 3570 for (i = 0; i < table->num_drop_rules; i++) { 3571 pcifunc = rvu_npc_exact_drop_rule_to_pcifunc(rvu, i); 3572 cfg = rvu_read64(rvu, blkaddr, NPC_AF_MCAMEX_BANKX_CFG(i, 0)); 3573 3574 /* channel will be always in keyword 0 */ 3575 cam1 = rvu_read64(rvu, blkaddr, 3576 NPC_AF_MCAMEX_BANKX_CAMX_W0(i, 0, 1)); 3577 chan = field->kw_mask[0] & cam1; 3578 3579 str = (cfg & 1) ? "enabled" : "disabled"; 3580 3581 seq_printf(s, "0x%x\t%d\t\t%llu\t0x%x\t%s\n", pcifunc, i, 3582 rvu_read64(rvu, blkaddr, 3583 NPC_AF_MATCH_STATX(table->counter_idx[i])), 3584 chan, str); 3585 } 3586 3587 return 0; 3588 } 3589 3590 RVU_DEBUG_SEQ_FOPS(npc_exact_drop_cnt, npc_exact_drop_cnt, NULL); 3591 3592 static void rvu_dbg_npc_init(struct rvu *rvu) 3593 { 3594 rvu->rvu_dbg.npc = debugfs_create_dir("npc", rvu->rvu_dbg.root); 3595 3596 debugfs_create_file("mcam_info", 0444, rvu->rvu_dbg.npc, rvu, 3597 &rvu_dbg_npc_mcam_info_fops); 3598 debugfs_create_file("mcam_rules", 0444, rvu->rvu_dbg.npc, rvu, 3599 &rvu_dbg_npc_mcam_rules_fops); 3600 3601 debugfs_create_file("rx_miss_act_stats", 0444, rvu->rvu_dbg.npc, rvu, 3602 &rvu_dbg_npc_rx_miss_act_fops); 3603 3604 if (!rvu->hw->cap.npc_exact_match_enabled) 3605 return; 3606 3607 debugfs_create_file("exact_entries", 0444, rvu->rvu_dbg.npc, rvu, 3608 &rvu_dbg_npc_exact_entries_fops); 3609 3610 debugfs_create_file("exact_info", 0444, rvu->rvu_dbg.npc, rvu, 3611 &rvu_dbg_npc_exact_info_fops); 3612 3613 debugfs_create_file("exact_drop_cnt", 0444, rvu->rvu_dbg.npc, rvu, 3614 &rvu_dbg_npc_exact_drop_cnt_fops); 3615 3616 } 3617 3618 static int cpt_eng_sts_display(struct seq_file *filp, u8 eng_type) 3619 { 3620 struct cpt_ctx *ctx = filp->private; 3621 u64 busy_sts = 0, free_sts = 0; 3622 u32 e_min = 0, e_max = 0, e, i; 3623 u16 max_ses, max_ies, max_aes; 3624 struct rvu *rvu = ctx->rvu; 3625 int blkaddr = ctx->blkaddr; 3626 u64 reg; 3627 3628 reg = rvu_read64(rvu, blkaddr, CPT_AF_CONSTANTS1); 3629 max_ses = reg & 0xffff; 3630 max_ies = (reg >> 16) & 0xffff; 3631 max_aes = (reg >> 32) & 0xffff; 3632 3633 switch (eng_type) { 3634 case CPT_AE_TYPE: 3635 e_min = max_ses + max_ies; 3636 e_max = max_ses + max_ies + max_aes; 3637 break; 3638 case CPT_SE_TYPE: 3639 e_min = 0; 3640 e_max = max_ses; 3641 break; 3642 case CPT_IE_TYPE: 3643 e_min = max_ses; 3644 e_max = max_ses + max_ies; 3645 break; 3646 default: 3647 return -EINVAL; 3648 } 3649 3650 for (e = e_min, i = 0; e < e_max; e++, i++) { 3651 reg = rvu_read64(rvu, blkaddr, CPT_AF_EXEX_STS(e)); 3652 if (reg & 0x1) 3653 busy_sts |= 1ULL << i; 3654 3655 if (reg & 0x2) 3656 free_sts |= 1ULL << i; 3657 } 3658 seq_printf(filp, "FREE STS : 0x%016llx\n", free_sts); 3659 seq_printf(filp, "BUSY STS : 0x%016llx\n", busy_sts); 3660 3661 return 0; 3662 } 3663 3664 static int rvu_dbg_cpt_ae_sts_display(struct seq_file *filp, void *unused) 3665 { 3666 return cpt_eng_sts_display(filp, CPT_AE_TYPE); 3667 } 3668 3669 RVU_DEBUG_SEQ_FOPS(cpt_ae_sts, cpt_ae_sts_display, NULL); 3670 3671 static int rvu_dbg_cpt_se_sts_display(struct seq_file *filp, void *unused) 3672 { 3673 return cpt_eng_sts_display(filp, CPT_SE_TYPE); 3674 } 3675 3676 RVU_DEBUG_SEQ_FOPS(cpt_se_sts, cpt_se_sts_display, NULL); 3677 3678 static int rvu_dbg_cpt_ie_sts_display(struct seq_file *filp, void *unused) 3679 { 3680 return cpt_eng_sts_display(filp, CPT_IE_TYPE); 3681 } 3682 3683 RVU_DEBUG_SEQ_FOPS(cpt_ie_sts, cpt_ie_sts_display, NULL); 3684 3685 static int rvu_dbg_cpt_engines_info_display(struct seq_file *filp, void *unused) 3686 { 3687 struct cpt_ctx *ctx = filp->private; 3688 u16 max_ses, max_ies, max_aes; 3689 struct rvu *rvu = ctx->rvu; 3690 int blkaddr = ctx->blkaddr; 3691 u32 e_max, e; 3692 u64 reg; 3693 3694 reg = rvu_read64(rvu, blkaddr, CPT_AF_CONSTANTS1); 3695 max_ses = reg & 0xffff; 3696 max_ies = (reg >> 16) & 0xffff; 3697 max_aes = (reg >> 32) & 0xffff; 3698 3699 e_max = max_ses + max_ies + max_aes; 3700 3701 seq_puts(filp, "===========================================\n"); 3702 for (e = 0; e < e_max; e++) { 3703 reg = rvu_read64(rvu, blkaddr, CPT_AF_EXEX_CTL2(e)); 3704 seq_printf(filp, "CPT Engine[%u] Group Enable 0x%02llx\n", e, 3705 reg & 0xff); 3706 reg = rvu_read64(rvu, blkaddr, CPT_AF_EXEX_ACTIVE(e)); 3707 seq_printf(filp, "CPT Engine[%u] Active Info 0x%llx\n", e, 3708 reg); 3709 reg = rvu_read64(rvu, blkaddr, CPT_AF_EXEX_CTL(e)); 3710 seq_printf(filp, "CPT Engine[%u] Control 0x%llx\n", e, 3711 reg); 3712 seq_puts(filp, "===========================================\n"); 3713 } 3714 return 0; 3715 } 3716 3717 RVU_DEBUG_SEQ_FOPS(cpt_engines_info, cpt_engines_info_display, NULL); 3718 3719 static int rvu_dbg_cpt_lfs_info_display(struct seq_file *filp, void *unused) 3720 { 3721 struct cpt_ctx *ctx = filp->private; 3722 int blkaddr = ctx->blkaddr; 3723 struct rvu *rvu = ctx->rvu; 3724 struct rvu_block *block; 3725 struct rvu_hwinfo *hw; 3726 u64 reg; 3727 u32 lf; 3728 3729 hw = rvu->hw; 3730 block = &hw->block[blkaddr]; 3731 if (!block->lf.bmap) 3732 return -ENODEV; 3733 3734 seq_puts(filp, "===========================================\n"); 3735 for (lf = 0; lf < block->lf.max; lf++) { 3736 reg = rvu_read64(rvu, blkaddr, CPT_AF_LFX_CTL(lf)); 3737 seq_printf(filp, "CPT Lf[%u] CTL 0x%llx\n", lf, reg); 3738 reg = rvu_read64(rvu, blkaddr, CPT_AF_LFX_CTL2(lf)); 3739 seq_printf(filp, "CPT Lf[%u] CTL2 0x%llx\n", lf, reg); 3740 reg = rvu_read64(rvu, blkaddr, CPT_AF_LFX_PTR_CTL(lf)); 3741 seq_printf(filp, "CPT Lf[%u] PTR_CTL 0x%llx\n", lf, reg); 3742 reg = rvu_read64(rvu, blkaddr, block->lfcfg_reg | 3743 (lf << block->lfshift)); 3744 seq_printf(filp, "CPT Lf[%u] CFG 0x%llx\n", lf, reg); 3745 seq_puts(filp, "===========================================\n"); 3746 } 3747 return 0; 3748 } 3749 3750 RVU_DEBUG_SEQ_FOPS(cpt_lfs_info, cpt_lfs_info_display, NULL); 3751 3752 static int rvu_dbg_cpt_err_info_display(struct seq_file *filp, void *unused) 3753 { 3754 struct cpt_ctx *ctx = filp->private; 3755 struct rvu *rvu = ctx->rvu; 3756 int blkaddr = ctx->blkaddr; 3757 u64 reg0, reg1; 3758 3759 reg0 = rvu_read64(rvu, blkaddr, CPT_AF_FLTX_INT(0)); 3760 reg1 = rvu_read64(rvu, blkaddr, CPT_AF_FLTX_INT(1)); 3761 seq_printf(filp, "CPT_AF_FLTX_INT: 0x%llx 0x%llx\n", reg0, reg1); 3762 reg0 = rvu_read64(rvu, blkaddr, CPT_AF_PSNX_EXE(0)); 3763 reg1 = rvu_read64(rvu, blkaddr, CPT_AF_PSNX_EXE(1)); 3764 seq_printf(filp, "CPT_AF_PSNX_EXE: 0x%llx 0x%llx\n", reg0, reg1); 3765 reg0 = rvu_read64(rvu, blkaddr, CPT_AF_PSNX_LF(0)); 3766 seq_printf(filp, "CPT_AF_PSNX_LF: 0x%llx\n", reg0); 3767 reg0 = rvu_read64(rvu, blkaddr, CPT_AF_RVU_INT); 3768 seq_printf(filp, "CPT_AF_RVU_INT: 0x%llx\n", reg0); 3769 reg0 = rvu_read64(rvu, blkaddr, CPT_AF_RAS_INT); 3770 seq_printf(filp, "CPT_AF_RAS_INT: 0x%llx\n", reg0); 3771 reg0 = rvu_read64(rvu, blkaddr, CPT_AF_EXE_ERR_INFO); 3772 seq_printf(filp, "CPT_AF_EXE_ERR_INFO: 0x%llx\n", reg0); 3773 3774 return 0; 3775 } 3776 3777 RVU_DEBUG_SEQ_FOPS(cpt_err_info, cpt_err_info_display, NULL); 3778 3779 static int rvu_dbg_cpt_pc_display(struct seq_file *filp, void *unused) 3780 { 3781 struct cpt_ctx *ctx = filp->private; 3782 struct rvu *rvu = ctx->rvu; 3783 int blkaddr = ctx->blkaddr; 3784 u64 reg; 3785 3786 reg = rvu_read64(rvu, blkaddr, CPT_AF_INST_REQ_PC); 3787 seq_printf(filp, "CPT instruction requests %llu\n", reg); 3788 reg = rvu_read64(rvu, blkaddr, CPT_AF_INST_LATENCY_PC); 3789 seq_printf(filp, "CPT instruction latency %llu\n", reg); 3790 reg = rvu_read64(rvu, blkaddr, CPT_AF_RD_REQ_PC); 3791 seq_printf(filp, "CPT NCB read requests %llu\n", reg); 3792 reg = rvu_read64(rvu, blkaddr, CPT_AF_RD_LATENCY_PC); 3793 seq_printf(filp, "CPT NCB read latency %llu\n", reg); 3794 reg = rvu_read64(rvu, blkaddr, CPT_AF_RD_UC_PC); 3795 seq_printf(filp, "CPT read requests caused by UC fills %llu\n", reg); 3796 reg = rvu_read64(rvu, blkaddr, CPT_AF_ACTIVE_CYCLES_PC); 3797 seq_printf(filp, "CPT active cycles pc %llu\n", reg); 3798 reg = rvu_read64(rvu, blkaddr, CPT_AF_CPTCLK_CNT); 3799 seq_printf(filp, "CPT clock count pc %llu\n", reg); 3800 3801 return 0; 3802 } 3803 3804 RVU_DEBUG_SEQ_FOPS(cpt_pc, cpt_pc_display, NULL); 3805 3806 static void rvu_dbg_cpt_init(struct rvu *rvu, int blkaddr) 3807 { 3808 struct cpt_ctx *ctx; 3809 3810 if (!is_block_implemented(rvu->hw, blkaddr)) 3811 return; 3812 3813 if (blkaddr == BLKADDR_CPT0) { 3814 rvu->rvu_dbg.cpt = debugfs_create_dir("cpt", rvu->rvu_dbg.root); 3815 ctx = &rvu->rvu_dbg.cpt_ctx[0]; 3816 ctx->blkaddr = BLKADDR_CPT0; 3817 ctx->rvu = rvu; 3818 } else { 3819 rvu->rvu_dbg.cpt = debugfs_create_dir("cpt1", 3820 rvu->rvu_dbg.root); 3821 ctx = &rvu->rvu_dbg.cpt_ctx[1]; 3822 ctx->blkaddr = BLKADDR_CPT1; 3823 ctx->rvu = rvu; 3824 } 3825 3826 debugfs_create_file("cpt_pc", 0600, rvu->rvu_dbg.cpt, ctx, 3827 &rvu_dbg_cpt_pc_fops); 3828 debugfs_create_file("cpt_ae_sts", 0600, rvu->rvu_dbg.cpt, ctx, 3829 &rvu_dbg_cpt_ae_sts_fops); 3830 debugfs_create_file("cpt_se_sts", 0600, rvu->rvu_dbg.cpt, ctx, 3831 &rvu_dbg_cpt_se_sts_fops); 3832 debugfs_create_file("cpt_ie_sts", 0600, rvu->rvu_dbg.cpt, ctx, 3833 &rvu_dbg_cpt_ie_sts_fops); 3834 debugfs_create_file("cpt_engines_info", 0600, rvu->rvu_dbg.cpt, ctx, 3835 &rvu_dbg_cpt_engines_info_fops); 3836 debugfs_create_file("cpt_lfs_info", 0600, rvu->rvu_dbg.cpt, ctx, 3837 &rvu_dbg_cpt_lfs_info_fops); 3838 debugfs_create_file("cpt_err_info", 0600, rvu->rvu_dbg.cpt, ctx, 3839 &rvu_dbg_cpt_err_info_fops); 3840 } 3841 3842 static const char *rvu_get_dbg_dir_name(struct rvu *rvu) 3843 { 3844 if (!is_rvu_otx2(rvu)) 3845 return "cn10k"; 3846 else 3847 return "octeontx2"; 3848 } 3849 3850 void rvu_dbg_init(struct rvu *rvu) 3851 { 3852 rvu->rvu_dbg.root = debugfs_create_dir(rvu_get_dbg_dir_name(rvu), NULL); 3853 3854 debugfs_create_file("rsrc_alloc", 0444, rvu->rvu_dbg.root, rvu, 3855 &rvu_dbg_rsrc_status_fops); 3856 3857 if (!is_rvu_otx2(rvu)) 3858 debugfs_create_file("lmtst_map_table", 0444, rvu->rvu_dbg.root, 3859 rvu, &rvu_dbg_lmtst_map_table_fops); 3860 3861 if (!cgx_get_cgxcnt_max()) 3862 goto create; 3863 3864 if (is_rvu_otx2(rvu)) 3865 debugfs_create_file("rvu_pf_cgx_map", 0444, rvu->rvu_dbg.root, 3866 rvu, &rvu_dbg_rvu_pf_cgx_map_fops); 3867 else 3868 debugfs_create_file("rvu_pf_rpm_map", 0444, rvu->rvu_dbg.root, 3869 rvu, &rvu_dbg_rvu_pf_cgx_map_fops); 3870 3871 create: 3872 rvu_dbg_npa_init(rvu); 3873 rvu_dbg_nix_init(rvu, BLKADDR_NIX0); 3874 3875 rvu_dbg_nix_init(rvu, BLKADDR_NIX1); 3876 rvu_dbg_cgx_init(rvu); 3877 rvu_dbg_npc_init(rvu); 3878 rvu_dbg_cpt_init(rvu, BLKADDR_CPT0); 3879 rvu_dbg_cpt_init(rvu, BLKADDR_CPT1); 3880 rvu_dbg_mcs_init(rvu); 3881 } 3882 3883 void rvu_dbg_exit(struct rvu *rvu) 3884 { 3885 debugfs_remove_recursive(rvu->rvu_dbg.root); 3886 } 3887 3888 #endif /* CONFIG_DEBUG_FS */ 3889