1-- 2-- Copyright 2020 The Android Open Source Project 3-- 4-- Licensed under the Apache License, Version 2.0 (the "License"); 5-- you may not use this file except in compliance with the License. 6-- You may obtain a copy of the License at 7-- 8-- https://www.apache.org/licenses/LICENSE-2.0 9-- 10-- Unless required by applicable law or agreed to in writing, software 11-- distributed under the License is distributed on an "AS IS" BASIS, 12-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13-- See the License for the specific language governing permissions and 14-- limitations under the License. 15 16DROP VIEW IF EXISTS {{output}}; 17CREATE VIEW {{output}} AS 18WITH frame_missed_counters AS ( 19 SELECT 20 LAG(ts) OVER (ORDER BY ts) AS ts, 21 -- We intentionally don't partition by track id here as only one 22 -- track should ever exist with this name (the track from 23 -- surfaceflinger). 24 ts - LAG(ts) OVER (ORDER BY ts) AS dur, 25 name, 26 INSTR(name, ' ') AS separator_pos, 27 value 28 FROM counter c 29 JOIN process_counter_track t ON c.track_id = t.id 30 WHERE t.name GLOB '{{track_name}}*' 31) 32SELECT 33 CASE 34 WHEN separator_pos = 0 THEN 'unspecified' 35 ELSE SUBSTR(name, separator_pos + 1) 36 END AS display_id, 37 ts, 38 dur, 39 value 40FROM frame_missed_counters; 41