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" |
Avi Drissman | 63e1f99 | 2023-01-13 18:54:43 | [diff] [blame] | 11 | #include "base/functional/callback.h" |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 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 | |
Etienne Pierre-doray | f3425c7 | 2023-11-18 06:47:13 | [diff] [blame] | 23 | // Copyable data part of PendingTask. |
| 24 | struct BASE_EXPORT TaskMetadata { |
| 25 | TaskMetadata(); |
| 26 | explicit TaskMetadata(const Location& posted_from, |
| 27 | TimeTicks queue_time = TimeTicks(), |
| 28 | TimeTicks delayed_run_time = TimeTicks(), |
| 29 | TimeDelta leeway = TimeDelta(), |
| 30 | subtle::DelayPolicy delay_policy = |
| 31 | subtle::DelayPolicy::kFlexibleNoSooner); |
| 32 | TaskMetadata(TaskMetadata&& other); |
| 33 | TaskMetadata(const TaskMetadata& other); |
| 34 | ~TaskMetadata(); |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 35 | |
Etienne Pierre-doray | f3425c7 | 2023-11-18 06:47:13 | [diff] [blame] | 36 | TaskMetadata& operator=(TaskMetadata&& other); |
| 37 | TaskMetadata& operator=(const TaskMetadata& other); |
tzik | b6769d5 | 2016-07-07 20:20:06 | [diff] [blame] | 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 site this PendingTask was posted from. |
Brett Wilson | 8e88b31 | 2017-09-12 05:22:16 | [diff] [blame] | 47 | Location posted_from; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 48 | |
Etienne Pierre-doray | 69f30c8 | 2021-04-27 20:50:37 | [diff] [blame] | 49 | // The time at which the task was queued, which happens at post time. For |
| 50 | // deferred non-nestable tasks, this is reset when the nested loop exits and |
| 51 | // the deferred tasks are pushed back at the front of the queue. This is not |
| 52 | // set for immediate SequenceManager tasks unless SetAddQueueTimeToTasks(true) |
| 53 | // was called. This defaults to a null TimeTicks if the task hasn't been |
| 54 | // inserted in a sequence yet. |
| 55 | TimeTicks queue_time; |
| 56 | |
Francois Doray | 118223f4 | 2019-12-04 17:00:28 | [diff] [blame] | 57 | // 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] | 58 | base::TimeTicks delayed_run_time; |
| 59 | |
Etienne Pierre-doray | 6fcfc787 | 2022-04-26 15:56:00 | [diff] [blame] | 60 | // |leeway| and |delay_policy| determine the preferred time range for running |
| 61 | // the delayed task. A larger leeway provides more freedom to run the task at |
| 62 | // an optimal time for power consumption. These fields are ignored for an |
| 63 | // immediate (non-delayed) task. |
| 64 | TimeDelta leeway; |
| 65 | subtle::DelayPolicy delay_policy = subtle::DelayPolicy::kFlexibleNoSooner; |
| 66 | |
Alan Cutter | 9b0e1ab | 2019-03-21 04:22:16 | [diff] [blame] | 67 | // Chain of symbols of the parent tasks which led to this one being posted. |
| 68 | static constexpr size_t kTaskBacktraceLength = 4; |
| 69 | std::array<const void*, kTaskBacktraceLength> task_backtrace = {}; |
ajwong | 4f13f74 | 2017-02-09 23:52:40 | [diff] [blame] | 70 | |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 71 | // 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] | 72 | // posted. This is a hash of the IPC message name that is set within the scope |
| 73 | // of an IPC handler and when symbolized uniquely identifies the message being |
Harkiran Bolaria | 875dd0d | 2020-09-15 18:10:46 | [diff] [blame] | 74 | // processed. This property is not propagated from one PendingTask to the |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 75 | // next. For example, if pending task A was posted while handling an IPC, |
| 76 | // 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] | 77 | // B will not inherit the |ipc_hash| of pending task A. |
Chris Hamilton | 88808531 | 2019-05-30 00:53:30 | [diff] [blame] | 78 | uint32_t ipc_hash = 0; |
Harkiran Bolaria | 875dd0d | 2020-09-15 18:10:46 | [diff] [blame] | 79 | const char* ipc_interface_name = nullptr; |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 80 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 81 | // Secondary sort key for run time. |
Gabriel Charette | ae4f9ce | 2018-04-05 19:00:01 | [diff] [blame] | 82 | int sequence_num = 0; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 83 | |
Alex Clarke | 1ac1f98 | 2019-03-29 08:48:37 | [diff] [blame] | 84 | bool task_backtrace_overflow = false; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 85 | }; |
| 86 | |
Etienne Pierre-doray | f3425c7 | 2023-11-18 06:47:13 | [diff] [blame] | 87 | // Contains data about a pending task. Stored in TaskQueue and DelayedTaskQueue |
| 88 | // for use by classes that queue and execute tasks. |
| 89 | struct BASE_EXPORT PendingTask : public TaskMetadata { |
| 90 | PendingTask(); |
| 91 | PendingTask(const Location& posted_from, |
| 92 | OnceClosure task, |
| 93 | TimeTicks queue_time = TimeTicks(), |
| 94 | TimeTicks delayed_run_time = TimeTicks(), |
| 95 | TimeDelta leeway = TimeDelta(), |
| 96 | subtle::DelayPolicy delay_policy = |
| 97 | subtle::DelayPolicy::kFlexibleNoSooner); |
| 98 | PendingTask(const TaskMetadata& metadata, OnceClosure task); |
| 99 | PendingTask(PendingTask&& other); |
| 100 | ~PendingTask(); |
| 101 | |
| 102 | PendingTask& operator=(PendingTask&& other); |
| 103 | |
| 104 | // The task to run. |
| 105 | OnceClosure task; |
| 106 | }; |
| 107 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 108 | } // namespace base |
| 109 | |
danakj | 0a44860 | 2015-03-10 00:31:16 | [diff] [blame] | 110 | #endif // BASE_PENDING_TASK_H_ |