blob: 6c5f656ebc190decfd472653f2b0acde6964ad0e [file] [log] [blame]
Eric Laurent3528c932018-02-23 17:17:22 -08001/*
2 * Copyright (C) 2018 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 * http://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 */
16
17
18#ifndef ANDROID_TIME_CHECK_H
19#define ANDROID_TIME_CHECK_H
20
21#include <utils/KeyedVector.h>
22#include <utils/Thread.h>
23
24
25namespace android {
26
27// A class monitoring execution time for a code block (scoped variable) and causing an assert
28// if it exceeds a certain time
29
30class TimeCheck {
31public:
32
33 // The default timeout is chosen to be less than system server watchdog timeout
34 static constexpr uint32_t kDefaultTimeOutMs = 5000;
35
36 TimeCheck(const char *tag, uint32_t timeoutMs = kDefaultTimeOutMs);
37 ~TimeCheck();
38
39private:
40
41 class TimeCheckThread : public Thread {
42 public:
43
44 TimeCheckThread() {}
45 virtual ~TimeCheckThread() override;
46
47 nsecs_t startMonitoring(const char *tag, uint32_t timeoutMs);
48 void stopMonitoring(nsecs_t endTimeNs);
49
50 private:
51
52 // RefBase
53 virtual void onFirstRef() override { run("TimeCheckThread", PRIORITY_URGENT_AUDIO); }
54
55 // Thread
56 virtual bool threadLoop() override;
57
58 Condition mCond;
59 Mutex mMutex;
60 // using the end time in ns as key is OK given the risk is low that two entries
61 // are added in such a way that <add time> + <timeout> are the same for both.
62 KeyedVector< nsecs_t, const char*> mMonitorRequests;
63 };
64
65 static sp<TimeCheckThread> getTimeCheckThread();
66
67 const nsecs_t mEndTimeNs;
68};
69
70}; // namespace android
71
72#endif // ANDROID_TIME_CHECK_H