Avi Drissman | e4622aa | 2022-09-08 20:36:06 | [diff] [blame] | 1 | // Copyright 2011 The Chromium Authors |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
danakj | 0a44860 | 2015-03-10 00:31:16 | [diff] [blame] | 5 | #ifndef BASE_PENDING_TASK_H_ |
| 6 | #define BASE_PENDING_TASK_H_ |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 7 | |
ajwong | 4f13f74 | 2017-02-09 23:52:40 | [diff] [blame] | 8 | #include <array> |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 9 | |
[email protected] | c360bae7 | 2011-11-18 06:08:02 | [diff] [blame] | 10 | #include "base/base_export.h" |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 11 | #include "base/callback.h" |
| 12 | #include "base/location.h" |
Etienne Pierre-doray | 6fcfc787 | 2022-04-26 15:56:00 | [diff] [blame] | 13 | #include "base/task/delay_policy.h" |
[email protected] | 8f9a3a5 | 2013-06-28 15:14:18 | [diff] [blame] | 14 | #include "base/time/time.h" |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 15 | |
| 16 | namespace base { |
| 17 | |
Alex Clarke | 1ac1f98 | 2019-03-29 08:48:37 | [diff] [blame] | 18 | enum class Nestable : uint8_t { |
Hajime Hoshi | 64853ef | 2017-10-11 12:56:07 | [diff] [blame] | 19 | kNonNestable, |
| 20 | kNestable, |
| 21 | }; |
| 22 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 23 | // Contains data about a pending task. Stored in TaskQueue and DelayedTaskQueue |
| 24 | // for use by classes that queue and execute tasks. |
Brett Wilson | b57e3dd | 2017-09-08 00:47:49 | [diff] [blame] | 25 | struct BASE_EXPORT PendingTask { |
Jesse McKenna | 9cf1137 | 2018-11-01 19:38:38 | [diff] [blame] | 26 | PendingTask(); |
Brett Wilson | 8e88b31 | 2017-09-12 05:22:16 | [diff] [blame] | 27 | PendingTask(const Location& posted_from, |
tzik | 739ffe3 | 2016-10-14 14:34:58 | [diff] [blame] | 28 | OnceClosure task, |
Etienne Pierre-doray | 6fcfc787 | 2022-04-26 15:56:00 | [diff] [blame] | 29 | TimeTicks queue_time = TimeTicks(), |
| 30 | TimeTicks delayed_run_time = TimeTicks(), |
| 31 | TimeDelta leeway = TimeDelta(), |
| 32 | subtle::DelayPolicy delay_policy = |
| 33 | subtle::DelayPolicy::kFlexibleNoSooner); |
tzik | b6769d5 | 2016-07-07 20:20:06 | [diff] [blame] | 34 | PendingTask(PendingTask&& other); |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 35 | ~PendingTask(); |
| 36 | |
tzik | b6769d5 | 2016-07-07 20:20:06 | [diff] [blame] | 37 | PendingTask& operator=(PendingTask&& other); |
| 38 | |
Etienne Pierre-doray | 69f30c8 | 2021-04-27 20:50:37 | [diff] [blame] | 39 | // Returns the time at which this task should run. This is |delayed_run_time| |
| 40 | // for a delayed task, |queue_time| otherwise. |
| 41 | base::TimeTicks GetDesiredExecutionTime() const; |
| 42 | |
Etienne Pierre-doray | 6fcfc787 | 2022-04-26 15:56:00 | [diff] [blame] | 43 | TimeTicks earliest_delayed_run_time() const; |
| 44 | TimeTicks latest_delayed_run_time() const; |
| 45 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 46 | // The task to run. |
tzik | 739ffe3 | 2016-10-14 14:34:58 | [diff] [blame] | 47 | OnceClosure task; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 48 | |
| 49 | // The site this PendingTask was posted from. |
Brett Wilson | 8e88b31 | 2017-09-12 05:22:16 | [diff] [blame] | 50 | Location posted_from; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 51 | |
Etienne Pierre-doray | 69f30c8 | 2021-04-27 20:50:37 | [diff] [blame] | 52 | // The time at which the task was queued, which happens at post time. For |
| 53 | // deferred non-nestable tasks, this is reset when the nested loop exits and |
| 54 | // the deferred tasks are pushed back at the front of the queue. This is not |
| 55 | // set for immediate SequenceManager tasks unless SetAddQueueTimeToTasks(true) |
| 56 | // was called. This defaults to a null TimeTicks if the task hasn't been |
| 57 | // inserted in a sequence yet. |
| 58 | TimeTicks queue_time; |
| 59 | |
Francois Doray | 118223f4 | 2019-12-04 17:00:28 | [diff] [blame] | 60 | // The time when the task should be run. This is null for an immediate task. |
Brett Wilson | b57e3dd | 2017-09-08 00:47:49 | [diff] [blame] | 61 | base::TimeTicks delayed_run_time; |
| 62 | |
Etienne Pierre-doray | 6fcfc787 | 2022-04-26 15:56:00 | [diff] [blame] | 63 | // |leeway| and |delay_policy| determine the preferred time range for running |
| 64 | // the delayed task. A larger leeway provides more freedom to run the task at |
| 65 | // an optimal time for power consumption. These fields are ignored for an |
| 66 | // immediate (non-delayed) task. |
| 67 | TimeDelta leeway; |
| 68 | subtle::DelayPolicy delay_policy = subtle::DelayPolicy::kFlexibleNoSooner; |
| 69 | |
Alan Cutter | 9b0e1ab | 2019-03-21 04:22:16 | [diff] [blame] | 70 | // Chain of symbols of the parent tasks which led to this one being posted. |
| 71 | static constexpr size_t kTaskBacktraceLength = 4; |
| 72 | std::array<const void*, kTaskBacktraceLength> task_backtrace = {}; |
ajwong | 4f13f74 | 2017-02-09 23:52:40 | [diff] [blame] | 73 | |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 74 | // The context of the IPC message that was being handled when this task was |
Chris Hamilton | 88808531 | 2019-05-30 00:53:30 | [diff] [blame] | 75 | // posted. This is a hash of the IPC message name that is set within the scope |
| 76 | // of an IPC handler and when symbolized uniquely identifies the message being |
Harkiran Bolaria | 875dd0d | 2020-09-15 18:10:46 | [diff] [blame] | 77 | // processed. This property is not propagated from one PendingTask to the |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 78 | // next. For example, if pending task A was posted while handling an IPC, |
| 79 | // and pending task B was posted from within pending task A, then pending task |
Harkiran Bolaria | 875dd0d | 2020-09-15 18:10:46 | [diff] [blame] | 80 | // B will not inherit the |ipc_hash| of pending task A. |
Chris Hamilton | 88808531 | 2019-05-30 00:53:30 | [diff] [blame] | 81 | uint32_t ipc_hash = 0; |
Harkiran Bolaria | 875dd0d | 2020-09-15 18:10:46 | [diff] [blame] | 82 | const char* ipc_interface_name = nullptr; |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 83 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 84 | // Secondary sort key for run time. |
Gabriel Charette | ae4f9ce | 2018-04-05 19:00:01 | [diff] [blame] | 85 | int sequence_num = 0; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 86 | |
Alex Clarke | 1ac1f98 | 2019-03-29 08:48:37 | [diff] [blame] | 87 | bool task_backtrace_overflow = false; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 88 | }; |
| 89 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 90 | } // namespace base |
| 91 | |
danakj | 0a44860 | 2015-03-10 00:31:16 | [diff] [blame] | 92 | #endif // BASE_PENDING_TASK_H_ |