blob: 5f852111e07798a023af63bca8aa48c73db8172c [file] [log] [blame]
Jason Molenda5e8dce42013-12-13 00:29:16 +00001//===-- SBQueue.cpp ---------------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Virgile Belloda0fc762014-03-08 16:22:55 +000010#include <inttypes.h>
11
Jason Molenda5e8dce42013-12-13 00:29:16 +000012#include "lldb/API/SBQueue.h"
13
14#include "lldb/API/SBProcess.h"
Jason Molendab9ffa982014-04-25 00:01:15 +000015#include "lldb/API/SBQueueItem.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000016#include "lldb/API/SBThread.h"
Jason Molendab9ffa982014-04-25 00:01:15 +000017
Jason Molenda5e8dce42013-12-13 00:29:16 +000018#include "lldb/Target/Process.h"
19#include "lldb/Target/Queue.h"
20#include "lldb/Target/QueueItem.h"
21#include "lldb/Target/Thread.h"
Zachary Turner6f9e6902017-03-03 20:56:28 +000022#include "lldb/Utility/Log.h"
Jason Molenda5e8dce42013-12-13 00:29:16 +000023
24using namespace lldb;
25using namespace lldb_private;
26
Kate Stoneb9c1b512016-09-06 20:57:50 +000027namespace lldb_private {
Jason Molendac8064ac2013-12-14 01:14:45 +000028
Kate Stoneb9c1b512016-09-06 20:57:50 +000029class QueueImpl {
30public:
31 QueueImpl()
32 : m_queue_wp(), m_threads(), m_thread_list_fetched(false),
33 m_pending_items(), m_pending_items_fetched(false) {}
Jason Molendac8064ac2013-12-14 01:14:45 +000034
Kate Stoneb9c1b512016-09-06 20:57:50 +000035 QueueImpl(const lldb::QueueSP &queue_sp)
36 : m_queue_wp(), m_threads(), m_thread_list_fetched(false),
37 m_pending_items(), m_pending_items_fetched(false) {
38 m_queue_wp = queue_sp;
39 }
Jason Molendac8064ac2013-12-14 01:14:45 +000040
Kate Stoneb9c1b512016-09-06 20:57:50 +000041 QueueImpl(const QueueImpl &rhs) {
Jason Molendac8064ac2013-12-14 01:14:45 +000042 if (&rhs == this)
Kate Stoneb9c1b512016-09-06 20:57:50 +000043 return;
44 m_queue_wp = rhs.m_queue_wp;
45 m_threads = rhs.m_threads;
46 m_thread_list_fetched = rhs.m_thread_list_fetched;
47 m_pending_items = rhs.m_pending_items;
48 m_pending_items_fetched = rhs.m_pending_items_fetched;
49 }
Jason Molendac8064ac2013-12-14 01:14:45 +000050
Kate Stoneb9c1b512016-09-06 20:57:50 +000051 ~QueueImpl() {}
Jason Molendac8064ac2013-12-14 01:14:45 +000052
Kate Stoneb9c1b512016-09-06 20:57:50 +000053 bool IsValid() { return m_queue_wp.lock() != NULL; }
Jason Molendac8064ac2013-12-14 01:14:45 +000054
Kate Stoneb9c1b512016-09-06 20:57:50 +000055 void Clear() {
56 m_queue_wp.reset();
57 m_thread_list_fetched = false;
58 m_threads.clear();
59 m_pending_items_fetched = false;
60 m_pending_items.clear();
61 }
Jason Molenda5e8dce42013-12-13 00:29:16 +000062
Kate Stoneb9c1b512016-09-06 20:57:50 +000063 void SetQueue(const lldb::QueueSP &queue_sp) {
64 Clear();
65 m_queue_wp = queue_sp;
66 }
67
68 lldb::queue_id_t GetQueueID() const {
69 lldb::queue_id_t result = LLDB_INVALID_QUEUE_ID;
70 lldb::QueueSP queue_sp = m_queue_wp.lock();
71 if (queue_sp) {
72 result = queue_sp->GetID();
73 }
74 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
Jason Molendaac605f42014-03-08 01:34:55 +000075 if (log)
Kate Stoneb9c1b512016-09-06 20:57:50 +000076 log->Printf("SBQueue(%p)::GetQueueID () => 0x%" PRIx64,
77 static_cast<const void *>(this), result);
78 return result;
79 }
Jason Molenda5e8dce42013-12-13 00:29:16 +000080
Kate Stoneb9c1b512016-09-06 20:57:50 +000081 uint32_t GetIndexID() const {
82 uint32_t result = LLDB_INVALID_INDEX32;
83 lldb::QueueSP queue_sp = m_queue_wp.lock();
84 if (queue_sp) {
85 result = queue_sp->GetIndexID();
86 }
87 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
Jason Molendaac605f42014-03-08 01:34:55 +000088 if (log)
Kate Stoneb9c1b512016-09-06 20:57:50 +000089 log->Printf("SBQueueImpl(%p)::GetIndexID () => %d",
90 static_cast<const void *>(this), result);
91 return result;
92 }
Jason Molenda5e8dce42013-12-13 00:29:16 +000093
Kate Stoneb9c1b512016-09-06 20:57:50 +000094 const char *GetName() const {
95 const char *name = NULL;
96 lldb::QueueSP queue_sp = m_queue_wp.lock();
97 if (queue_sp.get()) {
98 name = queue_sp->GetName();
99 }
Jason Molenda5e8dce42013-12-13 00:29:16 +0000100
Kate Stoneb9c1b512016-09-06 20:57:50 +0000101 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
Jason Molendaac605f42014-03-08 01:34:55 +0000102 if (log)
Kate Stoneb9c1b512016-09-06 20:57:50 +0000103 log->Printf("SBQueueImpl(%p)::GetName () => %s",
104 static_cast<const void *>(this), name ? name : "NULL");
Jason Molenda5e8dce42013-12-13 00:29:16 +0000105
Jason Molendaac605f42014-03-08 01:34:55 +0000106 return name;
Kate Stoneb9c1b512016-09-06 20:57:50 +0000107 }
108
109 void FetchThreads() {
110 if (m_thread_list_fetched == false) {
111 lldb::QueueSP queue_sp = m_queue_wp.lock();
112 if (queue_sp) {
113 Process::StopLocker stop_locker;
114 if (stop_locker.TryLock(&queue_sp->GetProcess()->GetRunLock())) {
115 const std::vector<ThreadSP> thread_list(queue_sp->GetThreads());
116 m_thread_list_fetched = true;
117 const uint32_t num_threads = thread_list.size();
118 for (uint32_t idx = 0; idx < num_threads; ++idx) {
119 ThreadSP thread_sp = thread_list[idx];
120 if (thread_sp && thread_sp->IsValid()) {
121 m_threads.push_back(thread_sp);
122 }
123 }
124 }
125 }
126 }
127 }
128
129 void FetchItems() {
130 if (m_pending_items_fetched == false) {
131 QueueSP queue_sp = m_queue_wp.lock();
132 if (queue_sp) {
133 Process::StopLocker stop_locker;
134 if (stop_locker.TryLock(&queue_sp->GetProcess()->GetRunLock())) {
135 const std::vector<QueueItemSP> queue_items(
136 queue_sp->GetPendingItems());
137 m_pending_items_fetched = true;
138 const uint32_t num_pending_items = queue_items.size();
139 for (uint32_t idx = 0; idx < num_pending_items; ++idx) {
140 QueueItemSP item = queue_items[idx];
141 if (item && item->IsValid()) {
142 m_pending_items.push_back(item);
143 }
144 }
145 }
146 }
147 }
148 }
149
150 uint32_t GetNumThreads() {
151 uint32_t result = 0;
152
153 FetchThreads();
154 if (m_thread_list_fetched) {
155 result = m_threads.size();
156 }
157 return result;
158 }
159
160 lldb::SBThread GetThreadAtIndex(uint32_t idx) {
161 FetchThreads();
162
163 SBThread sb_thread;
164 QueueSP queue_sp = m_queue_wp.lock();
165 if (queue_sp && idx < m_threads.size()) {
166 ProcessSP process_sp = queue_sp->GetProcess();
167 if (process_sp) {
168 ThreadSP thread_sp = m_threads[idx].lock();
169 if (thread_sp) {
170 sb_thread.SetThread(thread_sp);
171 }
172 }
173 }
174 return sb_thread;
175 }
176
177 uint32_t GetNumPendingItems() {
178 uint32_t result = 0;
179
180 QueueSP queue_sp = m_queue_wp.lock();
181 if (m_pending_items_fetched == false && queue_sp) {
182 result = queue_sp->GetNumPendingWorkItems();
183 } else {
184 result = m_pending_items.size();
185 }
186 return result;
187 }
188
189 lldb::SBQueueItem GetPendingItemAtIndex(uint32_t idx) {
190 SBQueueItem result;
191 FetchItems();
192 if (m_pending_items_fetched && idx < m_pending_items.size()) {
193 result.SetQueueItem(m_pending_items[idx]);
194 }
195 return result;
196 }
197
198 uint32_t GetNumRunningItems() {
199 uint32_t result = 0;
200 QueueSP queue_sp = m_queue_wp.lock();
201 if (queue_sp)
202 result = queue_sp->GetNumRunningWorkItems();
203 return result;
204 }
205
206 lldb::SBProcess GetProcess() {
207 SBProcess result;
208 QueueSP queue_sp = m_queue_wp.lock();
209 if (queue_sp) {
210 result.SetSP(queue_sp->GetProcess());
211 }
212 return result;
213 }
214
215 lldb::QueueKind GetKind() {
216 lldb::QueueKind kind = eQueueKindUnknown;
217 QueueSP queue_sp = m_queue_wp.lock();
218 if (queue_sp)
219 kind = queue_sp->GetKind();
220
221 return kind;
222 }
223
224private:
225 lldb::QueueWP m_queue_wp;
226 std::vector<lldb::ThreadWP>
227 m_threads; // threads currently executing this queue's items
228 bool
229 m_thread_list_fetched; // have we tried to fetch the threads list already?
230 std::vector<lldb::QueueItemSP> m_pending_items; // items currently enqueued
231 bool m_pending_items_fetched; // have we tried to fetch the item list already?
232};
Jason Molenda5e8dce42013-12-13 00:29:16 +0000233}
234
Kate Stoneb9c1b512016-09-06 20:57:50 +0000235SBQueue::SBQueue() : m_opaque_sp(new QueueImpl()) {}
236
237SBQueue::SBQueue(const QueueSP &queue_sp)
238 : m_opaque_sp(new QueueImpl(queue_sp)) {}
239
240SBQueue::SBQueue(const SBQueue &rhs) {
241 if (&rhs == this)
242 return;
243
244 m_opaque_sp = rhs.m_opaque_sp;
Jason Molenda5e8dce42013-12-13 00:29:16 +0000245}
246
Kate Stoneb9c1b512016-09-06 20:57:50 +0000247const lldb::SBQueue &SBQueue::operator=(const lldb::SBQueue &rhs) {
248 m_opaque_sp = rhs.m_opaque_sp;
249 return *this;
Jason Molenda5e8dce42013-12-13 00:29:16 +0000250}
251
Kate Stoneb9c1b512016-09-06 20:57:50 +0000252SBQueue::~SBQueue() {}
Jason Molenda5e8dce42013-12-13 00:29:16 +0000253
Kate Stoneb9c1b512016-09-06 20:57:50 +0000254bool SBQueue::IsValid() const {
255 bool is_valid = m_opaque_sp->IsValid();
256 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
257 if (log)
258 log->Printf("SBQueue(0x%" PRIx64 ")::IsValid() == %s",
259 m_opaque_sp->GetQueueID(), is_valid ? "true" : "false");
260 return is_valid;
Jason Molenda5e8dce42013-12-13 00:29:16 +0000261}
262
Kate Stoneb9c1b512016-09-06 20:57:50 +0000263void SBQueue::Clear() {
264 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
265 if (log)
266 log->Printf("SBQueue(0x%" PRIx64 ")::Clear()", m_opaque_sp->GetQueueID());
267 m_opaque_sp->Clear();
Jason Molenda5e8dce42013-12-13 00:29:16 +0000268}
269
Kate Stoneb9c1b512016-09-06 20:57:50 +0000270void SBQueue::SetQueue(const QueueSP &queue_sp) {
271 m_opaque_sp->SetQueue(queue_sp);
Jason Molendafe95dc92014-03-09 19:41:30 +0000272}
273
Kate Stoneb9c1b512016-09-06 20:57:50 +0000274lldb::queue_id_t SBQueue::GetQueueID() const {
275 lldb::queue_id_t qid = m_opaque_sp->GetQueueID();
276 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
277 if (log)
278 log->Printf("SBQueue(0x%" PRIx64 ")::GetQueueID() == 0x%" PRIx64,
279 m_opaque_sp->GetQueueID(), (uint64_t)qid);
280 return qid;
Jason Molenda5e8dce42013-12-13 00:29:16 +0000281}
Jason Molendaaac16e02014-03-13 02:54:54 +0000282
Kate Stoneb9c1b512016-09-06 20:57:50 +0000283uint32_t SBQueue::GetIndexID() const {
284 uint32_t index_id = m_opaque_sp->GetIndexID();
285 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
286 if (log)
287 log->Printf("SBQueue(0x%" PRIx64 ")::GetIndexID() == 0x%" PRIx32,
288 m_opaque_sp->GetQueueID(), index_id);
289 return index_id;
Jason Molendaaac16e02014-03-13 02:54:54 +0000290}
Kate Stoneb9c1b512016-09-06 20:57:50 +0000291
292const char *SBQueue::GetName() const {
293 const char *name = m_opaque_sp->GetName();
294 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
295 if (log)
296 log->Printf("SBQueue(0x%" PRIx64 ")::GetName() == %s",
297 m_opaque_sp->GetQueueID(), name ? name : "");
298 return name;
299}
300
301uint32_t SBQueue::GetNumThreads() {
302 uint32_t numthreads = m_opaque_sp->GetNumThreads();
303 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
304 if (log)
305 log->Printf("SBQueue(0x%" PRIx64 ")::GetNumThreads() == %d",
306 m_opaque_sp->GetQueueID(), numthreads);
307 return numthreads;
308}
309
310SBThread SBQueue::GetThreadAtIndex(uint32_t idx) {
311 SBThread th = m_opaque_sp->GetThreadAtIndex(idx);
312 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
313 if (log)
314 log->Printf("SBQueue(0x%" PRIx64 ")::GetThreadAtIndex(%d)",
315 m_opaque_sp->GetQueueID(), idx);
316 return th;
317}
318
319uint32_t SBQueue::GetNumPendingItems() {
320 uint32_t pending_items = m_opaque_sp->GetNumPendingItems();
321 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
322 if (log)
323 log->Printf("SBQueue(0x%" PRIx64 ")::GetNumPendingItems() == %d",
324 m_opaque_sp->GetQueueID(), pending_items);
325 return pending_items;
326}
327
328SBQueueItem SBQueue::GetPendingItemAtIndex(uint32_t idx) {
329 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
330 if (log)
331 log->Printf("SBQueue(0x%" PRIx64 ")::GetPendingItemAtIndex(%d)",
332 m_opaque_sp->GetQueueID(), idx);
333 return m_opaque_sp->GetPendingItemAtIndex(idx);
334}
335
336uint32_t SBQueue::GetNumRunningItems() {
337 uint32_t running_items = m_opaque_sp->GetNumRunningItems();
338 Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
339 if (log)
340 log->Printf("SBQueue(0x%" PRIx64 ")::GetNumRunningItems() == %d",
341 m_opaque_sp->GetQueueID(), running_items);
342 return running_items;
343}
344
345SBProcess SBQueue::GetProcess() { return m_opaque_sp->GetProcess(); }
346
347lldb::QueueKind SBQueue::GetKind() { return m_opaque_sp->GetKind(); }