2022-02-01 11:56:32 +01:00
|
|
|
#!/usr/bin/bpftrace
|
|
|
|
|
|
|
|
|
|
//BEGIN {
|
|
|
|
|
// printf("Monitor TXQ usage\n");
|
|
|
|
|
// printf(" - Remember: BPF set queue_mapping is one-less here (zero-indexed)\n");
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
tracepoint:net:net_dev_start_xmit {
|
|
|
|
|
$qm = args->queue_mapping;
|
2022-02-01 13:28:20 +01:00
|
|
|
$dev = str(args->name, 16);
|
2022-02-01 11:56:32 +01:00
|
|
|
|
|
|
|
|
@stat_txq_usage[$dev] = lhist($qm, 0,32,1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Periodically print stats */
|
|
|
|
|
interval:s:3
|
|
|
|
|
{
|
|
|
|
|
printf("\nPeriodic show stats - time: ");
|
|
|
|
|
time();
|
|
|
|
|
print(@stat_txq_usage);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Default bpftrace will print all remaining maps at END */
|
|
|
|
|
//END {
|
|
|
|
|
// printf("END stats:\n");
|
|
|
|
|
//}
|