blob: 8e5bedd55bbbbdc37c0d07a4e5df73cda46c4b09 [file] [log] [blame]
Glenn Kastena18f6442014-03-18 17:17:04 -07001/*
2 * Copyright (C) 2014 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
Andy Hungf0859f32023-05-25 16:28:04 -070017#pragma once
Glenn Kastena18f6442014-03-18 17:17:04 -070018
Andy Hungf0859f32023-05-25 16:28:04 -070019#include <type_traits>
Glenn Kasten22340022014-04-07 12:04:41 -070020#include "Configuration.h"
Glenn Kastena18f6442014-03-18 17:17:04 -070021#include <stdint.h>
Glenn Kasten8589ce72017-09-08 17:03:42 -070022#include <media/nblog/NBLog.h>
Glenn Kastena18f6442014-03-18 17:17:04 -070023
24namespace android {
25
Glenn Kasten22340022014-04-07 12:04:41 -070026struct FastThreadDumpState;
27
Glenn Kastena18f6442014-03-18 17:17:04 -070028// Represents a single state of a FastThread
29struct FastThreadState {
Andy Hungf0859f32023-05-25 16:28:04 -070030 using Command = uint32_t;
Glenn Kastena18f6442014-03-18 17:17:04 -070031 static const Command
32 INITIAL = 0, // used only for the initial state
33 HOT_IDLE = 1, // do nothing
34 COLD_IDLE = 2, // wait for the futex
35 IDLE = 3, // either HOT_IDLE or COLD_IDLE
36 EXIT = 4; // exit from thread
37 // additional values defined per subclass
Andy Hung05302372023-05-26 16:24:28 -070038 Command mCommand = INITIAL; // current command
39 int32_t* mColdFutexAddr = nullptr; // for COLD_IDLE only, pointer to the associated futex
40 unsigned mColdGen = 0; // increment when COLD_IDLE is requested
41 // so it's only performed once
Glenn Kastena18f6442014-03-18 17:17:04 -070042
Glenn Kasten22340022014-04-07 12:04:41 -070043 // This might be a one-time configuration rather than per-state
Andy Hung05302372023-05-26 16:24:28 -070044 FastThreadDumpState* mDumpState = nullptr; // if non-NULL, then update dump state periodically
45 NBLog::Writer* mNBLogWriter = nullptr; // non-blocking logger
Glenn Kasten22340022014-04-07 12:04:41 -070046
Glenn Kastend702a562015-03-02 15:51:38 -080047 // returns NULL if command belongs to a subclass
48 static const char *commandToString(Command command);
Glenn Kastena18f6442014-03-18 17:17:04 -070049}; // struct FastThreadState
50
Andy Hungf0859f32023-05-25 16:28:04 -070051// No virtuals.
52static_assert(!std::is_polymorphic_v<FastThreadState>);
Glenn Kastena18f6442014-03-18 17:17:04 -070053
Andy Hungf0859f32023-05-25 16:28:04 -070054} // namespace android