mirror of
https://github.com/golang/go
synced 2024-11-21 11:34:44 -07:00
debug/dwarf: Fail on reading incorrect offset due to skipped compilation unit
This commit is contained in:
parent
44d4b69942
commit
e1ed146af8
@ -541,6 +541,8 @@ func (b *buf) entry(cu *Entry, atab abbrevTable, ubase Offset, vers int) *Entry
|
||||
} else if a.tag == TagCompileUnit {
|
||||
delay = append(delay, delayed{i, off, formAddrx})
|
||||
break
|
||||
} else {
|
||||
b.error("Can't adjust offset: compilation unit skipped")
|
||||
}
|
||||
|
||||
var err error
|
||||
@ -692,6 +694,8 @@ func (b *buf) entry(cu *Entry, atab abbrevTable, ubase Offset, vers int) *Entry
|
||||
} else if a.tag == TagCompileUnit {
|
||||
delay = append(delay, delayed{i, off, formStrx})
|
||||
break
|
||||
} else {
|
||||
b.error("Can't adjust offset: compilation unit skipped")
|
||||
}
|
||||
|
||||
val = resolveStrx(uint64(strBase), off)
|
||||
@ -752,6 +756,8 @@ func (b *buf) entry(cu *Entry, atab abbrevTable, ubase Offset, vers int) *Entry
|
||||
} else if a.tag == TagCompileUnit {
|
||||
delay = append(delay, delayed{i, off, formRnglistx})
|
||||
break
|
||||
} else {
|
||||
b.error("Can't adjust offset: compilation unit skipped")
|
||||
}
|
||||
|
||||
val = resolveRnglistx(uint64(rnglistsBase), off)
|
||||
@ -856,6 +862,15 @@ func (r *Reader) Seek(off Offset) {
|
||||
r.b = makeBuf(r.d, u, "info", off, u.data[off-u.off:])
|
||||
}
|
||||
|
||||
// SeekAndSetCU positions the [Reader] at offset off in the encoded entry stream, and additionally sets the current
|
||||
// CU for the reader.
|
||||
func (r *Reader) SeekAndSetCU(off Offset) {
|
||||
cuIdx := r.d.offsetToUnit(off)
|
||||
r.Seek(r.d.unit[cuIdx].off)
|
||||
r.Next()
|
||||
r.Seek(off)
|
||||
}
|
||||
|
||||
// maybeNextUnit advances to the next unit if this one is finished.
|
||||
func (r *Reader) maybeNextUnit() {
|
||||
for len(r.b.data) == 0 && r.unit+1 < len(r.d.unit) {
|
||||
|
Loading…
Reference in New Issue
Block a user