]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/link: recompute heapPos after copyHeap
authorCherry Zhang <cherryyz@google.com>
Wed, 18 Nov 2020 00:10:51 +0000 (19:10 -0500)
committerCherry Zhang <cherryyz@google.com>
Wed, 18 Nov 2020 14:45:14 +0000 (14:45 +0000)
Immediately after a forward Seek, the offset we're writing to is
beyond len(buf)+len(heap):

|<--- buf --->|<--- heap --->|
                                    ^
                                    off

If we do a copyHeap at this point, the new heapPos should not be
0:

|<---------- buf ----------->|<-heap->|
                                    ^
                                    off

Recompute it.

For #42082.

Change-Id: Icb3e4e1c7bf7d1fd3d76a2e0d7dfcb319c661534
Reviewed-on: https://go-review.googlesource.com/c/go/+/270941
Trust: Cherry Zhang <cherryyz@google.com>
Run-TryBot: Cherry Zhang <cherryyz@google.com>
TryBot-Result: Go Bot <gobot@golang.org>
Reviewed-by: Than McIntosh <thanm@google.com>
src/cmd/link/internal/ld/outbuf.go

index fa4d18333714cc6b9a1d7c531b3a89c228d21555..36ec394077035535aa5aac4e21d9b388d4931f3c 100644 (file)
@@ -183,7 +183,9 @@ func (out *OutBuf) writeLoc(lenToWrite int64) (int64, []byte) {
                // See if our heap would grow to be too large, and if so, copy it to the end
                // of the mmapped area.
                if heapLen > maxOutBufHeapLen && out.copyHeap() {
-                       heapPos, heapLen, lenNeeded = 0, 0, lenToWrite
+                       heapPos -= heapLen
+                       lenNeeded = heapPos + lenToWrite
+                       heapLen = 0
                }
                out.heap = append(out.heap, make([]byte, lenNeeded-heapLen)...)
        }