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:
parent
3a283d8f8b
commit
c85fb043ed
1 changed files with 24 additions and 15 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue