aboutsummaryrefslogtreecommitdiff
path: root/src/debug
diff options
context:
space:
mode:
authorIan Lance Taylor <iant@golang.org>2023-02-22 13:00:14 -0800
committerGopher Robot <gobot@golang.org>2023-02-22 23:19:29 +0000
commite7cfcda67d430a6e3cf4e8dfef27416870a2b007 (patch)
treeaace311ed4eef4a1b19d35433873df1b375dec97 /src/debug
parent06b67591e7861d813e94fa76434af9c778d81cf5 (diff)
downloadgo-e7cfcda67d430a6e3cf4e8dfef27416870a2b007.tar.gz
go-e7cfcda67d430a6e3cf4e8dfef27416870a2b007.zip
debug/macho: don't crash if dynamic symtab with no symtab
No test case because the problem can only happen for invalid data. Let the fuzzer find cases like this. For #47653 Fixes #58642 Change-Id: I19fee0dc9bd6239b520c15182b8f1e57bb0049bb Reviewed-on: https://go-review.googlesource.com/c/go/+/470397 Reviewed-by: Ian Lance Taylor <iant@google.com> Run-TryBot: Ian Lance Taylor <iant@google.com> Auto-Submit: Ian Lance Taylor <iant@google.com> Run-TryBot: Ian Lance Taylor <iant@golang.org> TryBot-Result: Gopher Robot <gobot@golang.org> Reviewed-by: Bryan Mills <bcmills@google.com>
Diffstat (limited to 'src/debug')
-rw-r--r--src/debug/macho/file.go4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/debug/macho/file.go b/src/debug/macho/file.go
index 9806c270bf..3e339c32c6 100644
--- a/src/debug/macho/file.go
+++ b/src/debug/macho/file.go
@@ -350,7 +350,9 @@ func NewFile(r io.ReaderAt) (*File, error) {
if err := binary.Read(b, bo, &hdr); err != nil {
return nil, err
}
- if hdr.Iundefsym > uint32(len(f.Symtab.Syms)) {
+ if f.Symtab == nil {
+ return nil, &FormatError{offset, "dynamic symbol table seen before any ordinary symbol table", nil}
+ } else if hdr.Iundefsym > uint32(len(f.Symtab.Syms)) {
return nil, &FormatError{offset, fmt.Sprintf(
"undefined symbols index in dynamic symbol table command is greater than symbol table length (%d > %d)",
hdr.Iundefsym, len(f.Symtab.Syms)), nil}