blob: 9ca16d54522167a0bc89732a0e502a482709bac2 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- ObjectFile.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
10#include "lldb/lldb-private.h"
Greg Claytone40b6422011-09-18 18:59:15 +000011#include "lldb/lldb-private-log.h"
Greg Claytondb2dc2b2012-01-12 05:25:17 +000012#include "lldb/Core/DataBuffer.h"
Greg Claytonb5a8f142012-02-05 02:38:54 +000013#include "lldb/Core/DataBufferHeap.h"
Greg Claytone40b6422011-09-18 18:59:15 +000014#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000015#include "lldb/Core/Module.h"
16#include "lldb/Core/PluginManager.h"
17#include "lldb/Core/RegularExpression.h"
Greg Clayton49ce8962012-08-29 21:13:06 +000018#include "lldb/Core/Section.h"
Chris Lattner24943d22010-06-08 16:52:24 +000019#include "lldb/Core/Timer.h"
20#include "lldb/Symbol/ObjectFile.h"
21#include "lldb/Symbol/ObjectContainer.h"
22#include "lldb/Symbol/SymbolFile.h"
Greg Claytonb5a8f142012-02-05 02:38:54 +000023#include "lldb/Target/Process.h"
Greg Clayton49ce8962012-08-29 21:13:06 +000024#include "Plugins/ObjectContainer/BSD-Archive/ObjectContainerBSDArchive.h"
Chris Lattner24943d22010-06-08 16:52:24 +000025
26using namespace lldb;
27using namespace lldb_private;
28
Greg Claytone40b6422011-09-18 18:59:15 +000029ObjectFileSP
Greg Clayton3508c382012-02-24 01:59:29 +000030ObjectFile::FindPlugin (const lldb::ModuleSP &module_sp, const FileSpec* file, addr_t file_offset, addr_t file_size, DataBufferSP &file_data_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000031{
Greg Claytone40b6422011-09-18 18:59:15 +000032 ObjectFileSP object_file_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000033
Greg Clayton3508c382012-02-24 01:59:29 +000034 if (module_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000035 {
Greg Clayton3508c382012-02-24 01:59:29 +000036 Timer scoped_timer (__PRETTY_FUNCTION__,
Daniel Malea5f35a4b2012-11-29 21:49:15 +000037 "ObjectFile::FindPlugin (module = %s/%s, file = %p, file_offset = 0x%8.8" PRIx64 ", file_size = 0x%8.8" PRIx64 ")",
Greg Clayton3508c382012-02-24 01:59:29 +000038 module_sp->GetFileSpec().GetDirectory().AsCString(),
39 module_sp->GetFileSpec().GetFilename().AsCString(),
Jason Molendaef9eb802012-09-11 06:35:15 +000040 file, (uint64_t) file_offset, (uint64_t) file_size);
Chris Lattner24943d22010-06-08 16:52:24 +000041 if (file)
42 {
Greg Claytondb2dc2b2012-01-12 05:25:17 +000043 // Memory map the entire file contents
Greg Clayton49ce8962012-08-29 21:13:06 +000044 if (!file_data_sp && file_size > 0)
Greg Claytondb2dc2b2012-01-12 05:25:17 +000045 {
46 assert (file_offset == 0);
47 file_data_sp = file->MemoryMapFileContents(file_offset, file_size);
48 }
Chris Lattner24943d22010-06-08 16:52:24 +000049
Greg Claytondb2dc2b2012-01-12 05:25:17 +000050 if (!file_data_sp || file_data_sp->GetByteSize() == 0)
Chris Lattner24943d22010-06-08 16:52:24 +000051 {
52 // Check for archive file with format "/path/to/archive.a(object.o)"
53 char path_with_object[PATH_MAX*2];
Greg Clayton3508c382012-02-24 01:59:29 +000054 module_sp->GetFileSpec().GetPath(path_with_object, sizeof(path_with_object));
Chris Lattner24943d22010-06-08 16:52:24 +000055
Greg Clayton49ce8962012-08-29 21:13:06 +000056 FileSpec archive_file;
57 ConstString archive_object;
Greg Clayton3cf7ab52013-02-06 00:38:25 +000058 const bool must_exist = true;
59 if (ObjectFile::SplitArchivePathWithObject (path_with_object, archive_file, archive_object, must_exist))
Chris Lattner24943d22010-06-08 16:52:24 +000060 {
Greg Clayton49ce8962012-08-29 21:13:06 +000061 file_size = archive_file.GetByteSize();
62 if (file_size > 0)
Chris Lattner24943d22010-06-08 16:52:24 +000063 {
Greg Clayton49ce8962012-08-29 21:13:06 +000064 module_sp->SetFileSpecAndObjectName (archive_file, archive_object);
65 file_data_sp = archive_file.MemoryMapFileContents(file_offset, file_size);
Chris Lattner24943d22010-06-08 16:52:24 +000066 }
67 }
68 }
69
Greg Claytondb2dc2b2012-01-12 05:25:17 +000070 if (file_data_sp && file_data_sp->GetByteSize() > 0)
Chris Lattner24943d22010-06-08 16:52:24 +000071 {
Greg Claytondb2dc2b2012-01-12 05:25:17 +000072 uint32_t idx;
Chris Lattner24943d22010-06-08 16:52:24 +000073
Greg Claytondb2dc2b2012-01-12 05:25:17 +000074 // Check if this is a normal object file by iterating through
75 // all object file plugin instances.
76 ObjectFileCreateInstance create_object_file_callback;
77 for (idx = 0; (create_object_file_callback = PluginManager::GetObjectFileCreateCallbackAtIndex(idx)) != NULL; ++idx)
78 {
Greg Clayton3508c382012-02-24 01:59:29 +000079 object_file_sp.reset (create_object_file_callback(module_sp, file_data_sp, file, file_offset, file_size));
Greg Claytondb2dc2b2012-01-12 05:25:17 +000080 if (object_file_sp.get())
81 return object_file_sp;
82 }
Chris Lattner24943d22010-06-08 16:52:24 +000083
Greg Claytondb2dc2b2012-01-12 05:25:17 +000084 // Check if this is a object container by iterating through
85 // all object container plugin instances and then trying to get
86 // an object file from the container.
87 ObjectContainerCreateInstance create_object_container_callback;
88 for (idx = 0; (create_object_container_callback = PluginManager::GetObjectContainerCreateCallbackAtIndex(idx)) != NULL; ++idx)
89 {
Greg Clayton3508c382012-02-24 01:59:29 +000090 std::auto_ptr<ObjectContainer> object_container_ap(create_object_container_callback(module_sp, file_data_sp, file, file_offset, file_size));
Chris Lattner24943d22010-06-08 16:52:24 +000091
Greg Claytondb2dc2b2012-01-12 05:25:17 +000092 if (object_container_ap.get())
93 object_file_sp = object_container_ap->GetObjectFile(file);
94
95 if (object_file_sp.get())
96 return object_file_sp;
97 }
Chris Lattner24943d22010-06-08 16:52:24 +000098 }
99 }
100 }
Greg Claytone40b6422011-09-18 18:59:15 +0000101 // We didn't find it, so clear our shared pointer in case it
102 // contains anything and return an empty shared pointer
103 object_file_sp.reset();
104 return object_file_sp;
105}
106
Greg Claytonb5a8f142012-02-05 02:38:54 +0000107ObjectFileSP
Greg Clayton3508c382012-02-24 01:59:29 +0000108ObjectFile::FindPlugin (const lldb::ModuleSP &module_sp,
Greg Claytonb5a8f142012-02-05 02:38:54 +0000109 const ProcessSP &process_sp,
110 lldb::addr_t header_addr,
111 DataBufferSP &file_data_sp)
112{
Greg Claytonb5a8f142012-02-05 02:38:54 +0000113 ObjectFileSP object_file_sp;
114
Greg Clayton3508c382012-02-24 01:59:29 +0000115 if (module_sp)
Greg Claytonb5a8f142012-02-05 02:38:54 +0000116 {
Greg Clayton3508c382012-02-24 01:59:29 +0000117 Timer scoped_timer (__PRETTY_FUNCTION__,
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000118 "ObjectFile::FindPlugin (module = %s/%s, process = %p, header_addr = 0x%" PRIx64 ")",
Greg Clayton3508c382012-02-24 01:59:29 +0000119 module_sp->GetFileSpec().GetDirectory().AsCString(),
120 module_sp->GetFileSpec().GetFilename().AsCString(),
121 process_sp.get(), header_addr);
Greg Claytonb5a8f142012-02-05 02:38:54 +0000122 uint32_t idx;
123
124 // Check if this is a normal object file by iterating through
125 // all object file plugin instances.
126 ObjectFileCreateMemoryInstance create_callback;
127 for (idx = 0; (create_callback = PluginManager::GetObjectFileCreateMemoryCallbackAtIndex(idx)) != NULL; ++idx)
128 {
Greg Clayton3508c382012-02-24 01:59:29 +0000129 object_file_sp.reset (create_callback(module_sp, file_data_sp, process_sp, header_addr));
Greg Claytonb5a8f142012-02-05 02:38:54 +0000130 if (object_file_sp.get())
131 return object_file_sp;
132 }
133
134 }
135 // We didn't find it, so clear our shared pointer in case it
136 // contains anything and return an empty shared pointer
137 object_file_sp.reset();
138 return object_file_sp;
139}
140
Greg Clayton3508c382012-02-24 01:59:29 +0000141ObjectFile::ObjectFile (const lldb::ModuleSP &module_sp,
Greg Claytone40b6422011-09-18 18:59:15 +0000142 const FileSpec *file_spec_ptr,
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000143 addr_t file_offset,
144 addr_t file_size,
145 DataBufferSP& file_data_sp) :
Greg Clayton3508c382012-02-24 01:59:29 +0000146 ModuleChild (module_sp),
Greg Claytone40b6422011-09-18 18:59:15 +0000147 m_file (), // This file could be different from the original module's file
148 m_type (eTypeInvalid),
149 m_strata (eStrataInvalid),
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000150 m_offset (file_offset),
151 m_length (file_size),
152 m_data (),
Greg Claytonb5a8f142012-02-05 02:38:54 +0000153 m_unwind_table (*this),
154 m_process_wp(),
Greg Clayton46c9a352012-02-09 06:16:32 +0000155 m_memory_addr (LLDB_INVALID_ADDRESS)
Greg Claytone40b6422011-09-18 18:59:15 +0000156{
157 if (file_spec_ptr)
158 m_file = *file_spec_ptr;
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000159 if (file_data_sp)
160 m_data.SetData (file_data_sp, file_offset, file_size);
Greg Claytone40b6422011-09-18 18:59:15 +0000161 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
162 if (log)
163 {
164 if (m_file)
165 {
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000166 log->Printf ("%p ObjectFile::ObjectFile () module = %s/%s, file = %s/%s, offset = 0x%8.8" PRIx64 ", size = %" PRIu64 "\n",
Greg Claytone40b6422011-09-18 18:59:15 +0000167 this,
Greg Clayton3508c382012-02-24 01:59:29 +0000168 module_sp->GetFileSpec().GetDirectory().AsCString(),
169 module_sp->GetFileSpec().GetFilename().AsCString(),
Greg Claytone40b6422011-09-18 18:59:15 +0000170 m_file.GetDirectory().AsCString(),
171 m_file.GetFilename().AsCString(),
172 m_offset,
173 m_length);
174 }
175 else
176 {
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000177 log->Printf ("%p ObjectFile::ObjectFile () module = %s/%s, file = <NULL>, offset = 0x%8.8" PRIx64 ", size = %" PRIu64 "\n",
Greg Claytone40b6422011-09-18 18:59:15 +0000178 this,
Greg Clayton3508c382012-02-24 01:59:29 +0000179 module_sp->GetFileSpec().GetDirectory().AsCString(),
180 module_sp->GetFileSpec().GetFilename().AsCString(),
Greg Claytone40b6422011-09-18 18:59:15 +0000181 m_offset,
182 m_length);
183 }
184 }
185}
186
Greg Claytonb5a8f142012-02-05 02:38:54 +0000187
Greg Clayton3508c382012-02-24 01:59:29 +0000188ObjectFile::ObjectFile (const lldb::ModuleSP &module_sp,
Greg Claytonb5a8f142012-02-05 02:38:54 +0000189 const ProcessSP &process_sp,
190 lldb::addr_t header_addr,
191 DataBufferSP& header_data_sp) :
Greg Clayton3508c382012-02-24 01:59:29 +0000192 ModuleChild (module_sp),
Greg Claytonb5a8f142012-02-05 02:38:54 +0000193 m_file (),
194 m_type (eTypeInvalid),
195 m_strata (eStrataInvalid),
196 m_offset (header_addr),
197 m_length (0),
198 m_data (),
199 m_unwind_table (*this),
200 m_process_wp (process_sp),
Greg Clayton46c9a352012-02-09 06:16:32 +0000201 m_memory_addr (header_addr)
Greg Claytonb5a8f142012-02-05 02:38:54 +0000202{
203 if (header_data_sp)
204 m_data.SetData (header_data_sp, 0, header_data_sp->GetByteSize());
205 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
206 if (log)
207 {
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000208 log->Printf ("%p ObjectFile::ObjectFile () module = %s/%s, process = %p, header_addr = 0x%" PRIx64 "\n",
Greg Claytonb5a8f142012-02-05 02:38:54 +0000209 this,
Greg Clayton3508c382012-02-24 01:59:29 +0000210 module_sp->GetFileSpec().GetDirectory().AsCString(),
211 module_sp->GetFileSpec().GetFilename().AsCString(),
Greg Claytonb5a8f142012-02-05 02:38:54 +0000212 process_sp.get(),
213 m_offset);
214 }
215}
216
217
Greg Claytone40b6422011-09-18 18:59:15 +0000218ObjectFile::~ObjectFile()
219{
220 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
221 if (log)
Greg Claytonc9b798c2012-11-28 00:44:24 +0000222 log->Printf ("%p ObjectFile::~ObjectFile ()\n", this);
Chris Lattner24943d22010-06-08 16:52:24 +0000223}
Jim Ingham7508e732010-08-09 23:31:02 +0000224
225bool
226ObjectFile::SetModulesArchitecture (const ArchSpec &new_arch)
227{
Greg Clayton3508c382012-02-24 01:59:29 +0000228 ModuleSP module_sp (GetModule());
229 if (module_sp)
230 return module_sp->SetArchitecture (new_arch);
231 return false;
Jim Ingham7508e732010-08-09 23:31:02 +0000232}
233
Greg Claytonb3448432011-03-24 21:19:54 +0000234AddressClass
Greg Claytone40b6422011-09-18 18:59:15 +0000235ObjectFile::GetAddressClass (addr_t file_addr)
Greg Claytonb1888f22011-03-19 01:12:21 +0000236{
237 Symtab *symtab = GetSymtab();
238 if (symtab)
239 {
240 Symbol *symbol = symtab->FindSymbolContainingFileAddress(file_addr);
241 if (symbol)
242 {
Greg Clayton0c31d3d2012-03-07 21:03:09 +0000243 if (symbol->ValueIsAddress())
Greg Claytonb1888f22011-03-19 01:12:21 +0000244 {
Greg Clayton0c31d3d2012-03-07 21:03:09 +0000245 const SectionSP section_sp (symbol->GetAddress().GetSection());
Greg Clayton3508c382012-02-24 01:59:29 +0000246 if (section_sp)
Greg Claytonb1888f22011-03-19 01:12:21 +0000247 {
Greg Clayton3508c382012-02-24 01:59:29 +0000248 const SectionType section_type = section_sp->GetType();
Greg Claytonb1888f22011-03-19 01:12:21 +0000249 switch (section_type)
250 {
251 case eSectionTypeInvalid: return eAddressClassUnknown;
252 case eSectionTypeCode: return eAddressClassCode;
253 case eSectionTypeContainer: return eAddressClassUnknown;
Greg Clayton24a6bd92011-10-27 17:55:14 +0000254 case eSectionTypeData:
255 case eSectionTypeDataCString:
256 case eSectionTypeDataCStringPointers:
257 case eSectionTypeDataSymbolAddress:
258 case eSectionTypeData4:
259 case eSectionTypeData8:
260 case eSectionTypeData16:
261 case eSectionTypeDataPointers:
262 case eSectionTypeZeroFill:
263 case eSectionTypeDataObjCMessageRefs:
264 case eSectionTypeDataObjCCFStrings:
265 return eAddressClassData;
266 case eSectionTypeDebug:
267 case eSectionTypeDWARFDebugAbbrev:
268 case eSectionTypeDWARFDebugAranges:
269 case eSectionTypeDWARFDebugFrame:
270 case eSectionTypeDWARFDebugInfo:
271 case eSectionTypeDWARFDebugLine:
272 case eSectionTypeDWARFDebugLoc:
273 case eSectionTypeDWARFDebugMacInfo:
274 case eSectionTypeDWARFDebugPubNames:
275 case eSectionTypeDWARFDebugPubTypes:
276 case eSectionTypeDWARFDebugRanges:
277 case eSectionTypeDWARFDebugStr:
278 case eSectionTypeDWARFAppleNames:
279 case eSectionTypeDWARFAppleTypes:
280 case eSectionTypeDWARFAppleNamespaces:
281 case eSectionTypeDWARFAppleObjC:
282 return eAddressClassDebug;
Greg Claytonb1888f22011-03-19 01:12:21 +0000283 case eSectionTypeEHFrame: return eAddressClassRuntime;
284 case eSectionTypeOther: return eAddressClassUnknown;
285 }
286 }
287 }
288
Greg Claytonb3448432011-03-24 21:19:54 +0000289 const SymbolType symbol_type = symbol->GetType();
Greg Claytonb1888f22011-03-19 01:12:21 +0000290 switch (symbol_type)
291 {
292 case eSymbolTypeAny: return eAddressClassUnknown;
293 case eSymbolTypeAbsolute: return eAddressClassUnknown;
Greg Claytonb1888f22011-03-19 01:12:21 +0000294 case eSymbolTypeCode: return eAddressClassCode;
295 case eSymbolTypeTrampoline: return eAddressClassCode;
296 case eSymbolTypeData: return eAddressClassData;
297 case eSymbolTypeRuntime: return eAddressClassRuntime;
298 case eSymbolTypeException: return eAddressClassRuntime;
299 case eSymbolTypeSourceFile: return eAddressClassDebug;
300 case eSymbolTypeHeaderFile: return eAddressClassDebug;
301 case eSymbolTypeObjectFile: return eAddressClassDebug;
302 case eSymbolTypeCommonBlock: return eAddressClassDebug;
303 case eSymbolTypeBlock: return eAddressClassDebug;
304 case eSymbolTypeLocal: return eAddressClassData;
305 case eSymbolTypeParam: return eAddressClassData;
306 case eSymbolTypeVariable: return eAddressClassData;
307 case eSymbolTypeVariableType: return eAddressClassDebug;
308 case eSymbolTypeLineEntry: return eAddressClassDebug;
309 case eSymbolTypeLineHeader: return eAddressClassDebug;
310 case eSymbolTypeScopeBegin: return eAddressClassDebug;
311 case eSymbolTypeScopeEnd: return eAddressClassDebug;
312 case eSymbolTypeAdditional: return eAddressClassUnknown;
313 case eSymbolTypeCompiler: return eAddressClassDebug;
314 case eSymbolTypeInstrumentation:return eAddressClassDebug;
315 case eSymbolTypeUndefined: return eAddressClassUnknown;
Greg Clayton3f69eac2011-12-03 02:30:59 +0000316 case eSymbolTypeObjCClass: return eAddressClassRuntime;
317 case eSymbolTypeObjCMetaClass: return eAddressClassRuntime;
318 case eSymbolTypeObjCIVar: return eAddressClassRuntime;
Greg Claytonb1888f22011-03-19 01:12:21 +0000319 }
320 }
321 }
322 return eAddressClassUnknown;
323}
324
Greg Claytonb5a8f142012-02-05 02:38:54 +0000325DataBufferSP
326ObjectFile::ReadMemory (const ProcessSP &process_sp, lldb::addr_t addr, size_t byte_size)
327{
328 DataBufferSP data_sp;
329 if (process_sp)
330 {
331 std::auto_ptr<DataBufferHeap> data_ap (new DataBufferHeap (byte_size, 0));
332 Error error;
333 const size_t bytes_read = process_sp->ReadMemory (addr,
334 data_ap->GetBytes(),
335 data_ap->GetByteSize(),
336 error);
337 if (bytes_read == byte_size)
338 data_sp.reset (data_ap.release());
339 }
340 return data_sp;
341}
342
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000343size_t
344ObjectFile::GetData (off_t offset, size_t length, DataExtractor &data) const
345{
346 // The entire file has already been mmap'ed into m_data, so just copy from there
347 // as the back mmap buffer will be shared with shared pointers.
348 return data.SetData (m_data, offset, length);
349}
350
351size_t
352ObjectFile::CopyData (off_t offset, size_t length, void *dst) const
353{
354 // The entire file has already been mmap'ed into m_data, so just copy from there
355 return m_data.CopyByteOrderedData (offset, length, dst, length, lldb::endian::InlHostByteOrder());
356}
Greg Claytonb1888f22011-03-19 01:12:21 +0000357
Greg Claytonb5a8f142012-02-05 02:38:54 +0000358
359size_t
360ObjectFile::ReadSectionData (const Section *section, off_t section_offset, void *dst, size_t dst_len) const
361{
Greg Clayton46c9a352012-02-09 06:16:32 +0000362 if (IsInMemory())
Greg Claytonb5a8f142012-02-05 02:38:54 +0000363 {
364 ProcessSP process_sp (m_process_wp.lock());
365 if (process_sp)
366 {
367 Error error;
Greg Clayton2ddb2b82013-02-01 21:38:35 +0000368 const addr_t base_load_addr = section->GetLoadBaseAddress (&process_sp->GetTarget());
369 if (base_load_addr != LLDB_INVALID_ADDRESS)
370 return process_sp->ReadMemory (base_load_addr + section_offset, dst, dst_len, error);
Greg Claytonb5a8f142012-02-05 02:38:54 +0000371 }
372 }
373 else
374 {
Greg Clayton3383c172012-02-21 17:34:25 +0000375 const uint64_t section_file_size = section->GetFileSize();
376 if (section_offset < section_file_size)
377 {
378 const uint64_t section_bytes_left = section_file_size - section_offset;
379 uint64_t section_dst_len = dst_len;
380 if (section_dst_len > section_bytes_left)
381 section_dst_len = section_bytes_left;
382 return CopyData (section->GetFileOffset() + section_offset, section_dst_len, dst);
383 }
Sean Callanan1e526002013-01-04 23:20:01 +0000384 else
385 {
386 if (section->GetType() == eSectionTypeZeroFill)
387 {
388 const uint64_t section_size = section->GetByteSize();
389 const uint64_t section_bytes_left = section_size - section_offset;
390 uint64_t section_dst_len = dst_len;
391 if (section_dst_len > section_bytes_left)
392 section_dst_len = section_bytes_left;
393 bzero(dst, section_dst_len);
394 return section_dst_len;
395 }
396 }
Greg Claytonb5a8f142012-02-05 02:38:54 +0000397 }
398 return 0;
399}
400
401//----------------------------------------------------------------------
402// Get the section data the file on disk
403//----------------------------------------------------------------------
404size_t
405ObjectFile::ReadSectionData (const Section *section, DataExtractor& section_data) const
406{
Greg Clayton46c9a352012-02-09 06:16:32 +0000407 if (IsInMemory())
Greg Claytonb5a8f142012-02-05 02:38:54 +0000408 {
409 ProcessSP process_sp (m_process_wp.lock());
410 if (process_sp)
411 {
Greg Clayton2ddb2b82013-02-01 21:38:35 +0000412 const addr_t base_load_addr = section->GetLoadBaseAddress (&process_sp->GetTarget());
413 if (base_load_addr != LLDB_INVALID_ADDRESS)
Greg Claytonb5a8f142012-02-05 02:38:54 +0000414 {
Greg Clayton2ddb2b82013-02-01 21:38:35 +0000415 DataBufferSP data_sp (ReadMemory (process_sp, base_load_addr, section->GetByteSize()));
416 if (data_sp)
417 {
418 section_data.SetData (data_sp, 0, data_sp->GetByteSize());
419 section_data.SetByteOrder (process_sp->GetByteOrder());
420 section_data.SetAddressByteSize (process_sp->GetAddressByteSize());
421 return section_data.GetByteSize();
422 }
Greg Claytonb5a8f142012-02-05 02:38:54 +0000423 }
424 }
425 }
426 else
427 {
428 // The object file now contains a full mmap'ed copy of the object file data, so just use this
429 return MemoryMapSectionData (section, section_data);
430 }
431 section_data.Clear();
432 return 0;
433}
434
435size_t
436ObjectFile::MemoryMapSectionData (const Section *section, DataExtractor& section_data) const
437{
Greg Clayton46c9a352012-02-09 06:16:32 +0000438 if (IsInMemory())
Greg Claytonb5a8f142012-02-05 02:38:54 +0000439 {
440 return ReadSectionData (section, section_data);
441 }
442 else
443 {
444 // The object file now contains a full mmap'ed copy of the object file data, so just use this
Greg Clayton23d90ae2012-03-27 02:40:46 +0000445 return GetData(section->GetFileOffset(), section->GetFileSize(), section_data);
Greg Claytonb5a8f142012-02-05 02:38:54 +0000446 }
447 section_data.Clear();
448 return 0;
449}
450
Greg Clayton49ce8962012-08-29 21:13:06 +0000451
452bool
Greg Clayton3cf7ab52013-02-06 00:38:25 +0000453ObjectFile::SplitArchivePathWithObject (const char *path_with_object, FileSpec &archive_file, ConstString &archive_object, bool must_exist)
Greg Clayton49ce8962012-08-29 21:13:06 +0000454{
455 RegularExpression g_object_regex("(.*)\\(([^\\)]+)\\)$");
456 if (g_object_regex.Execute (path_with_object, 2))
457 {
458 std::string path;
459 std::string obj;
460 if (g_object_regex.GetMatchAtIndex (path_with_object, 1, path) &&
461 g_object_regex.GetMatchAtIndex (path_with_object, 2, obj))
462 {
463 archive_file.SetFile (path.c_str(), false);
464 archive_object.SetCString(obj.c_str());
Greg Clayton3cf7ab52013-02-06 00:38:25 +0000465 if (must_exist && !archive_file.Exists())
466 return false;
Greg Clayton49ce8962012-08-29 21:13:06 +0000467 return true;
468 }
469 }
470 return false;
471}
472