Fix for dump_syms to ignore line number information for addresses that don't have an enclosing function

git-svn-id: http://google-breakpad.googlecode.com/svn/trunk@293 4c0a9323-5329-0410-9bdc-e9ce6186880e
This commit is contained in:
nealsid 2008-11-03 23:23:50 +00:00
parent 3a283d8f8b
commit c85fb043ed

View file

@ -963,7 +963,9 @@ static BOOL WriteFormat(int fd, const char *fmt, ...) {
NSNumber *nextAddress; NSNumber *nextAddress;
uint64_t nextAddressVal; uint64_t nextAddressVal;
unsigned int addressCount = [sortedAddresses count]; unsigned int addressCount = [sortedAddresses count];
bool insideFunction = false;
for (unsigned int i = 0; i < addressCount; ++i) { for (unsigned int i = 0; i < addressCount; ++i) {
NSNumber *address = [sortedAddresses objectAtIndex:i]; NSNumber *address = [sortedAddresses objectAtIndex:i];
// skip sources that have a starting address of 0 // skip sources that have a starting address of 0
@ -1048,8 +1050,10 @@ static BOOL WriteFormat(int fd, const char *fmt, ...) {
if (line) { if (line) {
if (symbol && functionLength) { if (symbol && functionLength) {
uint64_t functionLengthVal = [functionLength unsignedLongLongValue]; uint64_t functionLengthVal = [functionLength unsignedLongLongValue];
insideFunction = true;
// sanity check to make sure the length we were told does not exceed // sanity check to make sure the length we were told does not exceed
// the space between this function and the next // the space between this function and the next
if (nextFunctionAddress != 0) { if (nextFunctionAddress != 0) {
@ -1066,25 +1070,30 @@ static BOOL WriteFormat(int fd, const char *fmt, ...) {
return NO; return NO;
} }
// Source line // Throw out line number information that doesn't correspond to
uint64_t length = nextAddressVal - addressVal; // any function
if (insideFunction) {
// Source line
uint64_t length = nextAddressVal - addressVal;
// if fileNameToFileIndex/dict has an entry for the // if fileNameToFileIndex/dict has an entry for the
// file/kFunctionFileKey, we're processing DWARF and have stored // file/kFunctionFileKey, we're processing DWARF and have stored
// files for each program counter. If there is no entry, we're // files for each program counter. If there is no entry, we're
// processing STABS and can use the old method of mapping // processing STABS and can use the old method of mapping
// addresses to files(which was basically iterating over a set // addresses to files(which was basically iterating over a set
// of addresses until we reached one that was greater than the // of addresses until we reached one that was greater than the
// high PC of the current file, then moving on to the next file) // high PC of the current file, then moving on to the next file)
NSNumber *fileIndex = [fileNameToFileIndex objectForKey:[dict objectForKey:kFunctionFileKey]]; NSNumber *fileIndex = [fileNameToFileIndex objectForKey:[dict objectForKey:kFunctionFileKey]];
if (!WriteFormat(fd, "%llx %llx %d %d\n", addressVal, length, if (!WriteFormat(fd, "%llx %llx %d %d\n", addressVal, length,
[line unsignedIntValue], fileIndex ? [fileIndex unsignedIntValue] : fileIdx)) [line unsignedIntValue], fileIndex ? [fileIndex unsignedIntValue] : fileIdx))
return NO; return NO;
}
} else { } else {
// PUBLIC <address> <stack-size> <name> // PUBLIC <address> <stack-size> <name>
if (!WriteFormat(fd, "PUBLIC %llx 0 %s\n", addressVal, if (!WriteFormat(fd, "PUBLIC %llx 0 %s\n", addressVal,
[symbol UTF8String])) [symbol UTF8String]))
return NO; return NO;
insideFunction = false;
} }
} }