[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 1 | // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 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" |
Brett Wilson | 3d88e776 | 2017-08-14 19:54:38 | [diff] [blame] | 12 | #include "base/containers/queue.h" |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 13 | #include "base/location.h" |
Erik Chen | a9533519 | 2018-07-30 17:48:22 | [diff] [blame] | 14 | #include "base/optional.h" |
[email protected] | 8f9a3a5 | 2013-06-28 15:14:18 | [diff] [blame] | 15 | #include "base/time/time.h" |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 16 | |
| 17 | namespace base { |
| 18 | |
Alex Clarke | 1ac1f98 | 2019-03-29 08:48:37 | [diff] [blame] | 19 | enum class Nestable : uint8_t { |
Hajime Hoshi | 64853ef | 2017-10-11 12:56:07 | [diff] [blame] | 20 | kNonNestable, |
| 21 | kNestable, |
| 22 | }; |
| 23 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 24 | // Contains data about a pending task. Stored in TaskQueue and DelayedTaskQueue |
| 25 | // for use by classes that queue and execute tasks. |
Brett Wilson | b57e3dd | 2017-09-08 00:47:49 | [diff] [blame] | 26 | struct BASE_EXPORT PendingTask { |
Jesse McKenna | 9cf1137 | 2018-11-01 19:38:38 | [diff] [blame] | 27 | PendingTask(); |
Brett Wilson | 8e88b31 | 2017-09-12 05:22:16 | [diff] [blame] | 28 | PendingTask(const Location& posted_from, |
tzik | 739ffe3 | 2016-10-14 14:34:58 | [diff] [blame] | 29 | OnceClosure task, |
Hajime Hoshi | 64853ef | 2017-10-11 12:56:07 | [diff] [blame] | 30 | TimeTicks delayed_run_time = TimeTicks(), |
| 31 | Nestable nestable = Nestable::kNestable); |
tzik | b6769d5 | 2016-07-07 20:20:06 | [diff] [blame] | 32 | PendingTask(PendingTask&& other); |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 33 | ~PendingTask(); |
| 34 | |
tzik | b6769d5 | 2016-07-07 20:20:06 | [diff] [blame] | 35 | PendingTask& operator=(PendingTask&& other); |
| 36 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 37 | // Used to support sorting. |
| 38 | bool operator<(const PendingTask& other) const; |
| 39 | |
| 40 | // The task to run. |
tzik | 739ffe3 | 2016-10-14 14:34:58 | [diff] [blame] | 41 | OnceClosure task; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 42 | |
| 43 | // The site this PendingTask was posted from. |
Brett Wilson | 8e88b31 | 2017-09-12 05:22:16 | [diff] [blame] | 44 | Location posted_from; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 45 | |
Francois Doray | 118223f4 | 2019-12-04 17:00:28 | [diff] [blame] | 46 | // 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] | 47 | base::TimeTicks delayed_run_time; |
| 48 | |
Etienne Pierre-doray | 2d07903 | 2019-02-07 15:18:23 | [diff] [blame] | 49 | // The time at which the task was queued. For SequenceManager tasks and |
Gabriel Charette | 52fa3ae | 2019-04-15 21:44:37 | [diff] [blame] | 50 | // ThreadPool non-delayed tasks, this happens at post time. For |
| 51 | // ThreadPool delayed tasks, this happens some time after the task's delay |
Etienne Pierre-doray | 2d07903 | 2019-02-07 15:18:23 | [diff] [blame] | 52 | // has expired. This is not set for SequenceManager tasks if |
| 53 | // SetAddQueueTimeToTasks(true) wasn't call. This defaults to a null TimeTicks |
| 54 | // if the task hasn't been inserted in a sequence yet. |
Karolina Soltys | fe88c9e | 2018-11-06 15:27:01 | [diff] [blame] | 55 | TimeTicks queue_time; |
Erik Chen | a9533519 | 2018-07-30 17:48:22 | [diff] [blame] | 56 | |
Alan Cutter | 9b0e1ab | 2019-03-21 04:22:16 | [diff] [blame] | 57 | // Chain of symbols of the parent tasks which led to this one being posted. |
| 58 | static constexpr size_t kTaskBacktraceLength = 4; |
| 59 | std::array<const void*, kTaskBacktraceLength> task_backtrace = {}; |
ajwong | 4f13f74 | 2017-02-09 23:52:40 | [diff] [blame] | 60 | |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 61 | // 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] | 62 | // posted. This is a hash of the IPC message name that is set within the scope |
| 63 | // of an IPC handler and when symbolized uniquely identifies the message being |
Harkiran Bolaria | 875dd0d | 2020-09-15 18:10:46 | [diff] [blame] | 64 | // processed. This property is not propagated from one PendingTask to the |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 65 | // next. For example, if pending task A was posted while handling an IPC, |
| 66 | // 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] | 67 | // B will not inherit the |ipc_hash| of pending task A. |
Chris Hamilton | 88808531 | 2019-05-30 00:53:30 | [diff] [blame] | 68 | uint32_t ipc_hash = 0; |
Harkiran Bolaria | 875dd0d | 2020-09-15 18:10:46 | [diff] [blame] | 69 | const char* ipc_interface_name = nullptr; |
Chris Hamilton | 60dcc26b | 2019-04-24 16:59:51 | [diff] [blame] | 70 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 71 | // Secondary sort key for run time. |
Gabriel Charette | ae4f9ce | 2018-04-05 19:00:01 | [diff] [blame] | 72 | int sequence_num = 0; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 73 | |
Alex Clarke | 1ac1f98 | 2019-03-29 08:48:37 | [diff] [blame] | 74 | bool task_backtrace_overflow = false; |
| 75 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 76 | // OK to dispatch from a nested loop. |
Hajime Hoshi | 64853ef | 2017-10-11 12:56:07 | [diff] [blame] | 77 | Nestable nestable; |
cpu | ee890795 | 2014-08-28 23:25:37 | [diff] [blame] | 78 | |
| 79 | // Needs high resolution timers. |
Gabriel Charette | ae4f9ce | 2018-04-05 19:00:01 | [diff] [blame] | 80 | bool is_high_res = false; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 81 | }; |
| 82 | |
Brett Wilson | 3d88e776 | 2017-08-14 19:54:38 | [diff] [blame] | 83 | using TaskQueue = base::queue<PendingTask>; |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 84 | |
[email protected] | 262060ff | 2011-11-17 23:26:53 | [diff] [blame] | 85 | // PendingTasks are sorted by their |delayed_run_time| property. |
danakj | 5d79215 | 2016-06-15 20:47:47 | [diff] [blame] | 86 | using DelayedTaskQueue = std::priority_queue<base::PendingTask>; |
[email protected] | 262060ff | 2011-11-17 23:26:53 | [diff] [blame] | 87 | |
[email protected] | dd1f9fe | 2011-11-15 23:36:30 | [diff] [blame] | 88 | } // namespace base |
| 89 | |
danakj | 0a44860 | 2015-03-10 00:31:16 | [diff] [blame] | 90 | #endif // BASE_PENDING_TASK_H_ |