162306a36Sopenharmony_ci#!/bin/bash 262306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0+ 362306a36Sopenharmony_ci# 462306a36Sopenharmony_ci# Analyze a given results directory for rcuscale performance measurements, 562306a36Sopenharmony_ci# looking for ftrace data. Exits with 0 if data was found, analyzed, and 662306a36Sopenharmony_ci# printed. Intended to be invoked from kvm-recheck-rcuscale.sh after 762306a36Sopenharmony_ci# argument checking. 862306a36Sopenharmony_ci# 962306a36Sopenharmony_ci# Usage: kvm-recheck-rcuscale-ftrace.sh resdir 1062306a36Sopenharmony_ci# 1162306a36Sopenharmony_ci# Copyright (C) IBM Corporation, 2016 1262306a36Sopenharmony_ci# 1362306a36Sopenharmony_ci# Authors: Paul E. McKenney <paulmck@linux.ibm.com> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_cii="$1" 1662306a36Sopenharmony_ci. functions.sh 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ciif test "`grep -c 'rcu_exp_grace_period.*start' < $i/console.log`" -lt 100 1962306a36Sopenharmony_cithen 2062306a36Sopenharmony_ci exit 10 2162306a36Sopenharmony_cifi 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_cised -e 's/^\[[^]]*]//' < $i/console.log | 2462306a36Sopenharmony_cigrep 'us : rcu_exp_grace_period' | 2562306a36Sopenharmony_cised -e 's/us : / : /' | 2662306a36Sopenharmony_citr -d '\015' | 2762306a36Sopenharmony_ciawk ' 2862306a36Sopenharmony_ci$8 == "start" { 2962306a36Sopenharmony_ci if (startseq != "") 3062306a36Sopenharmony_ci nlost++; 3162306a36Sopenharmony_ci starttask = $1; 3262306a36Sopenharmony_ci starttime = $3; 3362306a36Sopenharmony_ci startseq = $7; 3462306a36Sopenharmony_ci seqtask[startseq] = starttask; 3562306a36Sopenharmony_ci} 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci$8 == "end" { 3862306a36Sopenharmony_ci if (startseq == $7) { 3962306a36Sopenharmony_ci curgpdur = $3 - starttime; 4062306a36Sopenharmony_ci gptimes[++n] = curgpdur; 4162306a36Sopenharmony_ci gptaskcnt[starttask]++; 4262306a36Sopenharmony_ci sum += curgpdur; 4362306a36Sopenharmony_ci if (curgpdur > 1000) 4462306a36Sopenharmony_ci print "Long GP " starttime "us to " $3 "us (" curgpdur "us)"; 4562306a36Sopenharmony_ci startseq = ""; 4662306a36Sopenharmony_ci } else { 4762306a36Sopenharmony_ci # Lost a message or some such, reset. 4862306a36Sopenharmony_ci startseq = ""; 4962306a36Sopenharmony_ci nlost++; 5062306a36Sopenharmony_ci } 5162306a36Sopenharmony_ci} 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci$8 == "done" && seqtask[$7] != $1 { 5462306a36Sopenharmony_ci piggybackcnt[$1]++; 5562306a36Sopenharmony_ci} 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ciEND { 5862306a36Sopenharmony_ci newNR = asort(gptimes); 5962306a36Sopenharmony_ci if (newNR <= 0) { 6062306a36Sopenharmony_ci print "No ftrace records found???" 6162306a36Sopenharmony_ci exit 10; 6262306a36Sopenharmony_ci } 6362306a36Sopenharmony_ci pct50 = int(newNR * 50 / 100); 6462306a36Sopenharmony_ci if (pct50 < 1) 6562306a36Sopenharmony_ci pct50 = 1; 6662306a36Sopenharmony_ci pct90 = int(newNR * 90 / 100); 6762306a36Sopenharmony_ci if (pct90 < 1) 6862306a36Sopenharmony_ci pct90 = 1; 6962306a36Sopenharmony_ci pct99 = int(newNR * 99 / 100); 7062306a36Sopenharmony_ci if (pct99 < 1) 7162306a36Sopenharmony_ci pct99 = 1; 7262306a36Sopenharmony_ci div = 10 ** int(log(gptimes[pct90]) / log(10) + .5) / 100; 7362306a36Sopenharmony_ci print "Histogram bucket size: " div; 7462306a36Sopenharmony_ci last = gptimes[1] - 10; 7562306a36Sopenharmony_ci count = 0; 7662306a36Sopenharmony_ci for (i = 1; i <= newNR; i++) { 7762306a36Sopenharmony_ci current = div * int(gptimes[i] / div); 7862306a36Sopenharmony_ci if (last == current) { 7962306a36Sopenharmony_ci count++; 8062306a36Sopenharmony_ci } else { 8162306a36Sopenharmony_ci if (count > 0) 8262306a36Sopenharmony_ci print last, count; 8362306a36Sopenharmony_ci count = 1; 8462306a36Sopenharmony_ci last = current; 8562306a36Sopenharmony_ci } 8662306a36Sopenharmony_ci } 8762306a36Sopenharmony_ci if (count > 0) 8862306a36Sopenharmony_ci print last, count; 8962306a36Sopenharmony_ci print "Distribution of grace periods across tasks:"; 9062306a36Sopenharmony_ci for (i in gptaskcnt) { 9162306a36Sopenharmony_ci print "\t" i, gptaskcnt[i]; 9262306a36Sopenharmony_ci nbatches += gptaskcnt[i]; 9362306a36Sopenharmony_ci } 9462306a36Sopenharmony_ci ngps = nbatches; 9562306a36Sopenharmony_ci print "Distribution of piggybacking across tasks:"; 9662306a36Sopenharmony_ci for (i in piggybackcnt) { 9762306a36Sopenharmony_ci print "\t" i, piggybackcnt[i]; 9862306a36Sopenharmony_ci ngps += piggybackcnt[i]; 9962306a36Sopenharmony_ci } 10062306a36Sopenharmony_ci print "Average grace-period duration: " sum / newNR " microseconds"; 10162306a36Sopenharmony_ci print "Minimum grace-period duration: " gptimes[1]; 10262306a36Sopenharmony_ci print "50th percentile grace-period duration: " gptimes[pct50]; 10362306a36Sopenharmony_ci print "90th percentile grace-period duration: " gptimes[pct90]; 10462306a36Sopenharmony_ci print "99th percentile grace-period duration: " gptimes[pct99]; 10562306a36Sopenharmony_ci print "Maximum grace-period duration: " gptimes[newNR]; 10662306a36Sopenharmony_ci print "Grace periods: " ngps + 0 " Batches: " nbatches + 0 " Ratio: " ngps / nbatches " Lost: " nlost + 0; 10762306a36Sopenharmony_ci print "Computed from ftrace data."; 10862306a36Sopenharmony_ci}' 10962306a36Sopenharmony_ciexit 0 110