Commit 08db3492 authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

cmd/compile: convert GCProg generation to use obj.LSym

Passes toolstash-check.

Change-Id: I0cc4fe608a50681845a92053cb3888ea127b521a
Reviewed-on: https://go-review.googlesource.com/41402
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
Reviewed-by: default avatarMatthew Dempsky <mdempsky@google.com>
parent a495fe27
...@@ -882,7 +882,7 @@ func dcommontype(s *types.Sym, ot int, t *types.Type) int { ...@@ -882,7 +882,7 @@ func dcommontype(s *types.Sym, ot int, t *types.Type) int {
} else { } else {
ot = dsymptr(s.Linksym(), ot, algsym.Linksym(), 0) ot = dsymptr(s.Linksym(), ot, algsym.Linksym(), 0)
} }
ot = dsymptr(s.Linksym(), ot, gcsym.Linksym(), 0) // gcdata ot = dsymptr(s.Linksym(), ot, gcsym, 0) // gcdata
nsym := dname(p, "", nil, exported) nsym := dname(p, "", nil, exported)
ot = dsymptrOff(s.Linksym(), ot, nsym, 0) // str ot = dsymptrOff(s.Linksym(), ot, nsym, 0) // str
...@@ -1658,33 +1658,34 @@ const maxPtrmaskBytes = 2048 ...@@ -1658,33 +1658,34 @@ const maxPtrmaskBytes = 2048
// dgcsym emits and returns a data symbol containing GC information for type t, // dgcsym emits and returns a data symbol containing GC information for type t,
// along with a boolean reporting whether the UseGCProg bit should be set in // along with a boolean reporting whether the UseGCProg bit should be set in
// the type kind, and the ptrdata field to record in the reflect type information. // the type kind, and the ptrdata field to record in the reflect type information.
func dgcsym(t *types.Type) (sym *types.Sym, useGCProg bool, ptrdata int64) { func dgcsym(t *types.Type) (lsym *obj.LSym, useGCProg bool, ptrdata int64) {
ptrdata = typeptrdata(t) ptrdata = typeptrdata(t)
if ptrdata/int64(Widthptr) <= maxPtrmaskBytes*8 { if ptrdata/int64(Widthptr) <= maxPtrmaskBytes*8 {
sym = dgcptrmask(t) lsym = dgcptrmask(t)
return return
} }
useGCProg = true useGCProg = true
sym, ptrdata = dgcprog(t) lsym, ptrdata = dgcprog(t)
return return
} }
// dgcptrmask emits and returns the symbol containing a pointer mask for type t. // dgcptrmask emits and returns the symbol containing a pointer mask for type t.
func dgcptrmask(t *types.Type) *types.Sym { func dgcptrmask(t *types.Type) *obj.LSym {
ptrmask := make([]byte, (typeptrdata(t)/int64(Widthptr)+7)/8) ptrmask := make([]byte, (typeptrdata(t)/int64(Widthptr)+7)/8)
fillptrmask(t, ptrmask) fillptrmask(t, ptrmask)
p := fmt.Sprintf("gcbits.%x", ptrmask) p := fmt.Sprintf("gcbits.%x", ptrmask)
sym := Runtimepkg.Lookup(p) sym := Runtimepkg.Lookup(p)
lsym := sym.Linksym()
if !sym.Uniq() { if !sym.Uniq() {
sym.SetUniq(true) sym.SetUniq(true)
for i, x := range ptrmask { for i, x := range ptrmask {
duint8(sym.Linksym(), i, x) duint8(lsym, i, x)
} }
ggloblsym(sym.Linksym(), int32(len(ptrmask)), obj.DUPOK|obj.RODATA|obj.LOCAL) ggloblsym(lsym, int32(len(ptrmask)), obj.DUPOK|obj.RODATA|obj.LOCAL)
} }
return sym return lsym
} }
// fillptrmask fills in ptrmask with 1s corresponding to the // fillptrmask fills in ptrmask with 1s corresponding to the
...@@ -1714,51 +1715,51 @@ func fillptrmask(t *types.Type, ptrmask []byte) { ...@@ -1714,51 +1715,51 @@ func fillptrmask(t *types.Type, ptrmask []byte) {
// along with the size of the data described by the program (in the range [typeptrdata(t), t.Width]). // along with the size of the data described by the program (in the range [typeptrdata(t), t.Width]).
// In practice, the size is typeptrdata(t) except for non-trivial arrays. // In practice, the size is typeptrdata(t) except for non-trivial arrays.
// For non-trivial arrays, the program describes the full t.Width size. // For non-trivial arrays, the program describes the full t.Width size.
func dgcprog(t *types.Type) (*types.Sym, int64) { func dgcprog(t *types.Type) (*obj.LSym, int64) {
dowidth(t) dowidth(t)
if t.Width == BADWIDTH { if t.Width == BADWIDTH {
Fatalf("dgcprog: %v badwidth", t) Fatalf("dgcprog: %v badwidth", t)
} }
sym := typesymprefix(".gcprog", t) lsym := typesymprefix(".gcprog", t).Linksym()
var p GCProg var p GCProg
p.init(sym) p.init(lsym)
p.emit(t, 0) p.emit(t, 0)
offset := p.w.BitIndex() * int64(Widthptr) offset := p.w.BitIndex() * int64(Widthptr)
p.end() p.end()
if ptrdata := typeptrdata(t); offset < ptrdata || offset > t.Width { if ptrdata := typeptrdata(t); offset < ptrdata || offset > t.Width {
Fatalf("dgcprog: %v: offset=%d but ptrdata=%d size=%d", t, offset, ptrdata, t.Width) Fatalf("dgcprog: %v: offset=%d but ptrdata=%d size=%d", t, offset, ptrdata, t.Width)
} }
return sym, offset return lsym, offset
} }
type GCProg struct { type GCProg struct {
sym *types.Sym lsym *obj.LSym
symoff int symoff int
w gcprog.Writer w gcprog.Writer
} }
var Debug_gcprog int // set by -d gcprog var Debug_gcprog int // set by -d gcprog
func (p *GCProg) init(sym *types.Sym) { func (p *GCProg) init(lsym *obj.LSym) {
p.sym = sym p.lsym = lsym
p.symoff = 4 // first 4 bytes hold program length p.symoff = 4 // first 4 bytes hold program length
p.w.Init(p.writeByte) p.w.Init(p.writeByte)
if Debug_gcprog > 0 { if Debug_gcprog > 0 {
fmt.Fprintf(os.Stderr, "compile: start GCProg for %v\n", sym) fmt.Fprintf(os.Stderr, "compile: start GCProg for %v\n", lsym)
p.w.Debug(os.Stderr) p.w.Debug(os.Stderr)
} }
} }
func (p *GCProg) writeByte(x byte) { func (p *GCProg) writeByte(x byte) {
p.symoff = duint8(p.sym.Linksym(), p.symoff, x) p.symoff = duint8(p.lsym, p.symoff, x)
} }
func (p *GCProg) end() { func (p *GCProg) end() {
p.w.End() p.w.End()
duint32(p.sym.Linksym(), 0, uint32(p.symoff-4)) duint32(p.lsym, 0, uint32(p.symoff-4))
ggloblsym(p.sym.Linksym(), int32(p.symoff), obj.DUPOK|obj.RODATA|obj.LOCAL) ggloblsym(p.lsym, int32(p.symoff), obj.DUPOK|obj.RODATA|obj.LOCAL)
if Debug_gcprog > 0 { if Debug_gcprog > 0 {
fmt.Fprintf(os.Stderr, "compile: end GCProg for %v\n", p.sym) fmt.Fprintf(os.Stderr, "compile: end GCProg for %v\n", p.lsym)
} }
} }
......
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