From 6aa8ad4340101a9587e50828a2f4c45062e94f7e Mon Sep 17 00:00:00 2001 From: Primiano Tucci Date: Thu, 14 Nov 2024 17:54:13 +0000 Subject: [PATCH] ui: make ftrace track 10x faster Change the rendering from diamonds to just rects. Diamonds were 10x slower to draw due to transforms and context save/restore, and didn't bring any immediate benefit. Change-Id: I9e0e93b2114d1f44c8af6f8e43e8d53dd7fcf6c2 --- .../ftrace-tracks/ftrace-events.png.sha256 | 2 +- .../dev.perfetto.Ftrace/ftrace_track.ts | 49 ++++++++----------- 2 files changed, 22 insertions(+), 29 deletions(-) diff --git a/test/data/ui-screenshots/ftrace_tracks_and_tab.test.ts/ftrace-tracks/ftrace-events.png.sha256 b/test/data/ui-screenshots/ftrace_tracks_and_tab.test.ts/ftrace-tracks/ftrace-events.png.sha256 index b97e598e22..66f89fe0bb 100644 --- a/test/data/ui-screenshots/ftrace_tracks_and_tab.test.ts/ftrace-tracks/ftrace-events.png.sha256 +++ b/test/data/ui-screenshots/ftrace_tracks_and_tab.test.ts/ftrace-tracks/ftrace-events.png.sha256 @@ -1 +1 @@ -ef239fe1e10e3b830f7adf9b5b8f96a52c69a50e6d879cfb5a873cd26caab769 \ No newline at end of file +ae6623f3d00536a815ad76c40c5933845a436e6e8acee6349d0e925c06d0b6b0 \ No newline at end of file diff --git a/ui/src/plugins/dev.perfetto.Ftrace/ftrace_track.ts b/ui/src/plugins/dev.perfetto.Ftrace/ftrace_track.ts index 31ea7de5ee..78c59c8d44 100644 --- a/ui/src/plugins/dev.perfetto.Ftrace/ftrace_track.ts +++ b/ui/src/plugins/dev.perfetto.Ftrace/ftrace_track.ts @@ -27,11 +27,14 @@ import {TrackRenderContext} from '../../public/track'; const MARGIN = 2; const RECT_HEIGHT = 18; +const RECT_WIDTH = 8; const TRACK_HEIGHT = RECT_HEIGHT + 2 * MARGIN; -export interface Data extends TrackData { - timestamps: BigInt64Array; - names: string[]; +interface Data extends TrackData { + events: Array<{ + timestamp: time; + color: string; + }>; } export interface Config { @@ -92,21 +95,22 @@ export class FtraceRawTrack implements Track { order by tsQuant limit ${LIMIT};`); const rowCount = queryRes.numRows(); - const result: Data = { + + const it = queryRes.iter({tsQuant: LONG, name: STR}); + const events = []; + for (let row = 0; it.valid(); it.next(), row++) { + events.push({ + timestamp: Time.fromRaw(it.tsQuant), + color: colorForFtrace(it.name).base.cssString, + }); + } + return { start, end, resolution, length: rowCount, - timestamps: new BigInt64Array(rowCount), - names: [], + events, }; - - const it = queryRes.iter({tsQuant: LONG, name: STR}); - for (let row = 0; it.valid(); it.next(), row++) { - result.timestamps[row] = it.tsQuant; - result.names[row] = it.name; - } - return result; } render({ctx, size, timescale}: TrackRenderContext): void { @@ -125,21 +129,10 @@ export class FtraceRawTrack implements Track { dataStartPx, dataEndPx, ); - - const diamondSideLen = RECT_HEIGHT / Math.sqrt(2); - - for (let i = 0; i < data.timestamps.length; i++) { - const name = data.names[i]; - ctx.fillStyle = colorForFtrace(name).base.cssString; - const timestamp = Time.fromRaw(data.timestamps[i]); - const xPos = Math.floor(timescale.timeToPx(timestamp)); - - // Draw a diamond over the event - ctx.save(); - ctx.translate(xPos, MARGIN); - ctx.rotate(Math.PI / 4); - ctx.fillRect(0, 0, diamondSideLen, diamondSideLen); - ctx.restore(); + for (const e of data.events) { + ctx.fillStyle = e.color; + const xPos = Math.floor(timescale.timeToPx(e.timestamp)); + ctx.fillRect(xPos - RECT_WIDTH / 2, MARGIN, RECT_WIDTH, RECT_HEIGHT); } } }