1234567891011121314151617181920212223242526272829303132333435 |
- #!/usr/bin/tclsh
- #
- # Run this script, redirecting input from cachegrind output, to compute the
- # number of CPU cycles used by each VDBE opcode.
- #
- # The cachegrind output should be configured so that it reports a single
- # column of Ir at the left margin. Ex:
- #
- # cg_annotation --show=Ir --auto=yes cachegrind.out.* | tclsh opcodesum.tcl
- #
- set currentop x
- set ncycle(x) 0
- while {![eof stdin]} {
- set line [string map {\173 x \175 x \042 x} [gets stdin]]
- if {[regexp { \. case OP_.*:} $line]} {
- regexp {OP_(.+):} $line all currentop
- set ncycle($currentop) 0
- } elseif {[lindex $line 1]=="default:"
- && [regexp {really OP_Noop and OP_Explain} $line]} {
- break
- } elseif {[lindex $line 0]!="."} {
- regsub -all {[^0-9]} [lindex $line 0] {} n
- if {$n!=""} {incr ncycle($currentop) $n}
- }
- }
- unset ncycle(x)
- set results {}
- foreach op [lsort [array names ncycle]] {
- if {$ncycle($op)==0} continue
- lappend results [list $ncycle($op) $op]
- }
- foreach entry [lsort -index 0 -int -decr $results] {
- puts [format {%-16s %10d} [lindex $entry 1] [lindex $entry 0]]
- }
|