blob: 42d0c1c32af3144946485b4c52e9e6449245f0c3 [file] [log] [blame]
--
-- Copyright 2019 The Android Open Source Project
--
-- Licensed under the Apache License, Version 2.0 (the "License");
-- you may not use this file except in compliance with the License.
-- You may obtain a copy of the License at
--
-- https://www.apache.org/licenses/LICENSE-2.0
--
-- Unless required by applicable law or agreed to in writing, software
-- distributed under the License is distributed on an "AS IS" BASIS,
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-- See the License for the specific language governing permissions and
-- limitations under the License.
--
SELECT RUN_METRIC('android/process_oom_score.sql');
-- All LMK events ordered by timestamp
DROP TABLE IF EXISTS lmk_events;
CREATE TABLE lmk_events AS
WITH raw_events AS (
SELECT upid, MAX(ts) AS ts
FROM instant
JOIN process_track ON instant.track_id = process_track.id
WHERE instant.name = 'mem.lmk'
GROUP BY 1
)
SELECT
raw_events.ts,
raw_events.upid,
oom_scores.oom_score_val AS score
FROM raw_events
LEFT JOIN oom_score_span oom_scores
ON (raw_events.upid = oom_scores.upid
AND raw_events.ts >= oom_scores.ts
AND raw_events.ts < oom_scores.ts + oom_scores.dur)
ORDER BY 1;
DROP VIEW IF EXISTS android_lmk_event;
CREATE VIEW android_lmk_event AS
WITH raw_events AS (
SELECT
ts,
LEAD(ts) OVER (ORDER BY ts) - ts AS dur,
CAST(value AS INTEGER) AS pid
FROM counter c
JOIN counter_track t ON t.id = c.track_id
WHERE t.name = 'kill_one_process'
UNION ALL
SELECT
slice.ts,
slice.dur,
CAST(STR_SPLIT(slice.name, ",", 1) AS INTEGER) AS pid
FROM slice
WHERE slice.name GLOB 'lmk,*'
),
lmks_with_proc_name AS (
SELECT
*,
process.name AS process_name
FROM raw_events
LEFT JOIN process ON
process.pid = raw_events.pid
AND (raw_events.ts >= process.start_ts OR process.start_ts IS NULL)
AND (raw_events.ts < process.end_ts OR process.end_ts IS NULL)
WHERE raw_events.pid != 0
)
SELECT
'slice' AS track_type,
'Low Memory Kills (LMKs)' AS track_name,
ts,
dur,
CASE
WHEN process_name IS NULL THEN printf('Process %d', lmk.pid)
ELSE printf('%s (pid: %d)', process_name, lmk.pid)
END AS slice_name
FROM lmks_with_proc_name AS lmk;
DROP VIEW IF EXISTS android_lmk_output;
CREATE VIEW android_lmk_output AS
WITH lmk_counts AS (
SELECT score, COUNT(1) AS count
FROM lmk_events
GROUP BY score
)
SELECT AndroidLmkMetric(
'total_count', (SELECT COUNT(1) FROM lmk_events),
'by_oom_score', (
SELECT
RepeatedField(AndroidLmkMetric_ByOomScore(
'oom_score_adj', score,
'count', count
))
FROM lmk_counts
WHERE score IS NOT NULL
),
'oom_victim_count', (
SELECT COUNT(1)
FROM instant
WHERE name = 'mem.oom_kill'
)
);