mirror of https://github.com/golang/go.git
[release-branch.go1.13] runtime: fix textOff for multiple text sections
If a compilation has multiple text sections, code in
textOff must compare the offset argument against the range
for each text section to determine which one it is in.
The comparison looks like this:
if uintptr(off) >= sectaddr && uintptr(off) <= sectaddr+sectlen
If the off value being compared is equal to sectaddr+sectlen then it
is not within the range of the text section but after it. The
comparison should be just '<'.
Fixes #35211
Change-Id: I114633fd734563d38f4e842dd884c6c239f73c95
Reviewed-on: https://go-review.googlesource.com/c/go/+/203817
Run-TryBot: Lynn Boger <laboger@linux.vnet.ibm.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Ian Lance Taylor <iant@golang.org>
Reviewed-by: Cherry Zhang <cherryyz@google.com>
(cherry picked from commit 0ae9389609)
Reviewed-on: https://go-review.googlesource.com/c/go/+/203819
Run-TryBot: Carlos Amedee <carlos@golang.org>
Reviewed-by: Keith Randall <khr@golang.org>
This commit is contained in:
parent
4f81a326d0
commit
6eee9903c7
|
|
@ -287,7 +287,7 @@ func (t *_type) textOff(off textOff) unsafe.Pointer {
|
|||
for i := range md.textsectmap {
|
||||
sectaddr := md.textsectmap[i].vaddr
|
||||
sectlen := md.textsectmap[i].length
|
||||
if uintptr(off) >= sectaddr && uintptr(off) <= sectaddr+sectlen {
|
||||
if uintptr(off) >= sectaddr && uintptr(off) < sectaddr+sectlen {
|
||||
res = md.textsectmap[i].baseaddr + uintptr(off) - uintptr(md.textsectmap[i].vaddr)
|
||||
break
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue