blob: 569e6fe2c4f285bc35ce5f3f83d00fe6650e62c2 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- SBTarget.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
Eli Friedman7a62c8b2010-06-09 07:44:37 +000010#include "lldb/API/SBTarget.h"
Chris Lattner24943d22010-06-08 16:52:24 +000011
Greg Claytonb3448432011-03-24 21:19:54 +000012#include "lldb/lldb-public.h"
Chris Lattner24943d22010-06-08 16:52:24 +000013
Greg Clayton917c0002011-06-29 22:09:02 +000014#include "lldb/API/SBDebugger.h"
15#include "lldb/API/SBBreakpoint.h"
Chris Lattner24943d22010-06-08 16:52:24 +000016#include "lldb/API/SBFileSpec.h"
Greg Clayton917c0002011-06-29 22:09:02 +000017#include "lldb/API/SBListener.h"
Chris Lattner24943d22010-06-08 16:52:24 +000018#include "lldb/API/SBModule.h"
Jim Inghamcc637462011-09-13 00:29:56 +000019#include "lldb/API/SBSourceManager.h"
Greg Clayton917c0002011-06-29 22:09:02 +000020#include "lldb/API/SBProcess.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000021#include "lldb/API/SBStream.h"
Greg Clayton4ed315f2011-06-21 01:34:41 +000022#include "lldb/API/SBSymbolContextList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000023#include "lldb/Breakpoint/BreakpointID.h"
24#include "lldb/Breakpoint/BreakpointIDList.h"
25#include "lldb/Breakpoint/BreakpointList.h"
26#include "lldb/Breakpoint/BreakpointLocation.h"
27#include "lldb/Core/Address.h"
28#include "lldb/Core/AddressResolver.h"
29#include "lldb/Core/AddressResolverName.h"
Chris Lattner24943d22010-06-08 16:52:24 +000030#include "lldb/Core/ArchSpec.h"
31#include "lldb/Core/Debugger.h"
32#include "lldb/Core/Disassembler.h"
Caroline Tice7826c882010-10-26 03:11:13 +000033#include "lldb/Core/Log.h"
Greg Clayton49ce8962012-08-29 21:13:06 +000034#include "lldb/Core/Module.h"
35#include "lldb/Core/ModuleSpec.h"
Chris Lattner24943d22010-06-08 16:52:24 +000036#include "lldb/Core/RegularExpression.h"
37#include "lldb/Core/SearchFilter.h"
Greg Clayton49ce8962012-08-29 21:13:06 +000038#include "lldb/Core/Section.h"
Chris Lattner24943d22010-06-08 16:52:24 +000039#include "lldb/Core/STLUtils.h"
Greg Clayton917c0002011-06-29 22:09:02 +000040#include "lldb/Core/ValueObjectList.h"
41#include "lldb/Core/ValueObjectVariable.h"
42#include "lldb/Host/FileSpec.h"
Greg Claytoncd548032011-02-01 01:31:41 +000043#include "lldb/Host/Host.h"
Greg Clayton917c0002011-06-29 22:09:02 +000044#include "lldb/Interpreter/Args.h"
Greg Clayton49ce8962012-08-29 21:13:06 +000045#include "lldb/Symbol/ObjectFile.h"
Enrico Granata979e20d2011-07-29 19:53:35 +000046#include "lldb/Symbol/SymbolVendor.h"
Greg Clayton917c0002011-06-29 22:09:02 +000047#include "lldb/Symbol/VariableList.h"
Jim Ingham4722b102012-03-06 00:37:27 +000048#include "lldb/Target/LanguageRuntime.h"
Chris Lattner24943d22010-06-08 16:52:24 +000049#include "lldb/Target/Process.h"
50#include "lldb/Target/Target.h"
51#include "lldb/Target/TargetList.h"
52
53#include "lldb/Interpreter/CommandReturnObject.h"
54#include "../source/Commands/CommandObjectBreakpoint.h"
55
Chris Lattner24943d22010-06-08 16:52:24 +000056
57using namespace lldb;
58using namespace lldb_private;
59
60#define DEFAULT_DISASM_BYTE_SIZE 32
61
Greg Clayton98ca1e62012-02-24 20:59:25 +000062SBLaunchInfo::SBLaunchInfo (const char **argv) :
63 m_opaque_sp(new ProcessLaunchInfo())
Greg Clayton0a8dcac2012-02-24 05:03:03 +000064{
Greg Clayton98ca1e62012-02-24 20:59:25 +000065 m_opaque_sp->GetFlags().Reset (eLaunchFlagDebug | eLaunchFlagDisableASLR);
66 if (argv && argv[0])
67 m_opaque_sp->GetArguments().SetArguments(argv);
Greg Clayton0a8dcac2012-02-24 05:03:03 +000068}
69
Greg Clayton66c2e192012-03-07 23:52:51 +000070SBLaunchInfo::~SBLaunchInfo()
71{
72}
73
74lldb_private::ProcessLaunchInfo &
75SBLaunchInfo::ref ()
76{
77 return *m_opaque_sp;
78}
79
80
Greg Clayton0a8dcac2012-02-24 05:03:03 +000081uint32_t
82SBLaunchInfo::GetUserID()
83{
84 return m_opaque_sp->GetUserID();
85}
86
87uint32_t
88SBLaunchInfo::GetGroupID()
89{
90 return m_opaque_sp->GetGroupID();
91}
92
93bool
94SBLaunchInfo::UserIDIsValid ()
95{
96 return m_opaque_sp->UserIDIsValid();
97}
98
99bool
100SBLaunchInfo::GroupIDIsValid ()
101{
102 return m_opaque_sp->GroupIDIsValid();
103}
104
105void
106SBLaunchInfo::SetUserID (uint32_t uid)
107{
108 m_opaque_sp->SetUserID (uid);
109}
110
111void
112SBLaunchInfo::SetGroupID (uint32_t gid)
113{
114 m_opaque_sp->SetGroupID (gid);
115}
116
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000117uint32_t
118SBLaunchInfo::GetNumArguments ()
119{
120 return m_opaque_sp->GetArguments().GetArgumentCount();
121}
122
123const char *
124SBLaunchInfo::GetArgumentAtIndex (uint32_t idx)
125{
126 return m_opaque_sp->GetArguments().GetArgumentAtIndex(idx);
127}
128
129void
130SBLaunchInfo::SetArguments (const char **argv, bool append)
131{
132 if (append)
133 {
134 if (argv)
135 m_opaque_sp->GetArguments().AppendArguments(argv);
136 }
137 else
138 {
139 if (argv)
140 m_opaque_sp->GetArguments().SetArguments(argv);
141 else
142 m_opaque_sp->GetArguments().Clear();
143 }
144}
145
146uint32_t
147SBLaunchInfo::GetNumEnvironmentEntries ()
148{
149 return m_opaque_sp->GetEnvironmentEntries().GetArgumentCount();
150}
151
152const char *
153SBLaunchInfo::GetEnvironmentEntryAtIndex (uint32_t idx)
154{
155 return m_opaque_sp->GetEnvironmentEntries().GetArgumentAtIndex(idx);
156}
157
158void
159SBLaunchInfo::SetEnvironmentEntries (const char **envp, bool append)
160{
161 if (append)
162 {
163 if (envp)
164 m_opaque_sp->GetEnvironmentEntries().AppendArguments(envp);
165 }
166 else
167 {
168 if (envp)
169 m_opaque_sp->GetEnvironmentEntries().SetArguments(envp);
170 else
171 m_opaque_sp->GetEnvironmentEntries().Clear();
172 }
173}
174
175void
176SBLaunchInfo::Clear ()
177{
178 m_opaque_sp->Clear();
179}
180
181const char *
182SBLaunchInfo::GetWorkingDirectory () const
183{
184 return m_opaque_sp->GetWorkingDirectory();
185}
186
187void
188SBLaunchInfo::SetWorkingDirectory (const char *working_dir)
189{
190 m_opaque_sp->SetWorkingDirectory(working_dir);
191}
192
193uint32_t
194SBLaunchInfo::GetLaunchFlags ()
195{
196 return m_opaque_sp->GetFlags().Get();
197}
198
199void
200SBLaunchInfo::SetLaunchFlags (uint32_t flags)
201{
202 m_opaque_sp->GetFlags().Reset(flags);
203}
204
205const char *
206SBLaunchInfo::GetProcessPluginName ()
207{
208 return m_opaque_sp->GetProcessPluginName();
209}
210
211void
212SBLaunchInfo::SetProcessPluginName (const char *plugin_name)
213{
214 return m_opaque_sp->SetProcessPluginName (plugin_name);
215}
216
217const char *
218SBLaunchInfo::GetShell ()
219{
220 return m_opaque_sp->GetShell();
221}
222
223void
224SBLaunchInfo::SetShell (const char * path)
225{
226 m_opaque_sp->SetShell (path);
227}
228
229uint32_t
230SBLaunchInfo::GetResumeCount ()
231{
232 return m_opaque_sp->GetResumeCount();
233}
234
235void
236SBLaunchInfo::SetResumeCount (uint32_t c)
237{
238 m_opaque_sp->SetResumeCount (c);
239}
240
241bool
242SBLaunchInfo::AddCloseFileAction (int fd)
243{
244 return m_opaque_sp->AppendCloseFileAction(fd);
245}
246
247bool
248SBLaunchInfo::AddDuplicateFileAction (int fd, int dup_fd)
249{
250 return m_opaque_sp->AppendDuplicateFileAction(fd, dup_fd);
251}
252
253bool
254SBLaunchInfo::AddOpenFileAction (int fd, const char *path, bool read, bool write)
255{
256 return m_opaque_sp->AppendOpenFileAction(fd, path, read, write);
257}
258
259bool
260SBLaunchInfo::AddSuppressFileAction (int fd, bool read, bool write)
261{
262 return m_opaque_sp->AppendSuppressFileAction(fd, read, write);
263}
264
265
266SBAttachInfo::SBAttachInfo () :
Greg Clayton66c2e192012-03-07 23:52:51 +0000267 m_opaque_sp (new ProcessAttachInfo())
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000268{
269}
270
271SBAttachInfo::SBAttachInfo (lldb::pid_t pid) :
Greg Clayton66c2e192012-03-07 23:52:51 +0000272 m_opaque_sp (new ProcessAttachInfo())
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000273{
274 m_opaque_sp->SetProcessID (pid);
275}
276
277SBAttachInfo::SBAttachInfo (const char *path, bool wait_for) :
Greg Clayton66c2e192012-03-07 23:52:51 +0000278 m_opaque_sp (new ProcessAttachInfo())
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000279{
280 if (path && path[0])
281 m_opaque_sp->GetExecutableFile().SetFile(path, false);
282 m_opaque_sp->SetWaitForLaunch (wait_for);
283}
284
285SBAttachInfo::SBAttachInfo (const SBAttachInfo &rhs) :
Greg Clayton66c2e192012-03-07 23:52:51 +0000286 m_opaque_sp (new ProcessAttachInfo())
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000287{
288 *m_opaque_sp = *rhs.m_opaque_sp;
289}
290
Greg Clayton66c2e192012-03-07 23:52:51 +0000291SBAttachInfo::~SBAttachInfo()
292{
293}
294
295lldb_private::ProcessAttachInfo &
296SBAttachInfo::ref ()
297{
298 return *m_opaque_sp;
299}
300
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000301SBAttachInfo &
302SBAttachInfo::operator = (const SBAttachInfo &rhs)
303{
304 if (this != &rhs)
305 *m_opaque_sp = *rhs.m_opaque_sp;
306 return *this;
307}
308
309lldb::pid_t
310SBAttachInfo::GetProcessID ()
311{
312 return m_opaque_sp->GetProcessID();
313}
314
315void
316SBAttachInfo::SetProcessID (lldb::pid_t pid)
317{
318 m_opaque_sp->SetProcessID (pid);
319}
320
321
322uint32_t
323SBAttachInfo::GetResumeCount ()
324{
325 return m_opaque_sp->GetResumeCount();
326}
327
328void
329SBAttachInfo::SetResumeCount (uint32_t c)
330{
331 m_opaque_sp->SetResumeCount (c);
332}
333
334const char *
335SBAttachInfo::GetProcessPluginName ()
336{
337 return m_opaque_sp->GetProcessPluginName();
338}
339
340void
341SBAttachInfo::SetProcessPluginName (const char *plugin_name)
342{
343 return m_opaque_sp->SetProcessPluginName (plugin_name);
344}
345
346void
347SBAttachInfo::SetExecutable (const char *path)
348{
349 if (path && path[0])
350 m_opaque_sp->GetExecutableFile().SetFile(path, false);
351 else
352 m_opaque_sp->GetExecutableFile().Clear();
353}
354
355void
356SBAttachInfo::SetExecutable (SBFileSpec exe_file)
357{
358 if (exe_file.IsValid())
359 m_opaque_sp->GetExecutableFile() = exe_file.ref();
360 else
361 m_opaque_sp->GetExecutableFile().Clear();
362}
363
364bool
365SBAttachInfo::GetWaitForLaunch ()
366{
367 return m_opaque_sp->GetWaitForLaunch();
368}
369
370void
371SBAttachInfo::SetWaitForLaunch (bool b)
372{
373 m_opaque_sp->SetWaitForLaunch (b);
374}
375
Jim Ingham3a458eb2012-07-20 21:37:13 +0000376bool
377SBAttachInfo::GetIgnoreExisting ()
378{
379 return m_opaque_sp->GetIgnoreExisting();
380}
381
382void
383SBAttachInfo::SetIgnoreExisting (bool b)
384{
385 m_opaque_sp->SetIgnoreExisting (b);
386}
387
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000388uint32_t
Greg Clayton80efa5e2012-02-24 23:56:06 +0000389SBAttachInfo::GetUserID()
390{
391 return m_opaque_sp->GetUserID();
392}
393
394uint32_t
395SBAttachInfo::GetGroupID()
396{
397 return m_opaque_sp->GetGroupID();
398}
399
400bool
401SBAttachInfo::UserIDIsValid ()
402{
403 return m_opaque_sp->UserIDIsValid();
404}
405
406bool
407SBAttachInfo::GroupIDIsValid ()
408{
409 return m_opaque_sp->GroupIDIsValid();
410}
411
412void
413SBAttachInfo::SetUserID (uint32_t uid)
414{
415 m_opaque_sp->SetUserID (uid);
416}
417
418void
419SBAttachInfo::SetGroupID (uint32_t gid)
420{
421 m_opaque_sp->SetGroupID (gid);
422}
423
424uint32_t
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000425SBAttachInfo::GetEffectiveUserID()
426{
427 return m_opaque_sp->GetEffectiveUserID();
428}
429
430uint32_t
431SBAttachInfo::GetEffectiveGroupID()
432{
433 return m_opaque_sp->GetEffectiveGroupID();
434}
435
436bool
437SBAttachInfo::EffectiveUserIDIsValid ()
438{
439 return m_opaque_sp->EffectiveUserIDIsValid();
440}
441
442bool
443SBAttachInfo::EffectiveGroupIDIsValid ()
444{
445 return m_opaque_sp->EffectiveGroupIDIsValid ();
446}
447
448void
449SBAttachInfo::SetEffectiveUserID (uint32_t uid)
450{
451 m_opaque_sp->SetEffectiveUserID(uid);
452}
453
454void
455SBAttachInfo::SetEffectiveGroupID (uint32_t gid)
456{
457 m_opaque_sp->SetEffectiveGroupID(gid);
458}
459
460lldb::pid_t
461SBAttachInfo::GetParentProcessID ()
462{
463 return m_opaque_sp->GetParentProcessID();
464}
465
466void
467SBAttachInfo::SetParentProcessID (lldb::pid_t pid)
468{
469 m_opaque_sp->SetParentProcessID (pid);
470}
471
472bool
473SBAttachInfo::ParentProcessIDIsValid()
474{
475 return m_opaque_sp->ParentProcessIDIsValid();
476}
477
478
Chris Lattner24943d22010-06-08 16:52:24 +0000479//----------------------------------------------------------------------
480// SBTarget constructor
481//----------------------------------------------------------------------
Greg Claytonc3b61d22010-12-15 05:08:08 +0000482SBTarget::SBTarget () :
483 m_opaque_sp ()
Chris Lattner24943d22010-06-08 16:52:24 +0000484{
485}
486
487SBTarget::SBTarget (const SBTarget& rhs) :
Greg Clayton63094e02010-06-23 01:19:29 +0000488 m_opaque_sp (rhs.m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000489{
490}
491
492SBTarget::SBTarget(const TargetSP& target_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +0000493 m_opaque_sp (target_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000494{
495}
496
Greg Clayton538eb822010-11-05 23:17:00 +0000497const SBTarget&
498SBTarget::operator = (const SBTarget& rhs)
499{
500 if (this != &rhs)
501 m_opaque_sp = rhs.m_opaque_sp;
502 return *this;
503}
504
Chris Lattner24943d22010-06-08 16:52:24 +0000505//----------------------------------------------------------------------
506// Destructor
507//----------------------------------------------------------------------
508SBTarget::~SBTarget()
509{
510}
511
Jim Ingham5a15e692012-02-16 06:50:00 +0000512const char *
513SBTarget::GetBroadcasterClassName ()
514{
515 return Target::GetStaticBroadcasterClass().AsCString();
516}
517
Chris Lattner24943d22010-06-08 16:52:24 +0000518bool
519SBTarget::IsValid () const
520{
Filipe Cabecinhasf7d782b2012-05-19 09:59:08 +0000521 return m_opaque_sp.get() != NULL && m_opaque_sp->IsValid();
Chris Lattner24943d22010-06-08 16:52:24 +0000522}
523
524SBProcess
525SBTarget::GetProcess ()
526{
527 SBProcess sb_process;
Greg Clayton334d33a2012-01-30 07:41:31 +0000528 ProcessSP process_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000529 TargetSP target_sp(GetSP());
530 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000531 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000532 process_sp = target_sp->GetProcessSP();
Greg Clayton334d33a2012-01-30 07:41:31 +0000533 sb_process.SetSP (process_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000534 }
Caroline Tice7826c882010-10-26 03:11:13 +0000535
Greg Claytone005f2c2010-11-06 01:53:30 +0000536 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000537 if (log)
538 {
Greg Clayton49ce6822010-10-31 03:01:06 +0000539 log->Printf ("SBTarget(%p)::GetProcess () => SBProcess(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000540 target_sp.get(), process_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000541 }
542
Chris Lattner24943d22010-06-08 16:52:24 +0000543 return sb_process;
544}
545
Greg Clayton63094e02010-06-23 01:19:29 +0000546SBDebugger
547SBTarget::GetDebugger () const
548{
549 SBDebugger debugger;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000550 TargetSP target_sp(GetSP());
551 if (target_sp)
552 debugger.reset (target_sp->GetDebugger().shared_from_this());
Greg Clayton63094e02010-06-23 01:19:29 +0000553 return debugger;
554}
555
Jim Inghamb5871fe2011-03-31 00:01:24 +0000556SBProcess
557SBTarget::LaunchSimple
558(
559 char const **argv,
560 char const **envp,
561 const char *working_directory
562)
563{
564 char *stdin_path = NULL;
565 char *stdout_path = NULL;
566 char *stderr_path = NULL;
567 uint32_t launch_flags = 0;
568 bool stop_at_entry = false;
569 SBError error;
570 SBListener listener = GetDebugger().GetListener();
571 return Launch (listener,
572 argv,
573 envp,
574 stdin_path,
575 stdout_path,
576 stderr_path,
577 working_directory,
578 launch_flags,
579 stop_at_entry,
580 error);
581}
Greg Claytonde915be2011-01-23 05:56:20 +0000582
583SBProcess
584SBTarget::Launch
585(
Greg Clayton271a5db2011-02-03 21:28:34 +0000586 SBListener &listener,
Greg Claytonde915be2011-01-23 05:56:20 +0000587 char const **argv,
588 char const **envp,
589 const char *stdin_path,
590 const char *stdout_path,
591 const char *stderr_path,
592 const char *working_directory,
593 uint32_t launch_flags, // See LaunchFlags
594 bool stop_at_entry,
595 lldb::SBError& error
596)
597{
Greg Claytone005f2c2010-11-06 01:53:30 +0000598 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000599
Greg Clayton0416bdf2012-01-30 09:04:36 +0000600 SBProcess sb_process;
601 ProcessSP process_sp;
602 TargetSP target_sp(GetSP());
603
Caroline Tice7826c882010-10-26 03:11:13 +0000604 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000605 {
Greg Claytonde915be2011-01-23 05:56:20 +0000606 log->Printf ("SBTarget(%p)::Launch (argv=%p, envp=%p, stdin=%s, stdout=%s, stderr=%s, working-dir=%s, launch_flags=0x%x, stop_at_entry=%i, &error (%p))...",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000607 target_sp.get(),
Greg Claytonde915be2011-01-23 05:56:20 +0000608 argv,
609 envp,
610 stdin_path ? stdin_path : "NULL",
611 stdout_path ? stdout_path : "NULL",
612 stderr_path ? stderr_path : "NULL",
613 working_directory ? working_directory : "NULL",
614 launch_flags,
615 stop_at_entry,
616 error.get());
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000617 }
Greg Clayton0416bdf2012-01-30 09:04:36 +0000618
619 if (target_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000620 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000621 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Greg Clayton1a3083a2010-10-06 03:53:16 +0000622
Greg Clayton7c330d62011-01-27 01:01:10 +0000623 if (getenv("LLDB_LAUNCH_FLAG_DISABLE_ASLR"))
624 launch_flags |= eLaunchFlagDisableASLR;
625
Greg Clayton180546b2011-04-30 01:09:13 +0000626 StateType state = eStateInvalid;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000627 process_sp = target_sp->GetProcessSP();
Greg Clayton334d33a2012-01-30 07:41:31 +0000628 if (process_sp)
Greg Clayton28d5fcc2011-01-27 06:44:37 +0000629 {
Greg Clayton334d33a2012-01-30 07:41:31 +0000630 state = process_sp->GetState();
Greg Clayton180546b2011-04-30 01:09:13 +0000631
Greg Clayton334d33a2012-01-30 07:41:31 +0000632 if (process_sp->IsAlive() && state != eStateConnected)
Greg Clayton180546b2011-04-30 01:09:13 +0000633 {
634 if (state == eStateAttaching)
635 error.SetErrorString ("process attach is in progress");
636 else
637 error.SetErrorString ("a process is already being debugged");
Greg Clayton180546b2011-04-30 01:09:13 +0000638 return sb_process;
639 }
Greg Clayton28d5fcc2011-01-27 06:44:37 +0000640 }
641
Greg Clayton180546b2011-04-30 01:09:13 +0000642 if (state == eStateConnected)
643 {
644 // If we are already connected, then we have already specified the
645 // listener, so if a valid listener is supplied, we need to error out
646 // to let the client know.
647 if (listener.IsValid())
648 {
649 error.SetErrorString ("process is connected and already has a listener, pass empty listener");
Greg Clayton180546b2011-04-30 01:09:13 +0000650 return sb_process;
651 }
652 }
653 else
Greg Claytonc5f728c2010-10-06 22:10:17 +0000654 {
Greg Clayton271a5db2011-02-03 21:28:34 +0000655 if (listener.IsValid())
Greg Clayton46c9a352012-02-09 06:16:32 +0000656 process_sp = target_sp->CreateProcess (listener.ref(), NULL, NULL);
Greg Clayton271a5db2011-02-03 21:28:34 +0000657 else
Greg Clayton46c9a352012-02-09 06:16:32 +0000658 process_sp = target_sp->CreateProcess (target_sp->GetDebugger().GetListener(), NULL, NULL);
Greg Clayton180546b2011-04-30 01:09:13 +0000659 }
Greg Clayton7c330d62011-01-27 01:01:10 +0000660
Greg Clayton334d33a2012-01-30 07:41:31 +0000661 if (process_sp)
Greg Clayton180546b2011-04-30 01:09:13 +0000662 {
Greg Clayton334d33a2012-01-30 07:41:31 +0000663 sb_process.SetSP (process_sp);
Greg Clayton180546b2011-04-30 01:09:13 +0000664 if (getenv("LLDB_LAUNCH_FLAG_DISABLE_STDIO"))
665 launch_flags |= eLaunchFlagDisableSTDIO;
666
Greg Clayton36bc5ea2011-11-03 21:22:33 +0000667 ProcessLaunchInfo launch_info (stdin_path, stdout_path, stderr_path, working_directory, launch_flags);
668
Greg Clayton0416bdf2012-01-30 09:04:36 +0000669 Module *exe_module = target_sp->GetExecutableModulePointer();
Greg Clayton36bc5ea2011-11-03 21:22:33 +0000670 if (exe_module)
Greg Clayton1d1f39e2011-11-29 04:03:30 +0000671 launch_info.SetExecutableFile(exe_module->GetPlatformFileSpec(), true);
Greg Clayton36bc5ea2011-11-03 21:22:33 +0000672 if (argv)
673 launch_info.GetArguments().AppendArguments (argv);
674 if (envp)
675 launch_info.GetEnvironmentEntries ().SetArguments (envp);
676
Greg Clayton334d33a2012-01-30 07:41:31 +0000677 error.SetError (process_sp->Launch (launch_info));
Greg Clayton180546b2011-04-30 01:09:13 +0000678 if (error.Success())
Greg Clayton7c330d62011-01-27 01:01:10 +0000679 {
Greg Clayton180546b2011-04-30 01:09:13 +0000680 // We we are stopping at the entry point, we can return now!
681 if (stop_at_entry)
682 return sb_process;
Greg Clayton7c330d62011-01-27 01:01:10 +0000683
Greg Clayton180546b2011-04-30 01:09:13 +0000684 // Make sure we are stopped at the entry
Greg Clayton334d33a2012-01-30 07:41:31 +0000685 StateType state = process_sp->WaitForProcessToStop (NULL);
Greg Clayton180546b2011-04-30 01:09:13 +0000686 if (state == eStateStopped)
Greg Clayton7c330d62011-01-27 01:01:10 +0000687 {
Greg Clayton180546b2011-04-30 01:09:13 +0000688 // resume the process to skip the entry point
Greg Clayton334d33a2012-01-30 07:41:31 +0000689 error.SetError (process_sp->Resume());
Greg Clayton180546b2011-04-30 01:09:13 +0000690 if (error.Success())
Greg Clayton7c330d62011-01-27 01:01:10 +0000691 {
Greg Clayton180546b2011-04-30 01:09:13 +0000692 // If we are doing synchronous mode, then wait for the
693 // process to stop yet again!
Greg Clayton0416bdf2012-01-30 09:04:36 +0000694 if (target_sp->GetDebugger().GetAsyncExecution () == false)
Greg Clayton334d33a2012-01-30 07:41:31 +0000695 process_sp->WaitForProcessToStop (NULL);
Greg Clayton7c330d62011-01-27 01:01:10 +0000696 }
697 }
698 }
Greg Clayton180546b2011-04-30 01:09:13 +0000699 }
700 else
701 {
702 error.SetErrorString ("unable to create lldb_private::Process");
Greg Claytonc5f728c2010-10-06 22:10:17 +0000703 }
704 }
705 else
706 {
707 error.SetErrorString ("SBTarget is invalid");
Chris Lattner24943d22010-06-08 16:52:24 +0000708 }
Caroline Tice7826c882010-10-26 03:11:13 +0000709
Caroline Tice926060e2010-10-29 21:48:37 +0000710 log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000711 if (log)
712 {
Sean Callanan4e846742012-10-20 00:21:31 +0000713 log->Printf ("SBTarget(%p)::Launch (...) => SBProcess(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000714 target_sp.get(), process_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000715 }
716
Greg Clayton1a3083a2010-10-06 03:53:16 +0000717 return sb_process;
Chris Lattner24943d22010-06-08 16:52:24 +0000718}
719
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000720SBProcess
721SBTarget::Launch (SBLaunchInfo &sb_launch_info, SBError& error)
722{
723 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
724
725 SBProcess sb_process;
726 ProcessSP process_sp;
727 TargetSP target_sp(GetSP());
728
729 if (log)
730 {
731 log->Printf ("SBTarget(%p)::Launch (launch_info, error)...", target_sp.get());
732 }
733
734 if (target_sp)
735 {
736 Mutex::Locker api_locker (target_sp->GetAPIMutex());
737 StateType state = eStateInvalid;
738 process_sp = target_sp->GetProcessSP();
739 if (process_sp)
740 {
741 state = process_sp->GetState();
742
743 if (process_sp->IsAlive() && state != eStateConnected)
744 {
745 if (state == eStateAttaching)
746 error.SetErrorString ("process attach is in progress");
747 else
748 error.SetErrorString ("a process is already being debugged");
749 return sb_process;
750 }
751 }
752
753 if (state != eStateConnected)
754 process_sp = target_sp->CreateProcess (target_sp->GetDebugger().GetListener(), NULL, NULL);
755
756 if (process_sp)
757 {
758 sb_process.SetSP (process_sp);
759 lldb_private::ProcessLaunchInfo &launch_info = sb_launch_info.ref();
Greg Clayton98ca1e62012-02-24 20:59:25 +0000760
Greg Clayton98ca1e62012-02-24 20:59:25 +0000761 Module *exe_module = target_sp->GetExecutableModulePointer();
762 if (exe_module)
Han Ming Ongc86723f2012-03-02 01:02:04 +0000763 launch_info.SetExecutableFile(exe_module->GetPlatformFileSpec(), true);
Greg Clayton98ca1e62012-02-24 20:59:25 +0000764
765 const ArchSpec &arch_spec = target_sp->GetArchitecture();
766 if (arch_spec.IsValid())
767 launch_info.GetArchitecture () = arch_spec;
768
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000769 error.SetError (process_sp->Launch (launch_info));
Greg Clayton98ca1e62012-02-24 20:59:25 +0000770 const bool synchronous_execution = target_sp->GetDebugger().GetAsyncExecution () == false;
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000771 if (error.Success())
772 {
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000773 if (launch_info.GetFlags().Test(eLaunchFlagStopAtEntry))
Greg Clayton98ca1e62012-02-24 20:59:25 +0000774 {
775 // If we are doing synchronous mode, then wait for the initial
776 // stop to happen, else, return and let the caller watch for
777 // the stop
778 if (synchronous_execution)
Greg Clayton4a379b12012-07-17 03:23:13 +0000779 process_sp->WaitForProcessToStop (NULL);
Greg Clayton98ca1e62012-02-24 20:59:25 +0000780 // We we are stopping at the entry point, we can return now!
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000781 return sb_process;
Greg Clayton98ca1e62012-02-24 20:59:25 +0000782 }
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000783
784 // Make sure we are stopped at the entry
Greg Clayton4a379b12012-07-17 03:23:13 +0000785 StateType state = process_sp->WaitForProcessToStop (NULL);
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000786 if (state == eStateStopped)
787 {
788 // resume the process to skip the entry point
789 error.SetError (process_sp->Resume());
790 if (error.Success())
791 {
792 // If we are doing synchronous mode, then wait for the
793 // process to stop yet again!
Greg Clayton98ca1e62012-02-24 20:59:25 +0000794 if (synchronous_execution)
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000795 process_sp->WaitForProcessToStop (NULL);
796 }
797 }
798 }
799 }
800 else
801 {
802 error.SetErrorString ("unable to create lldb_private::Process");
803 }
804 }
805 else
806 {
807 error.SetErrorString ("SBTarget is invalid");
808 }
809
810 log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
811 if (log)
812 {
Sean Callanan4e846742012-10-20 00:21:31 +0000813 log->Printf ("SBTarget(%p)::Launch (...) => SBProcess(%p)",
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000814 target_sp.get(), process_sp.get());
815 }
816
817 return sb_process;
818}
819
820lldb::SBProcess
821SBTarget::Attach (SBAttachInfo &sb_attach_info, SBError& error)
822{
Sean Callanan4e846742012-10-20 00:21:31 +0000823 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
824
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000825 SBProcess sb_process;
826 ProcessSP process_sp;
827 TargetSP target_sp(GetSP());
Sean Callanan4e846742012-10-20 00:21:31 +0000828
829 if (log)
830 {
831 log->Printf ("SBTarget(%p)::Attach (sb_attach_info, error)...", target_sp.get());
832 }
833
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000834 if (target_sp)
835 {
836 Mutex::Locker api_locker (target_sp->GetAPIMutex());
837
838 StateType state = eStateInvalid;
839 process_sp = target_sp->GetProcessSP();
840 if (process_sp)
841 {
842 state = process_sp->GetState();
843
844 if (process_sp->IsAlive() && state != eStateConnected)
845 {
846 if (state == eStateAttaching)
847 error.SetErrorString ("process attach is in progress");
848 else
849 error.SetErrorString ("a process is already being debugged");
Sean Callanan4e846742012-10-20 00:21:31 +0000850 if (log)
851 {
852 log->Printf ("SBTarget(%p)::Attach (...) => error %s",
853 target_sp.get(), error.GetCString());
854 }
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000855 return sb_process;
856 }
857 }
858
859 if (state != eStateConnected)
860 process_sp = target_sp->CreateProcess (target_sp->GetDebugger().GetListener(), NULL, NULL);
861
862 if (process_sp)
863 {
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000864 ProcessAttachInfo &attach_info = sb_attach_info.ref();
Han Ming Ong435c5ef2012-02-29 00:12:56 +0000865 lldb::pid_t attach_pid = attach_info.GetProcessID();
866 if (attach_pid != LLDB_INVALID_PROCESS_ID)
867 {
868 PlatformSP platform_sp = target_sp->GetPlatform();
Greg Clayton02fac1c2012-09-27 00:03:39 +0000869 // See if we can pre-verify if a process exists or not
870 if (platform_sp && platform_sp->IsConnected())
Han Ming Ong435c5ef2012-02-29 00:12:56 +0000871 {
Greg Clayton02fac1c2012-09-27 00:03:39 +0000872 ProcessInstanceInfo instance_info;
873 if (platform_sp->GetProcessInfo(attach_pid, instance_info))
874 {
875 attach_info.SetUserID(instance_info.GetEffectiveUserID());
876 }
877 else
878 {
879 error.ref().SetErrorStringWithFormat("no process found with process ID %llu", attach_pid);
Sean Callanan4e846742012-10-20 00:21:31 +0000880 if (log)
881 {
882 log->Printf ("SBTarget(%p)::Attach (...) => error %s",
883 target_sp.get(), error.GetCString());
884 }
Greg Clayton02fac1c2012-09-27 00:03:39 +0000885 return sb_process;
886 }
Han Ming Ong435c5ef2012-02-29 00:12:56 +0000887 }
888 }
Han Ming Ong94b4e9a2012-02-29 19:16:40 +0000889 error.SetError (process_sp->Attach (attach_info));
890 if (error.Success())
891 {
892 sb_process.SetSP (process_sp);
893 // If we are doing synchronous mode, then wait for the
894 // process to stop!
895 if (target_sp->GetDebugger().GetAsyncExecution () == false)
896 process_sp->WaitForProcessToStop (NULL);
897 }
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000898 }
899 else
900 {
901 error.SetErrorString ("unable to create lldb_private::Process");
902 }
903 }
904 else
905 {
906 error.SetErrorString ("SBTarget is invalid");
907 }
Sean Callanan4e846742012-10-20 00:21:31 +0000908
909 if (log)
910 {
911 log->Printf ("SBTarget(%p)::Attach (...) => SBProcess(%p)",
912 target_sp.get(), process_sp.get());
913 }
914
Greg Clayton0a8dcac2012-02-24 05:03:03 +0000915 return sb_process;
916}
917
918
Greg Claytond5b0b442011-12-02 02:10:57 +0000919#if defined(__APPLE__)
920
921lldb::SBProcess
922SBTarget::AttachToProcessWithID (SBListener &listener,
923 ::pid_t pid,
924 lldb::SBError& error)
925{
926 return AttachToProcessWithID (listener, (lldb::pid_t)pid, error);
927}
928
929#endif // #if defined(__APPLE__)
Greg Claytonc5f728c2010-10-06 22:10:17 +0000930
931lldb::SBProcess
Greg Claytond8c62532010-10-07 04:19:01 +0000932SBTarget::AttachToProcessWithID
Greg Claytonc5f728c2010-10-06 22:10:17 +0000933(
Greg Clayton271a5db2011-02-03 21:28:34 +0000934 SBListener &listener,
Greg Claytonc5f728c2010-10-06 22:10:17 +0000935 lldb::pid_t pid,// The process ID to attach to
936 SBError& error // An error explaining what went wrong if attach fails
937)
938{
Sean Callanan4e846742012-10-20 00:21:31 +0000939 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
940
Greg Claytonc5f728c2010-10-06 22:10:17 +0000941 SBProcess sb_process;
Greg Clayton334d33a2012-01-30 07:41:31 +0000942 ProcessSP process_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000943 TargetSP target_sp(GetSP());
Sean Callanan4e846742012-10-20 00:21:31 +0000944
945 if (log)
946 {
947 log->Printf ("SBTarget(%p)::AttachToProcessWithID (listener, pid=%lld, error)...", target_sp.get(), pid);
948 }
949
Greg Clayton0416bdf2012-01-30 09:04:36 +0000950 if (target_sp)
Greg Claytonc5f728c2010-10-06 22:10:17 +0000951 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000952 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Greg Claytonde1dd812011-06-24 03:21:43 +0000953
954 StateType state = eStateInvalid;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000955 process_sp = target_sp->GetProcessSP();
Greg Clayton334d33a2012-01-30 07:41:31 +0000956 if (process_sp)
Greg Claytonde1dd812011-06-24 03:21:43 +0000957 {
Greg Clayton334d33a2012-01-30 07:41:31 +0000958 state = process_sp->GetState();
Greg Claytonde1dd812011-06-24 03:21:43 +0000959
Greg Clayton334d33a2012-01-30 07:41:31 +0000960 if (process_sp->IsAlive() && state != eStateConnected)
Greg Claytonde1dd812011-06-24 03:21:43 +0000961 {
962 if (state == eStateAttaching)
963 error.SetErrorString ("process attach is in progress");
964 else
965 error.SetErrorString ("a process is already being debugged");
Greg Claytonde1dd812011-06-24 03:21:43 +0000966 return sb_process;
967 }
968 }
969
970 if (state == eStateConnected)
971 {
972 // If we are already connected, then we have already specified the
973 // listener, so if a valid listener is supplied, we need to error out
974 // to let the client know.
975 if (listener.IsValid())
976 {
977 error.SetErrorString ("process is connected and already has a listener, pass empty listener");
Greg Claytonde1dd812011-06-24 03:21:43 +0000978 return sb_process;
979 }
980 }
Greg Clayton271a5db2011-02-03 21:28:34 +0000981 else
Greg Claytonde1dd812011-06-24 03:21:43 +0000982 {
983 if (listener.IsValid())
Greg Clayton46c9a352012-02-09 06:16:32 +0000984 process_sp = target_sp->CreateProcess (listener.ref(), NULL, NULL);
Greg Claytonde1dd812011-06-24 03:21:43 +0000985 else
Greg Clayton46c9a352012-02-09 06:16:32 +0000986 process_sp = target_sp->CreateProcess (target_sp->GetDebugger().GetListener(), NULL, NULL);
Greg Claytonde1dd812011-06-24 03:21:43 +0000987 }
Greg Clayton334d33a2012-01-30 07:41:31 +0000988 if (process_sp)
Greg Claytonc5f728c2010-10-06 22:10:17 +0000989 {
Greg Clayton334d33a2012-01-30 07:41:31 +0000990 sb_process.SetSP (process_sp);
991
Greg Clayton527154d2011-11-15 03:53:30 +0000992 ProcessAttachInfo attach_info;
993 attach_info.SetProcessID (pid);
Han Ming Ongd1040dd2012-02-25 01:07:38 +0000994
995 PlatformSP platform_sp = target_sp->GetPlatform();
996 ProcessInstanceInfo instance_info;
997 if (platform_sp->GetProcessInfo(pid, instance_info))
998 {
999 attach_info.SetUserID(instance_info.GetEffectiveUserID());
Han Ming Ongd1040dd2012-02-25 01:07:38 +00001000 }
Greg Clayton334d33a2012-01-30 07:41:31 +00001001 error.SetError (process_sp->Attach (attach_info));
Greg Claytonc6430772012-09-07 17:51:47 +00001002 if (error.Success())
1003 {
1004 // If we are doing synchronous mode, then wait for the
1005 // process to stop!
1006 if (target_sp->GetDebugger().GetAsyncExecution () == false)
Greg Clayton334d33a2012-01-30 07:41:31 +00001007 process_sp->WaitForProcessToStop (NULL);
Greg Claytonc6430772012-09-07 17:51:47 +00001008 }
Greg Claytonc5f728c2010-10-06 22:10:17 +00001009 }
1010 else
1011 {
1012 error.SetErrorString ("unable to create lldb_private::Process");
1013 }
1014 }
1015 else
1016 {
1017 error.SetErrorString ("SBTarget is invalid");
1018 }
Sean Callanan4e846742012-10-20 00:21:31 +00001019
1020 if (log)
1021 {
1022 log->Printf ("SBTarget(%p)::AttachToProcessWithID (...) => SBProcess(%p)",
1023 target_sp.get(), process_sp.get());
1024 }
Greg Claytonc5f728c2010-10-06 22:10:17 +00001025 return sb_process;
Greg Claytonc5f728c2010-10-06 22:10:17 +00001026}
1027
1028lldb::SBProcess
Greg Claytond8c62532010-10-07 04:19:01 +00001029SBTarget::AttachToProcessWithName
Greg Claytonc5f728c2010-10-06 22:10:17 +00001030(
Greg Clayton271a5db2011-02-03 21:28:34 +00001031 SBListener &listener,
Greg Claytonc5f728c2010-10-06 22:10:17 +00001032 const char *name, // basename of process to attach to
1033 bool wait_for, // if true wait for a new instance of "name" to be launched
1034 SBError& error // An error explaining what went wrong if attach fails
1035)
1036{
Sean Callanan4e846742012-10-20 00:21:31 +00001037 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1038
Greg Claytonc5f728c2010-10-06 22:10:17 +00001039 SBProcess sb_process;
Greg Clayton334d33a2012-01-30 07:41:31 +00001040 ProcessSP process_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001041 TargetSP target_sp(GetSP());
Sean Callanan4e846742012-10-20 00:21:31 +00001042
1043 if (log)
1044 {
1045 log->Printf ("SBTarget(%p)::AttachToProcessWithName (listener, name=%s, wait_for=%s, error)...", target_sp.get(), name, wait_for ? "true" : "false");
1046 }
1047
Greg Clayton0416bdf2012-01-30 09:04:36 +00001048 if (name && target_sp)
Greg Claytonc5f728c2010-10-06 22:10:17 +00001049 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001050 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Greg Claytonbdcda462010-12-20 20:49:23 +00001051
Greg Claytonde1dd812011-06-24 03:21:43 +00001052 StateType state = eStateInvalid;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001053 process_sp = target_sp->GetProcessSP();
Greg Clayton334d33a2012-01-30 07:41:31 +00001054 if (process_sp)
Greg Claytonde1dd812011-06-24 03:21:43 +00001055 {
Greg Clayton334d33a2012-01-30 07:41:31 +00001056 state = process_sp->GetState();
Greg Claytonde1dd812011-06-24 03:21:43 +00001057
Greg Clayton334d33a2012-01-30 07:41:31 +00001058 if (process_sp->IsAlive() && state != eStateConnected)
Greg Claytonde1dd812011-06-24 03:21:43 +00001059 {
1060 if (state == eStateAttaching)
1061 error.SetErrorString ("process attach is in progress");
1062 else
1063 error.SetErrorString ("a process is already being debugged");
Greg Claytonde1dd812011-06-24 03:21:43 +00001064 return sb_process;
1065 }
1066 }
1067
1068 if (state == eStateConnected)
1069 {
1070 // If we are already connected, then we have already specified the
1071 // listener, so if a valid listener is supplied, we need to error out
1072 // to let the client know.
1073 if (listener.IsValid())
1074 {
1075 error.SetErrorString ("process is connected and already has a listener, pass empty listener");
Greg Claytonde1dd812011-06-24 03:21:43 +00001076 return sb_process;
1077 }
1078 }
Greg Clayton271a5db2011-02-03 21:28:34 +00001079 else
Greg Claytonde1dd812011-06-24 03:21:43 +00001080 {
1081 if (listener.IsValid())
Greg Clayton46c9a352012-02-09 06:16:32 +00001082 process_sp = target_sp->CreateProcess (listener.ref(), NULL, NULL);
Greg Claytonde1dd812011-06-24 03:21:43 +00001083 else
Greg Clayton46c9a352012-02-09 06:16:32 +00001084 process_sp = target_sp->CreateProcess (target_sp->GetDebugger().GetListener(), NULL, NULL);
Greg Claytonde1dd812011-06-24 03:21:43 +00001085 }
Greg Claytonc5f728c2010-10-06 22:10:17 +00001086
Greg Clayton334d33a2012-01-30 07:41:31 +00001087 if (process_sp)
Greg Claytonc5f728c2010-10-06 22:10:17 +00001088 {
Greg Clayton334d33a2012-01-30 07:41:31 +00001089 sb_process.SetSP (process_sp);
Greg Clayton527154d2011-11-15 03:53:30 +00001090 ProcessAttachInfo attach_info;
1091 attach_info.GetExecutableFile().SetFile(name, false);
1092 attach_info.SetWaitForLaunch(wait_for);
Greg Clayton334d33a2012-01-30 07:41:31 +00001093 error.SetError (process_sp->Attach (attach_info));
Johnny Chen58d02ff2011-06-17 19:21:30 +00001094 // If we are doing synchronous mode, then wait for the
1095 // process to stop!
Greg Clayton0416bdf2012-01-30 09:04:36 +00001096 if (target_sp->GetDebugger().GetAsyncExecution () == false)
Greg Clayton334d33a2012-01-30 07:41:31 +00001097 process_sp->WaitForProcessToStop (NULL);
Greg Claytonc5f728c2010-10-06 22:10:17 +00001098 }
1099 else
1100 {
1101 error.SetErrorString ("unable to create lldb_private::Process");
1102 }
1103 }
1104 else
1105 {
1106 error.SetErrorString ("SBTarget is invalid");
1107 }
Sean Callanan4e846742012-10-20 00:21:31 +00001108
1109 if (log)
1110 {
1111 log->Printf ("SBTarget(%p)::AttachToPorcessWithName (...) => SBProcess(%p)",
1112 target_sp.get(), process_sp.get());
1113 }
Greg Claytonc5f728c2010-10-06 22:10:17 +00001114 return sb_process;
Greg Claytonc5f728c2010-10-06 22:10:17 +00001115}
1116
James McIlree38093402011-03-04 00:31:13 +00001117lldb::SBProcess
1118SBTarget::ConnectRemote
1119(
1120 SBListener &listener,
1121 const char *url,
1122 const char *plugin_name,
1123 SBError& error
1124)
1125{
Sean Callanan4e846742012-10-20 00:21:31 +00001126 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1127
James McIlree38093402011-03-04 00:31:13 +00001128 SBProcess sb_process;
Greg Clayton334d33a2012-01-30 07:41:31 +00001129 ProcessSP process_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001130 TargetSP target_sp(GetSP());
Sean Callanan4e846742012-10-20 00:21:31 +00001131
1132 if (log)
1133 {
1134 log->Printf ("SBTarget(%p)::ConnectRemote (listener, url=%s, plugin_name=%s, error)...", target_sp.get(), url, plugin_name);
1135 }
1136
Greg Clayton0416bdf2012-01-30 09:04:36 +00001137 if (target_sp)
James McIlree38093402011-03-04 00:31:13 +00001138 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001139 Mutex::Locker api_locker (target_sp->GetAPIMutex());
James McIlree38093402011-03-04 00:31:13 +00001140 if (listener.IsValid())
Greg Clayton46c9a352012-02-09 06:16:32 +00001141 process_sp = target_sp->CreateProcess (listener.ref(), plugin_name, NULL);
James McIlree38093402011-03-04 00:31:13 +00001142 else
Greg Clayton46c9a352012-02-09 06:16:32 +00001143 process_sp = target_sp->CreateProcess (target_sp->GetDebugger().GetListener(), plugin_name, NULL);
James McIlree38093402011-03-04 00:31:13 +00001144
1145
Greg Clayton334d33a2012-01-30 07:41:31 +00001146 if (process_sp)
James McIlree38093402011-03-04 00:31:13 +00001147 {
Greg Clayton334d33a2012-01-30 07:41:31 +00001148 sb_process.SetSP (process_sp);
Jason Molendafac2e622012-09-29 04:02:01 +00001149 error.SetError (process_sp->ConnectRemote (NULL, url));
James McIlree38093402011-03-04 00:31:13 +00001150 }
1151 else
1152 {
1153 error.SetErrorString ("unable to create lldb_private::Process");
1154 }
1155 }
1156 else
1157 {
1158 error.SetErrorString ("SBTarget is invalid");
1159 }
Sean Callanan4e846742012-10-20 00:21:31 +00001160
1161 if (log)
1162 {
1163 log->Printf ("SBTarget(%p)::ConnectRemote (...) => SBProcess(%p)",
1164 target_sp.get(), process_sp.get());
1165 }
James McIlree38093402011-03-04 00:31:13 +00001166 return sb_process;
1167}
1168
Chris Lattner24943d22010-06-08 16:52:24 +00001169SBFileSpec
1170SBTarget::GetExecutable ()
1171{
Caroline Tice7826c882010-10-26 03:11:13 +00001172
Chris Lattner24943d22010-06-08 16:52:24 +00001173 SBFileSpec exe_file_spec;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001174 TargetSP target_sp(GetSP());
1175 if (target_sp)
Chris Lattner24943d22010-06-08 16:52:24 +00001176 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001177 Module *exe_module = target_sp->GetExecutableModulePointer();
Greg Clayton5beb99d2011-08-11 02:48:45 +00001178 if (exe_module)
1179 exe_file_spec.SetFileSpec (exe_module->GetFileSpec());
Chris Lattner24943d22010-06-08 16:52:24 +00001180 }
Caroline Tice7826c882010-10-26 03:11:13 +00001181
Greg Claytone005f2c2010-11-06 01:53:30 +00001182 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001183 if (log)
1184 {
Greg Clayton49ce6822010-10-31 03:01:06 +00001185 log->Printf ("SBTarget(%p)::GetExecutable () => SBFileSpec(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001186 target_sp.get(), exe_file_spec.get());
Caroline Tice7826c882010-10-26 03:11:13 +00001187 }
1188
Chris Lattner24943d22010-06-08 16:52:24 +00001189 return exe_file_spec;
1190}
1191
Chris Lattner24943d22010-06-08 16:52:24 +00001192bool
Chris Lattner24943d22010-06-08 16:52:24 +00001193SBTarget::operator == (const SBTarget &rhs) const
1194{
Greg Clayton63094e02010-06-23 01:19:29 +00001195 return m_opaque_sp.get() == rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +00001196}
1197
1198bool
1199SBTarget::operator != (const SBTarget &rhs) const
1200{
Greg Clayton63094e02010-06-23 01:19:29 +00001201 return m_opaque_sp.get() != rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +00001202}
1203
Greg Clayton334d33a2012-01-30 07:41:31 +00001204lldb::TargetSP
1205SBTarget::GetSP () const
Greg Clayton15afa9f2011-10-01 02:59:24 +00001206{
1207 return m_opaque_sp;
1208}
1209
Greg Clayton63094e02010-06-23 01:19:29 +00001210void
Greg Clayton334d33a2012-01-30 07:41:31 +00001211SBTarget::SetSP (const lldb::TargetSP& target_sp)
Greg Clayton63094e02010-06-23 01:19:29 +00001212{
1213 m_opaque_sp = target_sp;
Chris Lattner24943d22010-06-08 16:52:24 +00001214}
1215
Greg Claytona3955062011-07-22 16:46:35 +00001216lldb::SBAddress
1217SBTarget::ResolveLoadAddress (lldb::addr_t vm_addr)
Greg Claytonea49cc72010-12-12 19:25:26 +00001218{
Greg Claytona3955062011-07-22 16:46:35 +00001219 lldb::SBAddress sb_addr;
1220 Address &addr = sb_addr.ref();
Greg Clayton0416bdf2012-01-30 09:04:36 +00001221 TargetSP target_sp(GetSP());
1222 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001223 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001224 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1225 if (target_sp->GetSectionLoadList().ResolveLoadAddress (vm_addr, addr))
Greg Claytona3955062011-07-22 16:46:35 +00001226 return sb_addr;
Greg Claytonbdcda462010-12-20 20:49:23 +00001227 }
Greg Claytonea49cc72010-12-12 19:25:26 +00001228
Greg Claytona3955062011-07-22 16:46:35 +00001229 // We have a load address that isn't in a section, just return an address
1230 // with the offset filled in (the address) and the section set to NULL
Greg Clayton3508c382012-02-24 01:59:29 +00001231 addr.SetRawAddress(vm_addr);
Greg Claytona3955062011-07-22 16:46:35 +00001232 return sb_addr;
Greg Claytonea49cc72010-12-12 19:25:26 +00001233}
1234
Greg Claytonafb81862011-03-02 21:34:46 +00001235SBSymbolContext
1236SBTarget::ResolveSymbolContextForAddress (const SBAddress& addr, uint32_t resolve_scope)
1237{
1238 SBSymbolContext sc;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001239 if (addr.IsValid())
1240 {
1241 TargetSP target_sp(GetSP());
1242 if (target_sp)
1243 target_sp->GetImages().ResolveSymbolContextForAddress (addr.ref(), resolve_scope, sc.ref());
1244 }
Greg Claytonafb81862011-03-02 21:34:46 +00001245 return sc;
1246}
1247
1248
Chris Lattner24943d22010-06-08 16:52:24 +00001249SBBreakpoint
1250SBTarget::BreakpointCreateByLocation (const char *file, uint32_t line)
1251{
Greg Claytond6d806c2010-11-08 00:28:40 +00001252 return SBBreakpoint(BreakpointCreateByLocation (SBFileSpec (file, false), line));
Chris Lattner24943d22010-06-08 16:52:24 +00001253}
1254
1255SBBreakpoint
1256SBTarget::BreakpointCreateByLocation (const SBFileSpec &sb_file_spec, uint32_t line)
1257{
Greg Claytone005f2c2010-11-06 01:53:30 +00001258 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001259
Chris Lattner24943d22010-06-08 16:52:24 +00001260 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001261 TargetSP target_sp(GetSP());
1262 if (target_sp && line != 0)
Greg Claytonbdcda462010-12-20 20:49:23 +00001263 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001264 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001265
Greg Clayton49ce8962012-08-29 21:13:06 +00001266 const LazyBool check_inlines = eLazyBoolCalculate;
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001267 const LazyBool skip_prologue = eLazyBoolCalculate;
Greg Clayton49ce8962012-08-29 21:13:06 +00001268 const bool internal = false;
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001269 *sb_bp = target_sp->CreateBreakpoint (NULL, *sb_file_spec, line, check_inlines, skip_prologue, internal);
Greg Claytonbdcda462010-12-20 20:49:23 +00001270 }
Caroline Tice7826c882010-10-26 03:11:13 +00001271
1272 if (log)
1273 {
1274 SBStream sstr;
1275 sb_bp.GetDescription (sstr);
Greg Clayton49ce6822010-10-31 03:01:06 +00001276 char path[PATH_MAX];
1277 sb_file_spec->GetPath (path, sizeof(path));
1278 log->Printf ("SBTarget(%p)::BreakpointCreateByLocation ( %s:%u ) => SBBreakpoint(%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001279 target_sp.get(),
Greg Clayton49ce6822010-10-31 03:01:06 +00001280 path,
Greg Claytona66ba462010-10-30 04:51:46 +00001281 line,
Greg Clayton49ce6822010-10-31 03:01:06 +00001282 sb_bp.get(),
Caroline Tice7826c882010-10-26 03:11:13 +00001283 sstr.GetData());
1284 }
1285
Chris Lattner24943d22010-06-08 16:52:24 +00001286 return sb_bp;
1287}
1288
1289SBBreakpoint
1290SBTarget::BreakpointCreateByName (const char *symbol_name, const char *module_name)
1291{
Greg Claytone005f2c2010-11-06 01:53:30 +00001292 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001293
Chris Lattner24943d22010-06-08 16:52:24 +00001294 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001295 TargetSP target_sp(GetSP());
1296 if (target_sp.get())
Chris Lattner24943d22010-06-08 16:52:24 +00001297 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001298 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001299
1300 const bool internal = false;
1301 const LazyBool skip_prologue = eLazyBoolCalculate;
Chris Lattner24943d22010-06-08 16:52:24 +00001302 if (module_name && module_name[0])
1303 {
Jim Ingham03c8ee52011-09-21 01:17:13 +00001304 FileSpecList module_spec_list;
1305 module_spec_list.Append (FileSpec (module_name, false));
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001306 *sb_bp = target_sp->CreateBreakpoint (&module_spec_list, NULL, symbol_name, eFunctionNameTypeAuto, skip_prologue, internal);
Chris Lattner24943d22010-06-08 16:52:24 +00001307 }
1308 else
1309 {
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001310 *sb_bp = target_sp->CreateBreakpoint (NULL, NULL, symbol_name, eFunctionNameTypeAuto, skip_prologue, internal);
Chris Lattner24943d22010-06-08 16:52:24 +00001311 }
1312 }
Caroline Tice7826c882010-10-26 03:11:13 +00001313
1314 if (log)
1315 {
Greg Clayton49ce6822010-10-31 03:01:06 +00001316 log->Printf ("SBTarget(%p)::BreakpointCreateByName (symbol=\"%s\", module=\"%s\") => SBBreakpoint(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001317 target_sp.get(), symbol_name, module_name, sb_bp.get());
Caroline Tice7826c882010-10-26 03:11:13 +00001318 }
1319
Chris Lattner24943d22010-06-08 16:52:24 +00001320 return sb_bp;
1321}
1322
Jim Inghamd6d47972011-09-23 00:54:11 +00001323lldb::SBBreakpoint
1324SBTarget::BreakpointCreateByName (const char *symbol_name,
1325 const SBFileSpecList &module_list,
1326 const SBFileSpecList &comp_unit_list)
1327{
Jim Ingham1fb8a2d2011-10-11 01:18:55 +00001328 uint32_t name_type_mask = eFunctionNameTypeAuto;
1329 return BreakpointCreateByName (symbol_name, name_type_mask, module_list, comp_unit_list);
1330}
1331
1332lldb::SBBreakpoint
1333SBTarget::BreakpointCreateByName (const char *symbol_name,
1334 uint32_t name_type_mask,
1335 const SBFileSpecList &module_list,
1336 const SBFileSpecList &comp_unit_list)
1337{
Jim Inghamd6d47972011-09-23 00:54:11 +00001338 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1339
1340 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001341 TargetSP target_sp(GetSP());
1342 if (target_sp && symbol_name && symbol_name[0])
Jim Inghamd6d47972011-09-23 00:54:11 +00001343 {
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001344 const bool internal = false;
1345 const LazyBool skip_prologue = eLazyBoolCalculate;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001346 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1347 *sb_bp = target_sp->CreateBreakpoint (module_list.get(),
Jim Inghamd6d47972011-09-23 00:54:11 +00001348 comp_unit_list.get(),
1349 symbol_name,
Jim Ingham1fb8a2d2011-10-11 01:18:55 +00001350 name_type_mask,
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001351 skip_prologue,
1352 internal);
Jim Inghamd6d47972011-09-23 00:54:11 +00001353 }
1354
1355 if (log)
1356 {
Jim Ingham1fb8a2d2011-10-11 01:18:55 +00001357 log->Printf ("SBTarget(%p)::BreakpointCreateByName (symbol=\"%s\", name_type: %d) => SBBreakpoint(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001358 target_sp.get(), symbol_name, name_type_mask, sb_bp.get());
Jim Inghamd6d47972011-09-23 00:54:11 +00001359 }
1360
1361 return sb_bp;
1362}
1363
Jim Ingham4722b102012-03-06 00:37:27 +00001364lldb::SBBreakpoint
1365SBTarget::BreakpointCreateByNames (const char *symbol_names[],
1366 uint32_t num_names,
1367 uint32_t name_type_mask,
1368 const SBFileSpecList &module_list,
1369 const SBFileSpecList &comp_unit_list)
1370{
1371 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1372
1373 SBBreakpoint sb_bp;
1374 TargetSP target_sp(GetSP());
1375 if (target_sp && num_names > 0)
1376 {
1377 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001378 const bool internal = false;
1379 const LazyBool skip_prologue = eLazyBoolCalculate;
Jim Ingham4722b102012-03-06 00:37:27 +00001380 *sb_bp = target_sp->CreateBreakpoint (module_list.get(),
1381 comp_unit_list.get(),
1382 symbol_names,
1383 num_names,
1384 name_type_mask,
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001385 skip_prologue,
1386 internal);
Jim Ingham4722b102012-03-06 00:37:27 +00001387 }
1388
1389 if (log)
1390 {
1391 log->Printf ("SBTarget(%p)::BreakpointCreateByName (symbols={", target_sp.get());
1392 for (uint32_t i = 0 ; i < num_names; i++)
1393 {
1394 char sep;
1395 if (i < num_names - 1)
1396 sep = ',';
1397 else
1398 sep = '}';
1399 if (symbol_names[i] != NULL)
1400 log->Printf ("\"%s\"%c ", symbol_names[i], sep);
1401 else
1402 log->Printf ("\"<NULL>\"%c ", sep);
1403
1404 }
1405 log->Printf ("name_type: %d) => SBBreakpoint(%p)", name_type_mask, sb_bp.get());
1406 }
1407
1408 return sb_bp;
1409}
Jim Inghamd6d47972011-09-23 00:54:11 +00001410
Chris Lattner24943d22010-06-08 16:52:24 +00001411SBBreakpoint
1412SBTarget::BreakpointCreateByRegex (const char *symbol_name_regex, const char *module_name)
1413{
Greg Claytone005f2c2010-11-06 01:53:30 +00001414 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001415
Chris Lattner24943d22010-06-08 16:52:24 +00001416 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001417 TargetSP target_sp(GetSP());
1418 if (target_sp && symbol_name_regex && symbol_name_regex[0])
Chris Lattner24943d22010-06-08 16:52:24 +00001419 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001420 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Chris Lattner24943d22010-06-08 16:52:24 +00001421 RegularExpression regexp(symbol_name_regex);
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001422 const bool internal = false;
1423 const LazyBool skip_prologue = eLazyBoolCalculate;
Chris Lattner24943d22010-06-08 16:52:24 +00001424
1425 if (module_name && module_name[0])
1426 {
Jim Ingham03c8ee52011-09-21 01:17:13 +00001427 FileSpecList module_spec_list;
1428 module_spec_list.Append (FileSpec (module_name, false));
Chris Lattner24943d22010-06-08 16:52:24 +00001429
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001430 *sb_bp = target_sp->CreateFuncRegexBreakpoint (&module_spec_list, NULL, regexp, skip_prologue, internal);
Chris Lattner24943d22010-06-08 16:52:24 +00001431 }
1432 else
1433 {
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001434 *sb_bp = target_sp->CreateFuncRegexBreakpoint (NULL, NULL, regexp, skip_prologue, internal);
Chris Lattner24943d22010-06-08 16:52:24 +00001435 }
1436 }
Caroline Tice7826c882010-10-26 03:11:13 +00001437
1438 if (log)
1439 {
Greg Clayton49ce6822010-10-31 03:01:06 +00001440 log->Printf ("SBTarget(%p)::BreakpointCreateByRegex (symbol_regex=\"%s\", module_name=\"%s\") => SBBreakpoint(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001441 target_sp.get(), symbol_name_regex, module_name, sb_bp.get());
Caroline Tice7826c882010-10-26 03:11:13 +00001442 }
1443
Chris Lattner24943d22010-06-08 16:52:24 +00001444 return sb_bp;
1445}
1446
Jim Inghamd6d47972011-09-23 00:54:11 +00001447lldb::SBBreakpoint
1448SBTarget::BreakpointCreateByRegex (const char *symbol_name_regex,
1449 const SBFileSpecList &module_list,
1450 const SBFileSpecList &comp_unit_list)
1451{
1452 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Chris Lattner24943d22010-06-08 16:52:24 +00001453
Jim Inghamd6d47972011-09-23 00:54:11 +00001454 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001455 TargetSP target_sp(GetSP());
1456 if (target_sp && symbol_name_regex && symbol_name_regex[0])
Jim Inghamd6d47972011-09-23 00:54:11 +00001457 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001458 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Jim Inghamd6d47972011-09-23 00:54:11 +00001459 RegularExpression regexp(symbol_name_regex);
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001460 const bool internal = false;
1461 const LazyBool skip_prologue = eLazyBoolCalculate;
Jim Inghamd6d47972011-09-23 00:54:11 +00001462
Jim Ingham2cf5ccb2012-05-22 00:12:20 +00001463 *sb_bp = target_sp->CreateFuncRegexBreakpoint (module_list.get(), comp_unit_list.get(), regexp, skip_prologue, internal);
Jim Inghamd6d47972011-09-23 00:54:11 +00001464 }
1465
1466 if (log)
1467 {
1468 log->Printf ("SBTarget(%p)::BreakpointCreateByRegex (symbol_regex=\"%s\") => SBBreakpoint(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001469 target_sp.get(), symbol_name_regex, sb_bp.get());
Jim Inghamd6d47972011-09-23 00:54:11 +00001470 }
1471
1472 return sb_bp;
1473}
Chris Lattner24943d22010-06-08 16:52:24 +00001474
1475SBBreakpoint
1476SBTarget::BreakpointCreateByAddress (addr_t address)
1477{
Greg Claytone005f2c2010-11-06 01:53:30 +00001478 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001479
Chris Lattner24943d22010-06-08 16:52:24 +00001480 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001481 TargetSP target_sp(GetSP());
1482 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001483 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001484 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1485 *sb_bp = target_sp->CreateBreakpoint (address, false);
Greg Claytonbdcda462010-12-20 20:49:23 +00001486 }
Caroline Tice7826c882010-10-26 03:11:13 +00001487
1488 if (log)
1489 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001490 log->Printf ("SBTarget(%p)::BreakpointCreateByAddress (address=%llu) => SBBreakpoint(%p)", target_sp.get(), (uint64_t) address, sb_bp.get());
Caroline Tice7826c882010-10-26 03:11:13 +00001491 }
1492
Chris Lattner24943d22010-06-08 16:52:24 +00001493 return sb_bp;
1494}
1495
Jim Ingham03c8ee52011-09-21 01:17:13 +00001496lldb::SBBreakpoint
1497SBTarget::BreakpointCreateBySourceRegex (const char *source_regex, const lldb::SBFileSpec &source_file, const char *module_name)
1498{
1499 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1500
1501 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001502 TargetSP target_sp(GetSP());
1503 if (target_sp && source_regex && source_regex[0])
Jim Ingham03c8ee52011-09-21 01:17:13 +00001504 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001505 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Jim Ingham03c8ee52011-09-21 01:17:13 +00001506 RegularExpression regexp(source_regex);
Jim Inghamd6d47972011-09-23 00:54:11 +00001507 FileSpecList source_file_spec_list;
1508 source_file_spec_list.Append (source_file.ref());
Jim Ingham03c8ee52011-09-21 01:17:13 +00001509
1510 if (module_name && module_name[0])
1511 {
1512 FileSpecList module_spec_list;
1513 module_spec_list.Append (FileSpec (module_name, false));
1514
Greg Clayton0416bdf2012-01-30 09:04:36 +00001515 *sb_bp = target_sp->CreateSourceRegexBreakpoint (&module_spec_list, &source_file_spec_list, regexp, false);
Jim Ingham03c8ee52011-09-21 01:17:13 +00001516 }
1517 else
1518 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001519 *sb_bp = target_sp->CreateSourceRegexBreakpoint (NULL, &source_file_spec_list, regexp, false);
Jim Ingham03c8ee52011-09-21 01:17:13 +00001520 }
1521 }
1522
1523 if (log)
1524 {
1525 char path[PATH_MAX];
1526 source_file->GetPath (path, sizeof(path));
1527 log->Printf ("SBTarget(%p)::BreakpointCreateByRegex (source_regex=\"%s\", file=\"%s\", module_name=\"%s\") => SBBreakpoint(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001528 target_sp.get(), source_regex, path, module_name, sb_bp.get());
Jim Ingham03c8ee52011-09-21 01:17:13 +00001529 }
1530
1531 return sb_bp;
1532}
1533
Jim Inghamd6d47972011-09-23 00:54:11 +00001534lldb::SBBreakpoint
1535SBTarget::BreakpointCreateBySourceRegex (const char *source_regex,
1536 const SBFileSpecList &module_list,
1537 const lldb::SBFileSpecList &source_file_list)
1538{
1539 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1540
1541 SBBreakpoint sb_bp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001542 TargetSP target_sp(GetSP());
1543 if (target_sp && source_regex && source_regex[0])
Jim Inghamd6d47972011-09-23 00:54:11 +00001544 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001545 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Jim Inghamd6d47972011-09-23 00:54:11 +00001546 RegularExpression regexp(source_regex);
Greg Clayton0416bdf2012-01-30 09:04:36 +00001547 *sb_bp = target_sp->CreateSourceRegexBreakpoint (module_list.get(), source_file_list.get(), regexp, false);
Jim Inghamd6d47972011-09-23 00:54:11 +00001548 }
1549
1550 if (log)
1551 {
1552 log->Printf ("SBTarget(%p)::BreakpointCreateByRegex (source_regex=\"%s\") => SBBreakpoint(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001553 target_sp.get(), source_regex, sb_bp.get());
Jim Inghamd6d47972011-09-23 00:54:11 +00001554 }
1555
1556 return sb_bp;
1557}
Jim Ingham03c8ee52011-09-21 01:17:13 +00001558
Jim Ingham4722b102012-03-06 00:37:27 +00001559lldb::SBBreakpoint
1560SBTarget::BreakpointCreateForException (lldb::LanguageType language,
1561 bool catch_bp,
1562 bool throw_bp)
1563{
1564 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1565
1566 SBBreakpoint sb_bp;
1567 TargetSP target_sp(GetSP());
1568 if (target_sp)
1569 {
1570 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1571 *sb_bp = target_sp->CreateExceptionBreakpoint (language, catch_bp, throw_bp);
1572 }
1573
1574 if (log)
1575 {
1576 log->Printf ("SBTarget(%p)::BreakpointCreateByRegex (Language: %s, catch: %s throw: %s) => SBBreakpoint(%p)",
1577 target_sp.get(),
1578 LanguageRuntime::GetNameForLanguageType(language),
1579 catch_bp ? "on" : "off",
1580 throw_bp ? "on" : "off",
1581 sb_bp.get());
1582 }
1583
1584 return sb_bp;
1585}
1586
Greg Claytonc7f5d5c2010-07-23 23:33:17 +00001587uint32_t
1588SBTarget::GetNumBreakpoints () const
1589{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001590 TargetSP target_sp(GetSP());
1591 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001592 {
1593 // The breakpoint list is thread safe, no need to lock
Greg Clayton0416bdf2012-01-30 09:04:36 +00001594 return target_sp->GetBreakpointList().GetSize();
Greg Claytonbdcda462010-12-20 20:49:23 +00001595 }
Greg Claytonc7f5d5c2010-07-23 23:33:17 +00001596 return 0;
1597}
1598
1599SBBreakpoint
1600SBTarget::GetBreakpointAtIndex (uint32_t idx) const
1601{
1602 SBBreakpoint sb_breakpoint;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001603 TargetSP target_sp(GetSP());
1604 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001605 {
1606 // The breakpoint list is thread safe, no need to lock
Greg Clayton0416bdf2012-01-30 09:04:36 +00001607 *sb_breakpoint = target_sp->GetBreakpointList().GetBreakpointAtIndex(idx);
Greg Claytonbdcda462010-12-20 20:49:23 +00001608 }
Greg Claytonc7f5d5c2010-07-23 23:33:17 +00001609 return sb_breakpoint;
1610}
Chris Lattner24943d22010-06-08 16:52:24 +00001611
1612bool
1613SBTarget::BreakpointDelete (break_id_t bp_id)
1614{
Greg Claytone005f2c2010-11-06 01:53:30 +00001615 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001616
Caroline Tice7826c882010-10-26 03:11:13 +00001617 bool result = false;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001618 TargetSP target_sp(GetSP());
1619 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001620 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001621 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1622 result = target_sp->RemoveBreakpointByID (bp_id);
Greg Claytonbdcda462010-12-20 20:49:23 +00001623 }
Caroline Tice7826c882010-10-26 03:11:13 +00001624
1625 if (log)
1626 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001627 log->Printf ("SBTarget(%p)::BreakpointDelete (bp_id=%d) => %i", target_sp.get(), (uint32_t) bp_id, result);
Caroline Tice7826c882010-10-26 03:11:13 +00001628 }
1629
1630 return result;
Chris Lattner24943d22010-06-08 16:52:24 +00001631}
1632
Johnny Chen096c2932011-09-26 22:40:50 +00001633SBBreakpoint
1634SBTarget::FindBreakpointByID (break_id_t bp_id)
1635{
1636 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1637
1638 SBBreakpoint sb_breakpoint;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001639 TargetSP target_sp(GetSP());
1640 if (target_sp && bp_id != LLDB_INVALID_BREAK_ID)
Johnny Chen096c2932011-09-26 22:40:50 +00001641 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001642 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1643 *sb_breakpoint = target_sp->GetBreakpointByID (bp_id);
Johnny Chen096c2932011-09-26 22:40:50 +00001644 }
1645
1646 if (log)
1647 {
1648 log->Printf ("SBTarget(%p)::FindBreakpointByID (bp_id=%d) => SBBreakpoint(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001649 target_sp.get(), (uint32_t) bp_id, sb_breakpoint.get());
Johnny Chen096c2932011-09-26 22:40:50 +00001650 }
1651
1652 return sb_breakpoint;
1653}
1654
Chris Lattner24943d22010-06-08 16:52:24 +00001655bool
1656SBTarget::EnableAllBreakpoints ()
1657{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001658 TargetSP target_sp(GetSP());
1659 if (target_sp)
Chris Lattner24943d22010-06-08 16:52:24 +00001660 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001661 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1662 target_sp->EnableAllBreakpoints ();
Chris Lattner24943d22010-06-08 16:52:24 +00001663 return true;
1664 }
1665 return false;
1666}
1667
1668bool
1669SBTarget::DisableAllBreakpoints ()
1670{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001671 TargetSP target_sp(GetSP());
1672 if (target_sp)
Chris Lattner24943d22010-06-08 16:52:24 +00001673 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001674 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1675 target_sp->DisableAllBreakpoints ();
Chris Lattner24943d22010-06-08 16:52:24 +00001676 return true;
1677 }
1678 return false;
1679}
1680
1681bool
1682SBTarget::DeleteAllBreakpoints ()
1683{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001684 TargetSP target_sp(GetSP());
1685 if (target_sp)
Chris Lattner24943d22010-06-08 16:52:24 +00001686 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001687 Mutex::Locker api_locker (target_sp->GetAPIMutex());
1688 target_sp->RemoveAllBreakpoints ();
Chris Lattner24943d22010-06-08 16:52:24 +00001689 return true;
1690 }
1691 return false;
1692}
1693
Johnny Chen096c2932011-09-26 22:40:50 +00001694uint32_t
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001695SBTarget::GetNumWatchpoints () const
Johnny Chen096c2932011-09-26 22:40:50 +00001696{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001697 TargetSP target_sp(GetSP());
1698 if (target_sp)
Johnny Chen096c2932011-09-26 22:40:50 +00001699 {
Johnny Chenecd4feb2011-10-14 00:42:25 +00001700 // The watchpoint list is thread safe, no need to lock
Greg Clayton0416bdf2012-01-30 09:04:36 +00001701 return target_sp->GetWatchpointList().GetSize();
Johnny Chen096c2932011-09-26 22:40:50 +00001702 }
1703 return 0;
1704}
1705
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001706SBWatchpoint
1707SBTarget::GetWatchpointAtIndex (uint32_t idx) const
Johnny Chen5eb54bb2011-09-27 20:29:45 +00001708{
Johnny Chenecd4feb2011-10-14 00:42:25 +00001709 SBWatchpoint sb_watchpoint;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001710 TargetSP target_sp(GetSP());
1711 if (target_sp)
Johnny Chen096c2932011-09-26 22:40:50 +00001712 {
Johnny Chenecd4feb2011-10-14 00:42:25 +00001713 // The watchpoint list is thread safe, no need to lock
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001714 sb_watchpoint.SetSP (target_sp->GetWatchpointList().GetByIndex(idx));
Johnny Chen096c2932011-09-26 22:40:50 +00001715 }
Johnny Chenecd4feb2011-10-14 00:42:25 +00001716 return sb_watchpoint;
Johnny Chen096c2932011-09-26 22:40:50 +00001717}
1718
1719bool
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001720SBTarget::DeleteWatchpoint (watch_id_t wp_id)
Johnny Chen096c2932011-09-26 22:40:50 +00001721{
1722 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1723
1724 bool result = false;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001725 TargetSP target_sp(GetSP());
1726 if (target_sp)
Johnny Chen096c2932011-09-26 22:40:50 +00001727 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001728 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Johnny Chenbbf6aa52012-05-31 22:56:36 +00001729 Mutex::Locker locker;
1730 target_sp->GetWatchpointList().GetListMutex(locker);
Greg Clayton0416bdf2012-01-30 09:04:36 +00001731 result = target_sp->RemoveWatchpointByID (wp_id);
Johnny Chen096c2932011-09-26 22:40:50 +00001732 }
1733
1734 if (log)
1735 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001736 log->Printf ("SBTarget(%p)::WatchpointDelete (wp_id=%d) => %i", target_sp.get(), (uint32_t) wp_id, result);
Johnny Chen096c2932011-09-26 22:40:50 +00001737 }
1738
1739 return result;
1740}
1741
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001742SBWatchpoint
1743SBTarget::FindWatchpointByID (lldb::watch_id_t wp_id)
Johnny Chen096c2932011-09-26 22:40:50 +00001744{
1745 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1746
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001747 SBWatchpoint sb_watchpoint;
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001748 lldb::WatchpointSP watchpoint_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001749 TargetSP target_sp(GetSP());
1750 if (target_sp && wp_id != LLDB_INVALID_WATCH_ID)
Johnny Chen096c2932011-09-26 22:40:50 +00001751 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001752 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Johnny Chenbbf6aa52012-05-31 22:56:36 +00001753 Mutex::Locker locker;
1754 target_sp->GetWatchpointList().GetListMutex(locker);
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001755 watchpoint_sp = target_sp->GetWatchpointList().FindByID(wp_id);
1756 sb_watchpoint.SetSP (watchpoint_sp);
Johnny Chen096c2932011-09-26 22:40:50 +00001757 }
1758
1759 if (log)
1760 {
Johnny Chenecd4feb2011-10-14 00:42:25 +00001761 log->Printf ("SBTarget(%p)::FindWatchpointByID (bp_id=%d) => SBWatchpoint(%p)",
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001762 target_sp.get(), (uint32_t) wp_id, watchpoint_sp.get());
Johnny Chen096c2932011-09-26 22:40:50 +00001763 }
1764
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001765 return sb_watchpoint;
1766}
1767
1768lldb::SBWatchpoint
Johnny Chen3f883492012-06-04 23:19:54 +00001769SBTarget::WatchAddress (lldb::addr_t addr, size_t size, bool read, bool write, SBError &error)
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001770{
1771 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1772
1773 SBWatchpoint sb_watchpoint;
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001774 lldb::WatchpointSP watchpoint_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001775 TargetSP target_sp(GetSP());
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001776 if (target_sp && (read || write) && addr != LLDB_INVALID_ADDRESS && size > 0)
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001777 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001778 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001779 uint32_t watch_type = 0;
1780 if (read)
1781 watch_type |= LLDB_WATCH_TYPE_READ;
1782 if (write)
1783 watch_type |= LLDB_WATCH_TYPE_WRITE;
Johnny Chenbbf6aa52012-05-31 22:56:36 +00001784 // Target::CreateWatchpoint() is thread safe.
Johnny Chen3f883492012-06-04 23:19:54 +00001785 Error cw_error;
1786 watchpoint_sp = target_sp->CreateWatchpoint(addr, size, watch_type, cw_error);
1787 error.SetError(cw_error);
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001788 sb_watchpoint.SetSP (watchpoint_sp);
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001789 }
1790
1791 if (log)
1792 {
1793 log->Printf ("SBTarget(%p)::WatchAddress (addr=0x%llx, 0x%u) => SBWatchpoint(%p)",
Greg Clayton0a19a1b2012-02-04 02:27:34 +00001794 target_sp.get(), addr, (uint32_t) size, watchpoint_sp.get());
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001795 }
1796
1797 return sb_watchpoint;
Johnny Chen096c2932011-09-26 22:40:50 +00001798}
1799
1800bool
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001801SBTarget::EnableAllWatchpoints ()
Johnny Chen096c2932011-09-26 22:40:50 +00001802{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001803 TargetSP target_sp(GetSP());
1804 if (target_sp)
Johnny Chen096c2932011-09-26 22:40:50 +00001805 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001806 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Johnny Chenbbf6aa52012-05-31 22:56:36 +00001807 Mutex::Locker locker;
1808 target_sp->GetWatchpointList().GetListMutex(locker);
Greg Clayton0416bdf2012-01-30 09:04:36 +00001809 target_sp->EnableAllWatchpoints ();
Johnny Chen096c2932011-09-26 22:40:50 +00001810 return true;
1811 }
1812 return false;
1813}
1814
1815bool
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001816SBTarget::DisableAllWatchpoints ()
Johnny Chen096c2932011-09-26 22:40:50 +00001817{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001818 TargetSP target_sp(GetSP());
1819 if (target_sp)
Johnny Chen096c2932011-09-26 22:40:50 +00001820 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001821 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Johnny Chenbbf6aa52012-05-31 22:56:36 +00001822 Mutex::Locker locker;
1823 target_sp->GetWatchpointList().GetListMutex(locker);
Greg Clayton0416bdf2012-01-30 09:04:36 +00001824 target_sp->DisableAllWatchpoints ();
Johnny Chen096c2932011-09-26 22:40:50 +00001825 return true;
1826 }
1827 return false;
1828}
1829
1830bool
Greg Clayton1fa6b3d2011-10-13 18:08:26 +00001831SBTarget::DeleteAllWatchpoints ()
Johnny Chen096c2932011-09-26 22:40:50 +00001832{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001833 TargetSP target_sp(GetSP());
1834 if (target_sp)
Johnny Chen096c2932011-09-26 22:40:50 +00001835 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001836 Mutex::Locker api_locker (target_sp->GetAPIMutex());
Johnny Chenbbf6aa52012-05-31 22:56:36 +00001837 Mutex::Locker locker;
1838 target_sp->GetWatchpointList().GetListMutex(locker);
Greg Clayton0416bdf2012-01-30 09:04:36 +00001839 target_sp->RemoveAllWatchpoints ();
Johnny Chen096c2932011-09-26 22:40:50 +00001840 return true;
1841 }
1842 return false;
1843}
1844
Chris Lattner24943d22010-06-08 16:52:24 +00001845
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001846lldb::SBModule
1847SBTarget::AddModule (const char *path,
1848 const char *triple,
1849 const char *uuid_cstr)
1850{
Greg Claytonf0bc8152012-04-23 20:23:39 +00001851 return AddModule (path, triple, uuid_cstr, NULL);
1852}
1853
1854lldb::SBModule
1855SBTarget::AddModule (const char *path,
1856 const char *triple,
1857 const char *uuid_cstr,
1858 const char *symfile)
1859{
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001860 lldb::SBModule sb_module;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001861 TargetSP target_sp(GetSP());
1862 if (target_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001863 {
Greg Clayton444fe992012-02-26 05:51:37 +00001864 ModuleSpec module_spec;
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001865 if (path)
Greg Clayton444fe992012-02-26 05:51:37 +00001866 module_spec.GetFileSpec().SetFile(path, false);
Greg Claytonf0bc8152012-04-23 20:23:39 +00001867
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001868 if (uuid_cstr)
Greg Clayton437b5bc2012-09-27 22:26:11 +00001869 module_spec.GetUUID().SetFromCString(uuid_cstr);
Greg Claytonf0bc8152012-04-23 20:23:39 +00001870
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001871 if (triple)
Greg Clayton444fe992012-02-26 05:51:37 +00001872 module_spec.GetArchitecture().SetTriple (triple, target_sp->GetPlatform ().get());
Greg Claytonf0bc8152012-04-23 20:23:39 +00001873
1874 if (symfile)
1875 module_spec.GetSymbolFileSpec ().SetFile(symfile, false);
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001876
Greg Clayton444fe992012-02-26 05:51:37 +00001877 sb_module.SetSP(target_sp->GetSharedModule (module_spec));
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001878 }
1879 return sb_module;
1880}
1881
1882bool
1883SBTarget::AddModule (lldb::SBModule &module)
1884{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001885 TargetSP target_sp(GetSP());
1886 if (target_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001887 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001888 target_sp->GetImages().AppendIfNeeded (module.GetSP());
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001889 return true;
1890 }
1891 return false;
1892}
1893
Chris Lattner24943d22010-06-08 16:52:24 +00001894uint32_t
1895SBTarget::GetNumModules () const
1896{
Greg Claytone005f2c2010-11-06 01:53:30 +00001897 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001898
Caroline Tice7826c882010-10-26 03:11:13 +00001899 uint32_t num = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001900 TargetSP target_sp(GetSP());
1901 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001902 {
1903 // The module list is thread safe, no need to lock
Greg Clayton0416bdf2012-01-30 09:04:36 +00001904 num = target_sp->GetImages().GetSize();
Greg Claytonbdcda462010-12-20 20:49:23 +00001905 }
Caroline Tice7826c882010-10-26 03:11:13 +00001906
1907 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +00001908 log->Printf ("SBTarget(%p)::GetNumModules () => %d", target_sp.get(), num);
Caroline Tice7826c882010-10-26 03:11:13 +00001909
1910 return num;
Chris Lattner24943d22010-06-08 16:52:24 +00001911}
1912
Greg Clayton43490d12010-07-30 20:12:55 +00001913void
1914SBTarget::Clear ()
1915{
Greg Claytone005f2c2010-11-06 01:53:30 +00001916 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001917
1918 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +00001919 log->Printf ("SBTarget(%p)::Clear ()", m_opaque_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +00001920
Greg Clayton43490d12010-07-30 20:12:55 +00001921 m_opaque_sp.reset();
1922}
1923
1924
Chris Lattner24943d22010-06-08 16:52:24 +00001925SBModule
1926SBTarget::FindModule (const SBFileSpec &sb_file_spec)
1927{
1928 SBModule sb_module;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001929 TargetSP target_sp(GetSP());
1930 if (target_sp && sb_file_spec.IsValid())
Greg Claytonbdcda462010-12-20 20:49:23 +00001931 {
Greg Clayton444fe992012-02-26 05:51:37 +00001932 ModuleSpec module_spec(*sb_file_spec);
Greg Claytonbdcda462010-12-20 20:49:23 +00001933 // The module list is thread safe, no need to lock
Greg Clayton444fe992012-02-26 05:51:37 +00001934 sb_module.SetSP (target_sp->GetImages().FindFirstModule (module_spec));
Greg Claytonbdcda462010-12-20 20:49:23 +00001935 }
Chris Lattner24943d22010-06-08 16:52:24 +00001936 return sb_module;
1937}
1938
Greg Clayton1b925202012-01-29 06:07:39 +00001939lldb::ByteOrder
1940SBTarget::GetByteOrder ()
1941{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001942 TargetSP target_sp(GetSP());
1943 if (target_sp)
1944 return target_sp->GetArchitecture().GetByteOrder();
Greg Clayton1b925202012-01-29 06:07:39 +00001945 return eByteOrderInvalid;
1946}
1947
1948const char *
1949SBTarget::GetTriple ()
1950{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001951 TargetSP target_sp(GetSP());
1952 if (target_sp)
Greg Clayton1b925202012-01-29 06:07:39 +00001953 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00001954 std::string triple (target_sp->GetArchitecture().GetTriple().str());
Greg Clayton1b925202012-01-29 06:07:39 +00001955 // Unique the string so we don't run into ownership issues since
1956 // the const strings put the string into the string pool once and
1957 // the strings never comes out
1958 ConstString const_triple (triple.c_str());
1959 return const_triple.GetCString();
1960 }
1961 return NULL;
1962}
1963
1964uint32_t
1965SBTarget::GetAddressByteSize()
1966{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001967 TargetSP target_sp(GetSP());
1968 if (target_sp)
1969 return target_sp->GetArchitecture().GetAddressByteSize();
Greg Clayton1b925202012-01-29 06:07:39 +00001970 return sizeof(void*);
1971}
1972
1973
Chris Lattner24943d22010-06-08 16:52:24 +00001974SBModule
1975SBTarget::GetModuleAtIndex (uint32_t idx)
1976{
Greg Claytone005f2c2010-11-06 01:53:30 +00001977 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00001978
Chris Lattner24943d22010-06-08 16:52:24 +00001979 SBModule sb_module;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001980 ModuleSP module_sp;
1981 TargetSP target_sp(GetSP());
1982 if (target_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001983 {
1984 // The module list is thread safe, no need to lock
Greg Clayton0416bdf2012-01-30 09:04:36 +00001985 module_sp = target_sp->GetImages().GetModuleAtIndex(idx);
1986 sb_module.SetSP (module_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +00001987 }
Caroline Tice7826c882010-10-26 03:11:13 +00001988
1989 if (log)
1990 {
Greg Clayton49ce6822010-10-31 03:01:06 +00001991 log->Printf ("SBTarget(%p)::GetModuleAtIndex (idx=%d) => SBModule(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00001992 target_sp.get(), idx, module_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +00001993 }
1994
Chris Lattner24943d22010-06-08 16:52:24 +00001995 return sb_module;
1996}
1997
Greg Clayton3e8c25f2011-09-24 00:52:29 +00001998bool
1999SBTarget::RemoveModule (lldb::SBModule module)
2000{
Greg Clayton0416bdf2012-01-30 09:04:36 +00002001 TargetSP target_sp(GetSP());
2002 if (target_sp)
2003 return target_sp->GetImages().Remove(module.GetSP());
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002004 return false;
2005}
2006
Chris Lattner24943d22010-06-08 16:52:24 +00002007
2008SBBroadcaster
2009SBTarget::GetBroadcaster () const
2010{
Greg Claytone005f2c2010-11-06 01:53:30 +00002011 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +00002012
Greg Clayton0416bdf2012-01-30 09:04:36 +00002013 TargetSP target_sp(GetSP());
2014 SBBroadcaster broadcaster(target_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +00002015
2016 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +00002017 log->Printf ("SBTarget(%p)::GetBroadcaster () => SBBroadcaster(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +00002018 target_sp.get(), broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +00002019
Chris Lattner24943d22010-06-08 16:52:24 +00002020 return broadcaster;
2021}
2022
Caroline Tice98f930f2010-09-20 05:20:02 +00002023bool
Caroline Tice7826c882010-10-26 03:11:13 +00002024SBTarget::GetDescription (SBStream &description, lldb::DescriptionLevel description_level)
Caroline Tice98f930f2010-09-20 05:20:02 +00002025{
Greg Clayton96154be2011-11-13 06:57:31 +00002026 Stream &strm = description.ref();
2027
Greg Clayton0416bdf2012-01-30 09:04:36 +00002028 TargetSP target_sp(GetSP());
2029 if (target_sp)
Caroline Ticee7a566e2010-09-20 16:21:41 +00002030 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002031 target_sp->Dump (&strm, description_level);
Caroline Tice7826c882010-10-26 03:11:13 +00002032 }
2033 else
Greg Clayton96154be2011-11-13 06:57:31 +00002034 strm.PutCString ("No value");
Caroline Tice7826c882010-10-26 03:11:13 +00002035
2036 return true;
2037}
2038
Greg Clayton7dd5c512012-02-06 01:44:54 +00002039lldb::SBSymbolContextList
2040SBTarget::FindFunctions (const char *name, uint32_t name_type_mask)
Greg Clayton4ed315f2011-06-21 01:34:41 +00002041{
Greg Clayton7dd5c512012-02-06 01:44:54 +00002042 lldb::SBSymbolContextList sb_sc_list;
Greg Clayton0416bdf2012-01-30 09:04:36 +00002043 if (name && name[0])
Greg Clayton4ed315f2011-06-21 01:34:41 +00002044 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002045 TargetSP target_sp(GetSP());
2046 if (target_sp)
2047 {
2048 const bool symbols_ok = true;
Sean Callanan302d78c2012-02-10 22:52:19 +00002049 const bool inlines_ok = true;
Greg Clayton7dd5c512012-02-06 01:44:54 +00002050 const bool append = true;
2051 target_sp->GetImages().FindFunctions (ConstString(name),
2052 name_type_mask,
Sean Callanan302d78c2012-02-10 22:52:19 +00002053 symbols_ok,
2054 inlines_ok,
Greg Clayton7dd5c512012-02-06 01:44:54 +00002055 append,
2056 *sb_sc_list);
Greg Clayton0416bdf2012-01-30 09:04:36 +00002057 }
Greg Clayton4ed315f2011-06-21 01:34:41 +00002058 }
Greg Clayton7dd5c512012-02-06 01:44:54 +00002059 return sb_sc_list;
Greg Clayton4ed315f2011-06-21 01:34:41 +00002060}
2061
Enrico Granata979e20d2011-07-29 19:53:35 +00002062lldb::SBType
2063SBTarget::FindFirstType (const char* type)
2064{
Greg Clayton0416bdf2012-01-30 09:04:36 +00002065 TargetSP target_sp(GetSP());
2066 if (type && target_sp)
Enrico Granata979e20d2011-07-29 19:53:35 +00002067 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002068 size_t count = target_sp->GetImages().GetSize();
Enrico Granata979e20d2011-07-29 19:53:35 +00002069 for (size_t idx = 0; idx < count; idx++)
2070 {
2071 SBType found_at_idx = GetModuleAtIndex(idx).FindFirstType(type);
2072
2073 if (found_at_idx.IsValid())
2074 return found_at_idx;
2075 }
2076 }
2077 return SBType();
2078}
2079
2080lldb::SBTypeList
2081SBTarget::FindTypes (const char* type)
2082{
2083
2084 SBTypeList retval;
2085
Greg Clayton0416bdf2012-01-30 09:04:36 +00002086 TargetSP target_sp(GetSP());
2087 if (type && target_sp)
Enrico Granata979e20d2011-07-29 19:53:35 +00002088 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002089 ModuleList& images = target_sp->GetImages();
Enrico Granata979e20d2011-07-29 19:53:35 +00002090 ConstString name_const(type);
Greg Claytondc0a38c2012-03-26 23:03:23 +00002091 bool exact_match = false;
Enrico Granata979e20d2011-07-29 19:53:35 +00002092 SymbolContext sc;
2093 TypeList type_list;
2094
Greg Clayton9f95fb62012-04-06 17:41:13 +00002095 uint32_t num_matches = images.FindTypes (sc,
Greg Claytondc0a38c2012-03-26 23:03:23 +00002096 name_const,
2097 exact_match,
2098 UINT32_MAX,
2099 type_list);
Enrico Granata979e20d2011-07-29 19:53:35 +00002100
2101 for (size_t idx = 0; idx < num_matches; idx++)
2102 {
Greg Clayton0fb0bcc2011-08-03 22:57:10 +00002103 TypeSP type_sp (type_list.GetTypeAtIndex(idx));
2104 if (type_sp)
2105 retval.Append(SBType(type_sp));
Enrico Granata979e20d2011-07-29 19:53:35 +00002106 }
2107 }
2108 return retval;
2109}
2110
Greg Clayton917c0002011-06-29 22:09:02 +00002111SBValueList
2112SBTarget::FindGlobalVariables (const char *name, uint32_t max_matches)
2113{
2114 SBValueList sb_value_list;
2115
Greg Clayton0416bdf2012-01-30 09:04:36 +00002116 TargetSP target_sp(GetSP());
2117 if (name && target_sp)
Greg Clayton917c0002011-06-29 22:09:02 +00002118 {
2119 VariableList variable_list;
2120 const bool append = true;
Greg Clayton0416bdf2012-01-30 09:04:36 +00002121 const uint32_t match_count = target_sp->GetImages().FindGlobalVariables (ConstString (name),
2122 append,
2123 max_matches,
2124 variable_list);
Greg Clayton917c0002011-06-29 22:09:02 +00002125
2126 if (match_count > 0)
2127 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002128 ExecutionContextScope *exe_scope = target_sp->GetProcessSP().get();
Greg Clayton917c0002011-06-29 22:09:02 +00002129 if (exe_scope == NULL)
Greg Clayton0416bdf2012-01-30 09:04:36 +00002130 exe_scope = target_sp.get();
Greg Clayton917c0002011-06-29 22:09:02 +00002131 ValueObjectList &value_object_list = sb_value_list.ref();
2132 for (uint32_t i=0; i<match_count; ++i)
2133 {
2134 lldb::ValueObjectSP valobj_sp (ValueObjectVariable::Create (exe_scope, variable_list.GetVariableAtIndex(i)));
2135 if (valobj_sp)
2136 value_object_list.Append(valobj_sp);
2137 }
2138 }
2139 }
2140
2141 return sb_value_list;
2142}
2143
Jim Inghamcc637462011-09-13 00:29:56 +00002144SBSourceManager
2145SBTarget::GetSourceManager()
2146{
2147 SBSourceManager source_manager (*this);
2148 return source_manager;
2149}
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002150
Sean Callananef1f6902011-12-14 23:49:37 +00002151lldb::SBInstructionList
Greg Claytona9893072012-03-06 22:24:44 +00002152SBTarget::ReadInstructions (lldb::SBAddress base_addr, uint32_t count)
2153{
2154 SBInstructionList sb_instructions;
2155
2156 TargetSP target_sp(GetSP());
2157 if (target_sp)
2158 {
2159 Address *addr_ptr = base_addr.get();
2160
2161 if (addr_ptr)
2162 {
2163 DataBufferHeap data (target_sp->GetArchitecture().GetMaximumOpcodeByteSize() * count, 0);
2164 bool prefer_file_cache = false;
2165 lldb_private::Error error;
2166 const size_t bytes_read = target_sp->ReadMemory(*addr_ptr, prefer_file_cache, data.GetBytes(), data.GetByteSize(), error);
2167 sb_instructions.SetDisassembler (Disassembler::DisassembleBytes (target_sp->GetArchitecture(),
2168 NULL,
2169 *addr_ptr,
2170 data.GetBytes(),
2171 bytes_read,
2172 count));
2173 }
2174 }
2175
2176 return sb_instructions;
2177
2178}
2179
2180lldb::SBInstructionList
Sean Callananef1f6902011-12-14 23:49:37 +00002181SBTarget::GetInstructions (lldb::SBAddress base_addr, const void *buf, size_t size)
2182{
2183 SBInstructionList sb_instructions;
2184
Greg Clayton0416bdf2012-01-30 09:04:36 +00002185 TargetSP target_sp(GetSP());
2186 if (target_sp)
Sean Callananef1f6902011-12-14 23:49:37 +00002187 {
2188 Address addr;
2189
2190 if (base_addr.get())
2191 addr = *base_addr.get();
2192
Greg Clayton0416bdf2012-01-30 09:04:36 +00002193 sb_instructions.SetDisassembler (Disassembler::DisassembleBytes (target_sp->GetArchitecture(),
Sean Callananef1f6902011-12-14 23:49:37 +00002194 NULL,
2195 addr,
2196 buf,
2197 size));
2198 }
2199
2200 return sb_instructions;
2201}
2202
2203lldb::SBInstructionList
2204SBTarget::GetInstructions (lldb::addr_t base_addr, const void *buf, size_t size)
2205{
2206 return GetInstructions (ResolveLoadAddress(base_addr), buf, size);
2207}
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002208
2209SBError
2210SBTarget::SetSectionLoadAddress (lldb::SBSection section,
2211 lldb::addr_t section_base_addr)
2212{
2213 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +00002214 TargetSP target_sp(GetSP());
2215 if (target_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002216 {
2217 if (!section.IsValid())
2218 {
2219 sb_error.SetErrorStringWithFormat ("invalid section");
2220 }
2221 else
2222 {
Greg Clayton9ab696e2012-03-27 21:10:07 +00002223 SectionSP section_sp (section.GetSP());
2224 if (section_sp)
2225 {
2226 if (section_sp->IsThreadSpecific())
2227 {
2228 sb_error.SetErrorString ("thread specific sections are not yet supported");
2229 }
2230 else
2231 {
Greg Clayton545762f2012-07-07 01:24:12 +00002232 target_sp->GetSectionLoadList().SetSectionLoadAddress (section_sp, section_base_addr);
Greg Clayton9ab696e2012-03-27 21:10:07 +00002233 }
2234 }
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002235 }
2236 }
2237 else
2238 {
Greg Clayton9ab696e2012-03-27 21:10:07 +00002239 sb_error.SetErrorString ("invalid target");
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002240 }
2241 return sb_error;
2242}
2243
2244SBError
2245SBTarget::ClearSectionLoadAddress (lldb::SBSection section)
2246{
2247 SBError sb_error;
2248
Greg Clayton0416bdf2012-01-30 09:04:36 +00002249 TargetSP target_sp(GetSP());
2250 if (target_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002251 {
2252 if (!section.IsValid())
2253 {
2254 sb_error.SetErrorStringWithFormat ("invalid section");
2255 }
2256 else
2257 {
Greg Clayton545762f2012-07-07 01:24:12 +00002258 target_sp->GetSectionLoadList().SetSectionUnloaded (section.GetSP());
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002259 }
2260 }
2261 else
2262 {
2263 sb_error.SetErrorStringWithFormat ("invalid target");
2264 }
2265 return sb_error;
2266}
2267
2268SBError
2269SBTarget::SetModuleLoadAddress (lldb::SBModule module, int64_t slide_offset)
2270{
2271 SBError sb_error;
2272
Greg Clayton0416bdf2012-01-30 09:04:36 +00002273 TargetSP target_sp(GetSP());
2274 if (target_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002275 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002276 ModuleSP module_sp (module.GetSP());
2277 if (module_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002278 {
Greg Clayton9ab696e2012-03-27 21:10:07 +00002279 bool changed = false;
2280 if (module_sp->SetLoadAddress (*target_sp, slide_offset, changed))
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002281 {
Greg Clayton9ab696e2012-03-27 21:10:07 +00002282 // The load was successful, make sure that at least some sections
2283 // changed before we notify that our module was loaded.
2284 if (changed)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002285 {
Greg Clayton9ab696e2012-03-27 21:10:07 +00002286 ModuleList module_list;
2287 module_list.Append(module_sp);
2288 target_sp->ModulesDidLoad (module_list);
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002289 }
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002290 }
2291 }
Greg Clayton0416bdf2012-01-30 09:04:36 +00002292 else
2293 {
2294 sb_error.SetErrorStringWithFormat ("invalid module");
2295 }
2296
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002297 }
2298 else
2299 {
2300 sb_error.SetErrorStringWithFormat ("invalid target");
2301 }
2302 return sb_error;
2303}
2304
2305SBError
2306SBTarget::ClearModuleLoadAddress (lldb::SBModule module)
2307{
2308 SBError sb_error;
2309
2310 char path[PATH_MAX];
Greg Clayton0416bdf2012-01-30 09:04:36 +00002311 TargetSP target_sp(GetSP());
2312 if (target_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002313 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002314 ModuleSP module_sp (module.GetSP());
2315 if (module_sp)
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002316 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002317 ObjectFile *objfile = module_sp->GetObjectFile();
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002318 if (objfile)
2319 {
2320 SectionList *section_list = objfile->GetSectionList();
2321 if (section_list)
2322 {
2323 const size_t num_sections = section_list->GetSize();
2324 for (size_t sect_idx = 0; sect_idx < num_sections; ++sect_idx)
2325 {
2326 SectionSP section_sp (section_list->GetSectionAtIndex(sect_idx));
2327 if (section_sp)
Greg Clayton545762f2012-07-07 01:24:12 +00002328 target_sp->GetSectionLoadList().SetSectionUnloaded (section_sp);
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002329 }
2330 }
2331 else
2332 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002333 module_sp->GetFileSpec().GetPath (path, sizeof(path));
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002334 sb_error.SetErrorStringWithFormat ("no sections in object file '%s'", path);
2335 }
2336 }
2337 else
2338 {
Greg Clayton0416bdf2012-01-30 09:04:36 +00002339 module_sp->GetFileSpec().GetPath (path, sizeof(path));
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002340 sb_error.SetErrorStringWithFormat ("no object file for module '%s'", path);
2341 }
2342 }
Greg Clayton0416bdf2012-01-30 09:04:36 +00002343 else
2344 {
2345 sb_error.SetErrorStringWithFormat ("invalid module");
2346 }
Greg Clayton3e8c25f2011-09-24 00:52:29 +00002347 }
2348 else
2349 {
2350 sb_error.SetErrorStringWithFormat ("invalid target");
2351 }
2352 return sb_error;
2353}
2354
2355