Commit 6ffd70e7 authored by Carl Shapiro's avatar Carl Shapiro

encoding/gob: do not hide pointer argument for the garbage collector

R=golang-dev, r
CC=golang-dev
https://golang.org/cl/14154043
parent cdb33231
...@@ -654,21 +654,19 @@ func (dec *Decoder) ignoreMap(state *decoderState, keyOp, elemOp decOp) { ...@@ -654,21 +654,19 @@ func (dec *Decoder) ignoreMap(state *decoderState, keyOp, elemOp decOp) {
// decodeSlice decodes a slice and stores the slice header through p. // decodeSlice decodes a slice and stores the slice header through p.
// Slices are encoded as an unsigned length followed by the elements. // Slices are encoded as an unsigned length followed by the elements.
func (dec *Decoder) decodeSlice(atyp reflect.Type, state *decoderState, p uintptr, elemOp decOp, elemWid uintptr, indir, elemIndir int, ovfl error) { func (dec *Decoder) decodeSlice(atyp reflect.Type, state *decoderState, p unsafe.Pointer, elemOp decOp, elemWid uintptr, indir, elemIndir int, ovfl error) {
nr := state.decodeUint() nr := state.decodeUint()
n := int(nr) n := int(nr)
if indir > 0 { if indir > 0 {
up := unsafe.Pointer(p) if *(*unsafe.Pointer)(p) == nil {
if *(*unsafe.Pointer)(up) == nil {
// Allocate the slice header. // Allocate the slice header.
*(*unsafe.Pointer)(up) = unsafe.Pointer(new([]unsafe.Pointer)) *(*unsafe.Pointer)(p) = unsafe.Pointer(new([]unsafe.Pointer))
} }
p = *(*uintptr)(up)
} }
// Allocate storage for the slice elements, that is, the underlying array, // Allocate storage for the slice elements, that is, the underlying array,
// if the existing slice does not have the capacity. // if the existing slice does not have the capacity.
// Always write a header at p. // Always write a header at p.
hdrp := (*reflect.SliceHeader)(unsafe.Pointer(p)) hdrp := (*reflect.SliceHeader)(p)
if hdrp.Cap < n { if hdrp.Cap < n {
hdrp.Data = reflect.MakeSlice(atyp, n, n).Pointer() hdrp.Data = reflect.MakeSlice(atyp, n, n).Pointer()
hdrp.Cap = n hdrp.Cap = n
...@@ -887,7 +885,7 @@ func (dec *Decoder) decOpFor(wireId typeId, rt reflect.Type, name string, inProg ...@@ -887,7 +885,7 @@ func (dec *Decoder) decOpFor(wireId typeId, rt reflect.Type, name string, inProg
elemOp, elemIndir := dec.decOpFor(elemId, t.Elem(), name, inProgress) elemOp, elemIndir := dec.decOpFor(elemId, t.Elem(), name, inProgress)
ovfl := overflow(name) ovfl := overflow(name)
op = func(i *decInstr, state *decoderState, p unsafe.Pointer) { op = func(i *decInstr, state *decoderState, p unsafe.Pointer) {
state.dec.decodeSlice(t, state, uintptr(p), *elemOp, t.Elem().Size(), i.indir, elemIndir, ovfl) state.dec.decodeSlice(t, state, p, *elemOp, t.Elem().Size(), i.indir, elemIndir, ovfl)
} }
case reflect.Struct: case reflect.Struct:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment