blob: 4542b46d988e87f1138c780850c9d8e6b45ac994 [file] [log] [blame]
Misha Brukman46453792003-09-22 23:44:46 +00001//===- ReaderWrappers.cpp - Parse bytecode from file or buffer -----------===//
Misha Brukman8a96c532005-04-21 21:44:41 +00002//
John Criswellb576c942003-10-20 19:43:21 +00003// The LLVM Compiler Infrastructure
4//
5// This file was developed by the LLVM research group and is distributed under
6// the University of Illinois Open Source License. See LICENSE.TXT for details.
Misha Brukman8a96c532005-04-21 21:44:41 +00007//
John Criswellb576c942003-10-20 19:43:21 +00008//===----------------------------------------------------------------------===//
Misha Brukman46453792003-09-22 23:44:46 +00009//
10// This file implements loading and parsing a bytecode file and parsing a
11// bytecode module from a given buffer.
12//
13//===----------------------------------------------------------------------===//
14
Reid Spencerdf45a542004-06-29 23:24:14 +000015#include "llvm/Bytecode/Analyzer.h"
Chris Lattnerdeab9a72003-11-19 16:06:55 +000016#include "llvm/Bytecode/Reader.h"
Reid Spencerdf45a542004-06-29 23:24:14 +000017#include "Reader.h"
Chris Lattnercb7e2e22003-10-18 05:54:18 +000018#include "llvm/Module.h"
19#include "llvm/Instructions.h"
Reid Spencer551ccae2004-09-01 22:55:40 +000020#include "llvm/ADT/StringExtras.h"
Chris Lattner0d3382a2007-02-07 19:49:01 +000021#include "llvm/Support/Compressor.h"
Reid Spencer9153f8f2004-12-13 18:25:27 +000022#include "llvm/System/MappedFile.h"
Reid Spencer32f55532006-06-07 23:18:34 +000023#include "llvm/System/Program.h"
Chris Lattner2d6481c2003-12-29 21:35:05 +000024#include <cerrno>
Duraid Madina0f7bfba2005-12-26 14:23:22 +000025#include <memory>
Chris Lattnerdeab9a72003-11-19 16:06:55 +000026using namespace llvm;
Brian Gaeked0fde302003-11-11 22:41:34 +000027
Chris Lattnercb7e2e22003-10-18 05:54:18 +000028//===----------------------------------------------------------------------===//
29// BytecodeFileReader - Read from an mmap'able file descriptor.
30//
31
Misha Brukman12c29d12003-09-22 23:38:23 +000032namespace {
Misha Brukman12c29d12003-09-22 23:38:23 +000033 /// BytecodeFileReader - parses a bytecode file from a file
34 ///
Reid Spencerdf45a542004-06-29 23:24:14 +000035 class BytecodeFileReader : public BytecodeReader {
Misha Brukman12c29d12003-09-22 23:38:23 +000036 private:
Reid Spencer0b5a5042006-08-25 17:43:11 +000037 std::string fileName;
Reid Spencer9153f8f2004-12-13 18:25:27 +000038 sys::MappedFile mapFile;
Misha Brukman12c29d12003-09-22 23:38:23 +000039
40 BytecodeFileReader(const BytecodeFileReader&); // Do not implement
Misha Brukman5c344412003-09-23 15:09:26 +000041 void operator=(const BytecodeFileReader &BFR); // Do not implement
Misha Brukman12c29d12003-09-22 23:38:23 +000042
43 public:
Reid Spencerdf45a542004-06-29 23:24:14 +000044 BytecodeFileReader(const std::string &Filename, llvm::BytecodeHandler* H=0);
Reid Spencer0b5a5042006-08-25 17:43:11 +000045 bool read(std::string* ErrMsg);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +000046
47 void freeState() {
48 BytecodeReader::freeState();
49 mapFile.close();
50 }
Misha Brukman12c29d12003-09-22 23:38:23 +000051 };
Misha Brukman12c29d12003-09-22 23:38:23 +000052}
53
Reid Spencerdf45a542004-06-29 23:24:14 +000054BytecodeFileReader::BytecodeFileReader(const std::string &Filename,
Chris Lattnerf0edc6c2006-10-12 18:32:30 +000055 llvm::BytecodeHandler* H)
56 : BytecodeReader(H), fileName(Filename) {
Reid Spencer0b5a5042006-08-25 17:43:11 +000057}
58
59bool BytecodeFileReader::read(std::string* ErrMsg) {
60 if (mapFile.open(sys::Path(fileName), sys::MappedFile::READ_ACCESS, ErrMsg))
61 return true;
62 if (!mapFile.map(ErrMsg)) {
63 mapFile.close();
64 return true;
Reid Spencerb152fd22006-08-22 16:10:12 +000065 }
Reid Spencer0b5a5042006-08-25 17:43:11 +000066 unsigned char* buffer = reinterpret_cast<unsigned char*>(mapFile.base());
Chris Lattner0d3382a2007-02-07 19:49:01 +000067 return ParseBytecode(buffer, mapFile.size(), fileName,
68 Compressor::decompressToNewBuffer, ErrMsg);
Misha Brukman12c29d12003-09-22 23:38:23 +000069}
70
Chris Lattnercb7e2e22003-10-18 05:54:18 +000071//===----------------------------------------------------------------------===//
72// BytecodeBufferReader - Read from a memory buffer
73//
Misha Brukmand57308a2003-09-23 16:13:28 +000074
75namespace {
76 /// BytecodeBufferReader - parses a bytecode file from a buffer
77 ///
Reid Spencerdf45a542004-06-29 23:24:14 +000078 class BytecodeBufferReader : public BytecodeReader {
Misha Brukmand57308a2003-09-23 16:13:28 +000079 private:
80 const unsigned char *Buffer;
Reid Spencer0b5a5042006-08-25 17:43:11 +000081 const unsigned char *Buf;
82 unsigned Length;
83 std::string ModuleID;
Misha Brukmand57308a2003-09-23 16:13:28 +000084 bool MustDelete;
85
86 BytecodeBufferReader(const BytecodeBufferReader&); // Do not implement
87 void operator=(const BytecodeBufferReader &BFR); // Do not implement
88
89 public:
90 BytecodeBufferReader(const unsigned char *Buf, unsigned Length,
Reid Spencerdf45a542004-06-29 23:24:14 +000091 const std::string &ModuleID,
Reid Spencer97c7d742004-07-04 11:03:03 +000092 llvm::BytecodeHandler* Handler = 0);
Misha Brukmand57308a2003-09-23 16:13:28 +000093 ~BytecodeBufferReader();
94
Reid Spencer0b5a5042006-08-25 17:43:11 +000095 bool read(std::string* ErrMsg);
96
Misha Brukmand57308a2003-09-23 16:13:28 +000097 };
98}
99
Reid Spencer0b5a5042006-08-25 17:43:11 +0000100BytecodeBufferReader::BytecodeBufferReader(const unsigned char *buf,
101 unsigned len,
102 const std::string &modID,
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000103 llvm::BytecodeHandler *H)
104 : BytecodeReader(H), Buffer(0), Buf(buf), Length(len), ModuleID(modID)
105 , MustDelete(false) {
Reid Spencer0b5a5042006-08-25 17:43:11 +0000106}
107
108BytecodeBufferReader::~BytecodeBufferReader() {
109 if (MustDelete) delete [] Buffer;
110}
111
112bool
113BytecodeBufferReader::read(std::string* ErrMsg) {
Misha Brukmand57308a2003-09-23 16:13:28 +0000114 // If not aligned, allocate a new buffer to hold the bytecode...
115 const unsigned char *ParseBegin = 0;
Reid Spencer9a7e0c52004-08-04 22:56:46 +0000116 if (reinterpret_cast<uint64_t>(Buf) & 3) {
Misha Brukman34ce14b2003-09-24 22:04:02 +0000117 Buffer = new unsigned char[Length+4];
Chris Lattner4eed7932003-09-24 22:34:17 +0000118 unsigned Offset = 4 - ((intptr_t)Buffer & 3); // Make sure it's aligned
Misha Brukmand57308a2003-09-23 16:13:28 +0000119 ParseBegin = Buffer + Offset;
Misha Brukman34ce14b2003-09-24 22:04:02 +0000120 memcpy((unsigned char*)ParseBegin, Buf, Length); // Copy it over
Misha Brukmand57308a2003-09-23 16:13:28 +0000121 MustDelete = true;
122 } else {
123 // If we don't need to copy it over, just use the caller's copy
John Criswell4dcbd5e2003-09-23 21:19:11 +0000124 ParseBegin = Buffer = Buf;
Misha Brukmand57308a2003-09-23 16:13:28 +0000125 MustDelete = false;
126 }
Chris Lattner0d3382a2007-02-07 19:49:01 +0000127 if (ParseBytecode(ParseBegin, Length, ModuleID,
128 Compressor::decompressToNewBuffer, ErrMsg)) {
Misha Brukman7f58de22003-10-08 19:55:47 +0000129 if (MustDelete) delete [] Buffer;
Reid Spencer0b5a5042006-08-25 17:43:11 +0000130 return true;
Misha Brukman7f58de22003-10-08 19:55:47 +0000131 }
Reid Spencer0b5a5042006-08-25 17:43:11 +0000132 return false;
Misha Brukmand57308a2003-09-23 16:13:28 +0000133}
134
Chris Lattnercb7e2e22003-10-18 05:54:18 +0000135//===----------------------------------------------------------------------===//
136// BytecodeStdinReader - Read bytecode from Standard Input
137//
Misha Brukmand57308a2003-09-23 16:13:28 +0000138
139namespace {
140 /// BytecodeStdinReader - parses a bytecode file from stdin
Misha Brukman8a96c532005-04-21 21:44:41 +0000141 ///
Reid Spencerdf45a542004-06-29 23:24:14 +0000142 class BytecodeStdinReader : public BytecodeReader {
Misha Brukmand57308a2003-09-23 16:13:28 +0000143 private:
144 std::vector<unsigned char> FileData;
145 unsigned char *FileBuf;
146
147 BytecodeStdinReader(const BytecodeStdinReader&); // Do not implement
148 void operator=(const BytecodeStdinReader &BFR); // Do not implement
149
150 public:
Reid Spencerdf45a542004-06-29 23:24:14 +0000151 BytecodeStdinReader( llvm::BytecodeHandler* H = 0 );
Reid Spencer0b5a5042006-08-25 17:43:11 +0000152 bool read(std::string* ErrMsg);
Misha Brukmand57308a2003-09-23 16:13:28 +0000153 };
154}
Misha Brukman12c29d12003-09-22 23:38:23 +0000155
Misha Brukman8a96c532005-04-21 21:44:41 +0000156BytecodeStdinReader::BytecodeStdinReader( BytecodeHandler* H )
Reid Spencerdf45a542004-06-29 23:24:14 +0000157 : BytecodeReader(H)
158{
Reid Spencer0b5a5042006-08-25 17:43:11 +0000159}
160
161bool
162BytecodeStdinReader::read(std::string* ErrMsg)
163{
Reid Spencer32f55532006-06-07 23:18:34 +0000164 sys::Program::ChangeStdinToBinary();
Reid Spencer0a834722004-12-21 07:51:33 +0000165 char Buffer[4096*4];
Misha Brukman12c29d12003-09-22 23:38:23 +0000166
167 // Read in all of the data from stdin, we cannot mmap stdin...
Bill Wendlingbcd24982006-12-07 20:28:15 +0000168 while (cin.stream()->good()) {
169 cin.stream()->read(Buffer, 4096*4);
170 int BlockSize = cin.stream()->gcount();
Reid Spencer0a834722004-12-21 07:51:33 +0000171 if (0 >= BlockSize)
172 break;
Misha Brukman12c29d12003-09-22 23:38:23 +0000173 FileData.insert(FileData.end(), Buffer, Buffer+BlockSize);
174 }
175
Reid Spencer0b5a5042006-08-25 17:43:11 +0000176 if (FileData.empty()) {
177 if (ErrMsg)
178 *ErrMsg = "Standard Input is empty!";
179 return true;
180 }
Misha Brukman12c29d12003-09-22 23:38:23 +0000181
Misha Brukman12c29d12003-09-22 23:38:23 +0000182 FileBuf = &FileData[0];
Chris Lattner0d3382a2007-02-07 19:49:01 +0000183 if (ParseBytecode(FileBuf, FileData.size(), "<stdin>",
184 Compressor::decompressToNewBuffer, ErrMsg))
Reid Spencer0b5a5042006-08-25 17:43:11 +0000185 return true;
186 return false;
Misha Brukman12c29d12003-09-22 23:38:23 +0000187}
188
Chris Lattnercb7e2e22003-10-18 05:54:18 +0000189//===----------------------------------------------------------------------===//
Misha Brukmand57308a2003-09-23 16:13:28 +0000190// Wrapper functions
Chris Lattnercb7e2e22003-10-18 05:54:18 +0000191//===----------------------------------------------------------------------===//
Misha Brukmand57308a2003-09-23 16:13:28 +0000192
193/// getBytecodeBufferModuleProvider - lazy function-at-a-time loading from a
194/// buffer
Misha Brukman8a96c532005-04-21 21:44:41 +0000195ModuleProvider*
Chris Lattnerdeab9a72003-11-19 16:06:55 +0000196llvm::getBytecodeBufferModuleProvider(const unsigned char *Buffer,
197 unsigned Length,
Reid Spencerdf45a542004-06-29 23:24:14 +0000198 const std::string &ModuleID,
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000199 std::string *ErrMsg,
200 BytecodeHandler *H) {
Chris Lattnerf3ccb692007-01-07 06:45:57 +0000201 BytecodeBufferReader *rdr =
Reid Spencer0b5a5042006-08-25 17:43:11 +0000202 new BytecodeBufferReader(Buffer, Length, ModuleID, H);
203 if (rdr->read(ErrMsg))
204 return 0;
Chris Lattnerf3ccb692007-01-07 06:45:57 +0000205 return rdr;
Misha Brukman12c29d12003-09-22 23:38:23 +0000206}
207
Misha Brukmand57308a2003-09-23 16:13:28 +0000208/// ParseBytecodeBuffer - Parse a given bytecode buffer
209///
Chris Lattnerdeab9a72003-11-19 16:06:55 +0000210Module *llvm::ParseBytecodeBuffer(const unsigned char *Buffer, unsigned Length,
211 const std::string &ModuleID,
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000212 std::string *ErrMsg) {
213 ModuleProvider *MP =
Reid Spencer0b5a5042006-08-25 17:43:11 +0000214 getBytecodeBufferModuleProvider(Buffer, Length, ModuleID, ErrMsg, 0);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000215 if (!MP) return 0;
Reid Spencer9b84ad12006-12-15 19:49:23 +0000216 Module *M = MP->releaseModule(ErrMsg);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000217 delete MP;
218 return M;
Misha Brukman12c29d12003-09-22 23:38:23 +0000219}
220
Misha Brukmand57308a2003-09-23 16:13:28 +0000221/// getBytecodeModuleProvider - lazy function-at-a-time loading from a file
Misha Brukman12c29d12003-09-22 23:38:23 +0000222///
Reid Spencer0b5a5042006-08-25 17:43:11 +0000223ModuleProvider *
224llvm::getBytecodeModuleProvider(const std::string &Filename,
225 std::string* ErrMsg,
226 BytecodeHandler* H) {
227 // Read from a file
228 if (Filename != std::string("-")) {
Chris Lattnerf3ccb692007-01-07 06:45:57 +0000229 BytecodeFileReader *rdr = new BytecodeFileReader(Filename, H);
Reid Spencer0b5a5042006-08-25 17:43:11 +0000230 if (rdr->read(ErrMsg))
231 return 0;
Chris Lattnerf3ccb692007-01-07 06:45:57 +0000232 return rdr;
Reid Spencer0b5a5042006-08-25 17:43:11 +0000233 }
234
235 // Read from stdin
Chris Lattnerf3ccb692007-01-07 06:45:57 +0000236 BytecodeStdinReader *rdr = new BytecodeStdinReader(H);
Reid Spencer0b5a5042006-08-25 17:43:11 +0000237 if (rdr->read(ErrMsg))
238 return 0;
Chris Lattnerf3ccb692007-01-07 06:45:57 +0000239 return rdr;
Misha Brukman12c29d12003-09-22 23:38:23 +0000240}
241
Misha Brukmand57308a2003-09-23 16:13:28 +0000242/// ParseBytecodeFile - Parse the given bytecode file
243///
Chris Lattnerdeab9a72003-11-19 16:06:55 +0000244Module *llvm::ParseBytecodeFile(const std::string &Filename,
Reid Spencer0b5a5042006-08-25 17:43:11 +0000245 std::string *ErrMsg) {
246 ModuleProvider* MP = getBytecodeModuleProvider(Filename, ErrMsg);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000247 if (!MP) return 0;
Reid Spencer9b84ad12006-12-15 19:49:23 +0000248 Module *M = MP->releaseModule(ErrMsg);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000249 delete MP;
250 return M;
Misha Brukman12c29d12003-09-22 23:38:23 +0000251}
Brian Gaeked0fde302003-11-11 22:41:34 +0000252
Reid Spencerdf45a542004-06-29 23:24:14 +0000253// AnalyzeBytecodeFile - analyze one file
Reid Spencer4542c432004-08-21 20:52:03 +0000254Module* llvm::AnalyzeBytecodeFile(
255 const std::string &Filename, ///< File to analyze
256 BytecodeAnalysis& bca, ///< Statistical output
Reid Spencer0b5a5042006-08-25 17:43:11 +0000257 std::string *ErrMsg, ///< Error output
Misha Brukman5adf0ca2004-09-12 20:56:38 +0000258 std::ostream* output ///< Dump output
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000259) {
Reid Spencer0b5a5042006-08-25 17:43:11 +0000260 BytecodeHandler* AH = createBytecodeAnalyzerHandler(bca,output);
261 ModuleProvider* MP = getBytecodeModuleProvider(Filename, ErrMsg, AH);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000262 if (!MP) return 0;
Reid Spencer9b84ad12006-12-15 19:49:23 +0000263 Module *M = MP->releaseModule(ErrMsg);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000264 delete MP;
265 return M;
Reid Spencerdf45a542004-06-29 23:24:14 +0000266}
267
268// AnalyzeBytecodeBuffer - analyze a buffer
269Module* llvm::AnalyzeBytecodeBuffer(
Reid Spencer4542c432004-08-21 20:52:03 +0000270 const unsigned char* Buffer, ///< Pointer to start of bytecode buffer
271 unsigned Length, ///< Size of the bytecode buffer
272 const std::string& ModuleID, ///< Identifier for the module
273 BytecodeAnalysis& bca, ///< The results of the analysis
Reid Spencer0b5a5042006-08-25 17:43:11 +0000274 std::string* ErrMsg, ///< Errors, if any.
Misha Brukman5adf0ca2004-09-12 20:56:38 +0000275 std::ostream* output ///< Dump output, if any
276)
Reid Spencerdf45a542004-06-29 23:24:14 +0000277{
Reid Spencer0b5a5042006-08-25 17:43:11 +0000278 BytecodeHandler* hdlr = createBytecodeAnalyzerHandler(bca, output);
279 ModuleProvider* MP =
280 getBytecodeBufferModuleProvider(Buffer, Length, ModuleID, ErrMsg, hdlr);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000281 if (!MP) return 0;
Reid Spencer9b84ad12006-12-15 19:49:23 +0000282 Module *M = MP->releaseModule(ErrMsg);
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000283 delete MP;
284 return M;
Reid Spencerdf45a542004-06-29 23:24:14 +0000285}
286
Misha Brukman8a96c532005-04-21 21:44:41 +0000287bool llvm::GetBytecodeDependentLibraries(const std::string &fname,
Reid Spencer0b5a5042006-08-25 17:43:11 +0000288 Module::LibraryListType& deplibs,
289 std::string* ErrMsg) {
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000290 ModuleProvider* MP = getBytecodeModuleProvider(fname, ErrMsg);
Reid Spencer0b5a5042006-08-25 17:43:11 +0000291 if (!MP) {
Reid Spencere0cf59e2004-08-24 22:46:20 +0000292 deplibs.clear();
Reid Spencer0b5a5042006-08-25 17:43:11 +0000293 return true;
Reid Spencere0cf59e2004-08-24 22:46:20 +0000294 }
Reid Spencer9b84ad12006-12-15 19:49:23 +0000295 Module* M = MP->releaseModule(ErrMsg);
Reid Spencer0b5a5042006-08-25 17:43:11 +0000296 deplibs = M->getLibraries();
297 delete M;
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000298 delete MP;
Reid Spencer0b5a5042006-08-25 17:43:11 +0000299 return false;
Reid Spencere0cf59e2004-08-24 22:46:20 +0000300}
301
Chris Lattnere5cea5e2005-02-13 17:42:11 +0000302static void getSymbols(Module*M, std::vector<std::string>& symbols) {
Reid Spencer565ff3d2004-11-14 22:00:48 +0000303 // Loop over global variables
Chris Lattnere4d5c442005-03-15 04:54:21 +0000304 for (Module::global_iterator GI = M->global_begin(), GE=M->global_end(); GI != GE; ++GI)
Reid Spencer5cbf9852007-01-30 20:08:39 +0000305 if (!GI->isDeclaration() && !GI->hasInternalLinkage())
Chris Lattnere5cea5e2005-02-13 17:42:11 +0000306 if (!GI->getName().empty())
307 symbols.push_back(GI->getName());
Reid Spencer565ff3d2004-11-14 22:00:48 +0000308
Chris Lattnere5cea5e2005-02-13 17:42:11 +0000309 // Loop over functions.
310 for (Module::iterator FI = M->begin(), FE = M->end(); FI != FE; ++FI)
Reid Spencer5cbf9852007-01-30 20:08:39 +0000311 if (!FI->isDeclaration() && !FI->hasInternalLinkage())
Chris Lattnere5cea5e2005-02-13 17:42:11 +0000312 if (!FI->getName().empty())
313 symbols.push_back(FI->getName());
Reid Spencer565ff3d2004-11-14 22:00:48 +0000314}
315
Reid Spencer2bcfcbe2004-11-06 08:56:40 +0000316// Get just the externally visible defined symbols from the bytecode
317bool llvm::GetBytecodeSymbols(const sys::Path& fName,
Reid Spencer0b5a5042006-08-25 17:43:11 +0000318 std::vector<std::string>& symbols,
319 std::string* ErrMsg) {
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000320 ModuleProvider *MP = getBytecodeModuleProvider(fName.toString(), ErrMsg);
Reid Spencer0b5a5042006-08-25 17:43:11 +0000321 if (!MP)
322 return true;
Reid Spencer2bcfcbe2004-11-06 08:56:40 +0000323
Chris Lattner0300f3e2006-07-06 21:35:01 +0000324 // Get the module from the provider
Reid Spencer0b5a5042006-08-25 17:43:11 +0000325 Module* M = MP->materializeModule();
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000326 if (M == 0) {
327 delete MP;
Reid Spencer0b5a5042006-08-25 17:43:11 +0000328 return true;
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000329 }
Reid Spencer2bcfcbe2004-11-06 08:56:40 +0000330
Chris Lattner0300f3e2006-07-06 21:35:01 +0000331 // Get the symbols
332 getSymbols(M, symbols);
Reid Spencer2bcfcbe2004-11-06 08:56:40 +0000333
Chris Lattnerf0edc6c2006-10-12 18:32:30 +0000334 // Done with the module.
335 delete MP;
Chris Lattner0300f3e2006-07-06 21:35:01 +0000336 return true;
Reid Spencer2bcfcbe2004-11-06 08:56:40 +0000337}
338
Misha Brukman8a96c532005-04-21 21:44:41 +0000339ModuleProvider*
Reid Spencer766b7932004-11-15 01:20:11 +0000340llvm::GetBytecodeSymbols(const unsigned char*Buffer, unsigned Length,
Reid Spencer5a885782004-11-16 06:41:05 +0000341 const std::string& ModuleID,
Reid Spencer0b5a5042006-08-25 17:43:11 +0000342 std::vector<std::string>& symbols,
343 std::string* ErrMsg) {
344 // Get the module provider
345 ModuleProvider* MP =
346 getBytecodeBufferModuleProvider(Buffer, Length, ModuleID, ErrMsg, 0);
347 if (!MP)
348 return 0;
Reid Spencer565ff3d2004-11-14 22:00:48 +0000349
Reid Spencer0b5a5042006-08-25 17:43:11 +0000350 // Get the module from the provider
351 Module* M = MP->materializeModule();
352 if (M == 0) {
Reid Spencer5a885782004-11-16 06:41:05 +0000353 delete MP;
Reid Spencer0b5a5042006-08-25 17:43:11 +0000354 return 0;
Reid Spencer565ff3d2004-11-14 22:00:48 +0000355 }
Reid Spencer0b5a5042006-08-25 17:43:11 +0000356
357 // Get the symbols
358 getSymbols(M, symbols);
359
360 // Done with the module. Note that ModuleProvider will delete the
361 // Module when it is deleted. Also note that its the caller's responsibility
362 // to delete the ModuleProvider.
363 return MP;
Reid Spencer565ff3d2004-11-14 22:00:48 +0000364}