Skip to content

Commit

Permalink
[ui] Add a cmd to add counter track by ftrace args
Browse files Browse the repository at this point in the history
Bug: 330674016
Test: test ui plugin

Change-Id: Iebc040c57f0902c117ed5099413b7ffd912babfe
Signed-off-by: lukechang <[email protected]>
  • Loading branch information
lukechang committed Dec 4, 2024
1 parent dbfeb77 commit cb874d5
Showing 1 changed file with 84 additions and 1 deletion.
85 changes: 84 additions & 1 deletion ui/src/plugins/dev.perfetto.AndroidPerf/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,15 @@
// See the License for the specific language governing permissions and
// limitations under the License.

import {addDebugSliceTrack} from '../../components/tracks/debug_tracks';
import {Trace} from '../../public/trace';
import {PerfettoPlugin} from '../../public/plugin';
import {getTimeSpanOfSelectionOrVisibleWindow} from '../../public/utils';
import {addQueryResultsTab} from '../../components/query_table/query_result_tab';
import {
addDebugCounterTrack,
addDebugSliceTrack,
addPivotedTracks,
} from '../../components/tracks/debug_tracks';

export default class implements PerfettoPlugin {
static readonly id = 'dev.perfetto.AndroidPerf';
Expand Down Expand Up @@ -216,5 +220,84 @@ export default class implements PerfettoPlugin {
}
},
});

ctx.commands.registerCommand({
id: 'dev.perfetto.AndroidPerf#CounterByFtraceEventArgs',
name: 'Add counter tracks by ftrace event arguments',
callback: async (event, value, filter, filterValue) => {
if (event === undefined) {
event = prompt('Enter the name of the targeted ftrace event', '');
if (event === null) return;
const resp = await ctx.engine.query(`
SELECT * FROM ftrace_event WHERE name = '${event}' LIMIT 1
`);
if (resp.numRows() === 0) {
alert(`Can not find ${event} ftrace event in this trace`);
return;
}
}
if (value === undefined) {
value = prompt('Enter the name of arguments as counter value', '');
if (value === null) return;
const resp = await ctx.engine.query(`
SELECT *
FROM ftrace_event
JOIN args
USING (arg_set_id)
WHERE name = '${event}' AND key = '${value}'
LIMIT 1
`);
if (resp.numRows() === 0) {
alert(`The ${event} ftrace event does not have argument ${value}`);
return;
}
}
if (filter === undefined) {
filter = prompt('Enter the name of arguments to pivot', '');
if (filter === null) return;
const resp = await ctx.engine.query(`
SELECT *
FROM ftrace_event
JOIN args
USING (arg_set_id)
WHERE name = '${event}' AND key = '${filter}'
LIMIT 1
`);
if (resp.numRows() === 0) {
alert(`The ${event} ftrace event does not have argument ${filter}`);
return;
}
}
if (filterValue === undefined) {
filterValue = prompt(
'List the target pivot values (separate by comma) to present\n' +
'ex1: 123,456 \n' +
'ex2: "task_name1","task_name2"\n',
'',
);
if (filterValue === null) return;
}
await addPivotedTracks(
ctx,
{
sqlSource: `
SELECT
ts,
EXTRACT_ARG(arg_set_id, '${value}') AS value,
EXTRACT_ARG(arg_set_id, '${filter}') AS pivot
FROM ftrace_event
WHERE name = '${event}' AND pivot IN (${filterValue})`,
},
event + '#' + value + '@' + filter,
'pivot',
async (ctx, data, trackName) =>
addDebugCounterTrack({
trace: ctx,
data,
title: trackName,
}),
);
},
});
}
}

0 comments on commit cb874d5

Please sign in to comment.