func asmb() {
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f asmb\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f asmb\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f codeblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f codeblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
 
        if ld.Segrodata.Filelen > 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
                }
                ld.Bso.Flush()
 
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f datblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f datblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
        symo := int64(0)
        if ld.Debug['s'] == 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f sym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f sym\n", obj.Cputime())
                }
                ld.Bso.Flush()
                switch ld.HEADTYPE {
                                ld.Cwrite(ld.Elfstrdat)
 
                                if ld.Debug['v'] != 0 {
-                                       fmt.Fprintf(&ld.Bso, "%5.2f dwarf\n", obj.Cputime())
+                                       fmt.Fprintf(ld.Bso, "%5.2f dwarf\n", obj.Cputime())
                                }
 
                                if ld.Linkmode == ld.LinkExternal {
 
                case obj.Hwindows:
                        if ld.Debug['v'] != 0 {
-                               fmt.Fprintf(&ld.Bso, "%5.2f dwarf\n", obj.Cputime())
+                               fmt.Fprintf(ld.Bso, "%5.2f dwarf\n", obj.Cputime())
                        }
 
                case obj.Hdarwin:
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f headr\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f headr\n", obj.Cputime())
        }
        ld.Bso.Flush()
        ld.Cseek(0)
 
 
 func asmb() {
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f asmb\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f asmb\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
 
        if ld.Segrodata.Filelen > 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
                }
                ld.Bso.Flush()
 
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f datblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f datblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
        if ld.Debug['s'] == 0 {
                // TODO: rationalize
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f sym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f sym\n", obj.Cputime())
                }
                ld.Bso.Flush()
                switch ld.HEADTYPE {
                default:
                        if ld.Iself {
                                if ld.Debug['v'] != 0 {
-                                       fmt.Fprintf(&ld.Bso, "%5.2f elfsym\n", obj.Cputime())
+                                       fmt.Fprintf(ld.Bso, "%5.2f elfsym\n", obj.Cputime())
                                }
                                ld.Asmelfsym()
                                ld.Cflush()
 
        ld.Ctxt.Cursym = nil
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f header\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f header\n", obj.Cputime())
        }
        ld.Bso.Flush()
        ld.Cseek(0)
 
 
 func asmb() {
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f asmb\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f asmb\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
 
        if ld.Segrodata.Filelen > 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
                }
                ld.Bso.Flush()
 
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f datblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f datblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
        if ld.Debug['s'] == 0 {
                // TODO: rationalize
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f sym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f sym\n", obj.Cputime())
                }
                ld.Bso.Flush()
                switch ld.HEADTYPE {
                default:
                        if ld.Iself {
                                if ld.Debug['v'] != 0 {
-                                       fmt.Fprintf(&ld.Bso, "%5.2f elfsym\n", obj.Cputime())
+                                       fmt.Fprintf(ld.Bso, "%5.2f elfsym\n", obj.Cputime())
                                }
                                ld.Asmelfsym()
                                ld.Cflush()
 
        ld.Ctxt.Cursym = nil
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f header\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f header\n", obj.Cputime())
        }
        ld.Bso.Flush()
        ld.Cseek(0)
 
                if os.IsNotExist(err) {
                        // It's OK if we don't have a libgcc file at all.
                        if Debug['v'] != 0 {
-                               fmt.Fprintf(&Bso, "skipping libgcc file: %v\n", err)
+                               fmt.Fprintf(Bso, "skipping libgcc file: %v\n", err)
                        }
                        return
                }
 
 
 func reloc() {
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f reloc\n", obj.Cputime())
+               fmt.Fprintf(Bso, "%5.2f reloc\n", obj.Cputime())
        }
        Bso.Flush()
 
                return
        }
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f reloc\n", obj.Cputime())
+               fmt.Fprintf(Bso, "%5.2f reloc\n", obj.Cputime())
        }
        Bso.Flush()
 
 
 func Codeblk(addr int64, size int64) {
        if Debug['a'] != 0 {
-               fmt.Fprintf(&Bso, "codeblk [%#x,%#x) at offset %#x\n", addr, addr+size, Cpos())
+               fmt.Fprintf(Bso, "codeblk [%#x,%#x) at offset %#x\n", addr, addr+size, Cpos())
        }
 
        blk(Ctxt.Textp, addr, size)
                }
 
                if addr < sym.Value {
-                       fmt.Fprintf(&Bso, "%-20s %.8x|", "_", uint64(int64(addr)))
+                       fmt.Fprintf(Bso, "%-20s %.8x|", "_", uint64(int64(addr)))
                        for ; addr < sym.Value; addr++ {
-                               fmt.Fprintf(&Bso, " %.2x", 0)
+                               fmt.Fprintf(Bso, " %.2x", 0)
                        }
-                       fmt.Fprintf(&Bso, "\n")
+                       fmt.Fprintf(Bso, "\n")
                }
 
-               fmt.Fprintf(&Bso, "%.6x\t%-20s\n", uint64(int64(addr)), sym.Name)
+               fmt.Fprintf(Bso, "%.6x\t%-20s\n", uint64(int64(addr)), sym.Name)
                q = sym.P
 
                for len(q) >= 16 {
-                       fmt.Fprintf(&Bso, "%.6x\t% x\n", uint64(addr), q[:16])
+                       fmt.Fprintf(Bso, "%.6x\t% x\n", uint64(addr), q[:16])
                        addr += 16
                        q = q[16:]
                }
 
                if len(q) > 0 {
-                       fmt.Fprintf(&Bso, "%.6x\t% x\n", uint64(addr), q)
+                       fmt.Fprintf(Bso, "%.6x\t% x\n", uint64(addr), q)
                        addr += int64(len(q))
                }
        }
 
        if addr < eaddr {
-               fmt.Fprintf(&Bso, "%-20s %.8x|", "_", uint64(int64(addr)))
+               fmt.Fprintf(Bso, "%-20s %.8x|", "_", uint64(int64(addr)))
                for ; addr < eaddr; addr++ {
-                       fmt.Fprintf(&Bso, " %.2x", 0)
+                       fmt.Fprintf(Bso, " %.2x", 0)
                }
        }
 
 
 func Datblk(addr int64, size int64) {
        if Debug['a'] != 0 {
-               fmt.Fprintf(&Bso, "datblk [%#x,%#x) at offset %#x\n", addr, addr+size, Cpos())
+               fmt.Fprintf(Bso, "datblk [%#x,%#x) at offset %#x\n", addr, addr+size, Cpos())
        }
 
        blk(datap, addr, size)
                        break
                }
                if addr < sym.Value {
-                       fmt.Fprintf(&Bso, "\t%.8x| 00 ...\n", uint64(addr))
+                       fmt.Fprintf(Bso, "\t%.8x| 00 ...\n", uint64(addr))
                        addr = sym.Value
                }
 
-               fmt.Fprintf(&Bso, "%s\n\t%.8x|", sym.Name, uint(addr))
+               fmt.Fprintf(Bso, "%s\n\t%.8x|", sym.Name, uint(addr))
                p = sym.P
                ep = p[len(sym.P):]
                for -cap(p) < -cap(ep) {
                        if -cap(p) > -cap(sym.P) && int(-cap(p)+cap(sym.P))%16 == 0 {
-                               fmt.Fprintf(&Bso, "\n\t%.8x|", uint(addr+int64(-cap(p)+cap(sym.P))))
+                               fmt.Fprintf(Bso, "\n\t%.8x|", uint(addr+int64(-cap(p)+cap(sym.P))))
                        }
-                       fmt.Fprintf(&Bso, " %.2x", p[0])
+                       fmt.Fprintf(Bso, " %.2x", p[0])
                        p = p[1:]
                }
 
                addr += int64(len(sym.P))
                for ; addr < sym.Value+sym.Size; addr++ {
-                       fmt.Fprintf(&Bso, " %.2x", 0)
+                       fmt.Fprintf(Bso, " %.2x", 0)
                }
-               fmt.Fprintf(&Bso, "\n")
+               fmt.Fprintf(Bso, "\n")
 
                if Linkmode == LinkExternal {
                        for i = 0; i < int64(len(sym.R)); i++ {
                                        typ = "call"
                                }
 
-                               fmt.Fprintf(&Bso, "\treloc %.8x/%d %s %s+%#x [%#x]\n", uint(sym.Value+int64(r.Off)), r.Siz, typ, rsname, int64(r.Add), int64(r.Sym.Value+r.Add))
+                               fmt.Fprintf(Bso, "\treloc %.8x/%d %s %s+%#x [%#x]\n", uint(sym.Value+int64(r.Off)), r.Siz, typ, rsname, int64(r.Add), int64(r.Sym.Value+r.Add))
                        }
                }
        }
 
        if addr < eaddr {
-               fmt.Fprintf(&Bso, "\t%.8x| 00 ...\n", uint(addr))
+               fmt.Fprintf(Bso, "\t%.8x| 00 ...\n", uint(addr))
        }
-       fmt.Fprintf(&Bso, "\t%.8x|\n", uint(eaddr))
+       fmt.Fprintf(Bso, "\t%.8x|\n", uint(eaddr))
 }
 
 func Dwarfblk(addr int64, size int64) {
        if Debug['a'] != 0 {
-               fmt.Fprintf(&Bso, "dwarfblk [%#x,%#x) at offset %#x\n", addr, addr+size, Cpos())
+               fmt.Fprintf(Bso, "dwarfblk [%#x,%#x) at offset %#x\n", addr, addr+size, Cpos())
        }
 
        blk(dwarfp, addr, size)
 
 func dodata() {
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f dodata\n", obj.Cputime())
+               fmt.Fprintf(Bso, "%5.2f dodata\n", obj.Cputime())
        }
        Bso.Flush()
 
 
        }
 
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f dwarf\n", obj.Cputime())
+               fmt.Fprintf(Bso, "%5.2f dwarf\n", obj.Cputime())
        }
 
        // For diagnostic messages.
 
                ehdr.flags = 0x5000202
        }
        if data[0] != 'A' {
-               fmt.Fprintf(&Bso, ".ARM.attributes has unexpected format %c\n", data[0])
+               fmt.Fprintf(Bso, ".ARM.attributes has unexpected format %c\n", data[0])
                return
        }
        data = data[1:]
 
                nulIndex := bytes.IndexByte(sectiondata, 0)
                if nulIndex < 0 {
-                       fmt.Fprintf(&Bso, "corrupt .ARM.attributes (section name not NUL-terminated)\n")
+                       fmt.Fprintf(Bso, "corrupt .ARM.attributes (section name not NUL-terminated)\n")
                        return
                }
                name := string(sectiondata[:nulIndex])
                                        }
                                }
                                if attrList.err != nil {
-                                       fmt.Fprintf(&Bso, "could not parse .ARM.attributes\n")
+                                       fmt.Fprintf(Bso, "could not parse .ARM.attributes\n")
                                }
                        }
                }
 
 func ldelf(f *bio.Reader, pkg string, length int64, pn string) {
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f ldelf %s\n", obj.Cputime(), pn)
+               fmt.Fprintf(Bso, "%5.2f ldelf %s\n", obj.Cputime(), pn)
        }
 
        Ctxt.IncVersion()
 
 
 func ldpe(f *bio.Reader, pkg string, length int64, pn string) {
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f ldpe %s\n", obj.Cputime(), pn)
+               fmt.Fprintf(Bso, "%5.2f ldpe %s\n", obj.Cputime(), pn)
        }
 
        var sect *PeSect
 
 var (
        headstring string
        // buffered output
-       Bso bio.Writer
+       Bso *bio.Writer
 )
 
 // TODO(dfc) outBuf duplicates bio.Writer
                if Linkshared {
                        shlibname := filepath.Join(Ctxt.Libdir[i], name+".shlibname")
                        if Debug['v'] != 0 {
-                               fmt.Fprintf(&Bso, "searching for %s.a in %s\n", name, shlibname)
+                               fmt.Fprintf(Bso, "searching for %s.a in %s\n", name, shlibname)
                        }
                        if _, err := os.Stat(shlibname); err == nil {
                                addlibpath(Ctxt, "internal", "internal", "", name, shlibname)
                }
                pname := filepath.Join(Ctxt.Libdir[i], name+".a")
                if Debug['v'] != 0 {
-                       fmt.Fprintf(&Bso, "searching for %s.a in %s\n", name, pname)
+                       fmt.Fprintf(Bso, "searching for %s.a in %s\n", name, pname)
                }
                if _, err := os.Stat(pname); err == nil {
                        addlibpath(Ctxt, "internal", "internal", pname, name, "")
        }
 
        if found == 0 {
-               fmt.Fprintf(&Bso, "warning: unable to find %s.a\n", name)
+               fmt.Fprintf(Bso, "warning: unable to find %s.a\n", name)
        }
 }
 
                iscgo = iscgo || Ctxt.Library[i].Pkg == "runtime/cgo"
                if Ctxt.Library[i].Shlib == "" {
                        if Debug['v'] > 1 {
-                               fmt.Fprintf(&Bso, "%5.2f autolib: %s (from %s)\n", obj.Cputime(), Ctxt.Library[i].File, Ctxt.Library[i].Objref)
+                               fmt.Fprintf(Bso, "%5.2f autolib: %s (from %s)\n", obj.Cputime(), Ctxt.Library[i].File, Ctxt.Library[i].Objref)
                        }
                        objfile(Ctxt.Library[i])
                }
        for i = 0; i < len(Ctxt.Library); i++ {
                if Ctxt.Library[i].Shlib != "" {
                        if Debug['v'] > 1 {
-                               fmt.Fprintf(&Bso, "%5.2f autolib: %s (from %s)\n", obj.Cputime(), Ctxt.Library[i].Shlib, Ctxt.Library[i].Objref)
+                               fmt.Fprintf(Bso, "%5.2f autolib: %s (from %s)\n", obj.Cputime(), Ctxt.Library[i].Shlib, Ctxt.Library[i].Objref)
                        }
                        ldshlibsyms(Ctxt.Library[i].Shlib)
                }
                                args := hostlinkArchArgs()
                                args = append(args, "--print-libgcc-file-name")
                                if Debug['v'] != 0 {
-                                       fmt.Fprintf(&Bso, "%s %v\n", extld, args)
+                                       fmt.Fprintf(Bso, "%s %v\n", extld, args)
                                }
                                out, err := exec.Command(extld, args...).Output()
                                if err != nil {
                                        if Debug['v'] != 0 {
-                                               fmt.Fprintln(&Bso, "not using a libgcc file because compiler failed")
-                                               fmt.Fprintf(&Bso, "%v\n%s\n", err, out)
+                                               fmt.Fprintln(Bso, "not using a libgcc file because compiler failed")
+                                               fmt.Fprintf(Bso, "%v\n%s\n", err, out)
                                        }
                                        libgccfile = "none"
                                } else {
        pkg := pathtoprefix(lib.Pkg)
 
        if Debug['v'] > 1 {
-               fmt.Fprintf(&Bso, "%5.2f ldobj: %s (%s)\n", obj.Cputime(), lib.File, pkg)
+               fmt.Fprintf(Bso, "%5.2f ldobj: %s (%s)\n", obj.Cputime(), lib.File, pkg)
        }
        Bso.Flush()
        f, err := bio.Open(lib.File)
        argv = append(argv, hostobjCopy()...)
 
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "archive: %s\n", strings.Join(argv, " "))
+               fmt.Fprintf(Bso, "archive: %s\n", strings.Join(argv, " "))
                Bso.Flush()
        }
 
        }
 
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "host link:")
+               fmt.Fprintf(Bso, "host link:")
                for _, v := range argv {
-                       fmt.Fprintf(&Bso, " %q", v)
+                       fmt.Fprintf(Bso, " %q", v)
                }
-               fmt.Fprintf(&Bso, "\n")
+               fmt.Fprintf(Bso, "\n")
                Bso.Flush()
        }
 
        if out, err := exec.Command(argv[0], argv[1:]...).CombinedOutput(); err != nil {
                Exitf("running %s failed: %v\n%s", argv[0], err, out)
        } else if Debug['v'] != 0 && len(out) > 0 {
-               fmt.Fprintf(&Bso, "%s", out)
+               fmt.Fprintf(Bso, "%s", out)
                Bso.Flush()
        }
 
        // Otherwise, off is addressing the saved program counter.
        // Something underhanded is going on. Say nothing.
        if Debug['v'] != 0 || Debug['n'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f symsize = %d\n", obj.Cputime(), uint32(Symsize))
+               fmt.Fprintf(Bso, "%5.2f symsize = %d\n", obj.Cputime(), uint32(Symsize))
        }
        Bso.Flush()
 }
                                continue
                        }
                        if (r.Type == obj.R_CALL || r.Type == obj.R_CALLARM || r.Type == obj.R_CALLPOWER || r.Type == obj.R_CALLMIPS) && r.Sym.Type == obj.STEXT {
-                               fmt.Fprintf(&Bso, "%s calls %s\n", s.Name, r.Sym.Name)
+                               fmt.Fprintf(Bso, "%s calls %s\n", s.Name, r.Sym.Name)
                        }
                }
        }
 
        ftab.Size = int64(len(ftab.P))
 
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f pclntab=%d bytes, funcdata total %d bytes\n", obj.Cputime(), int64(ftab.Size), int64(funcdata_bytes))
+               fmt.Fprintf(Bso, "%5.2f pclntab=%d bytes, funcdata total %d bytes\n", obj.Cputime(), int64(ftab.Size), int64(funcdata_bytes))
        }
 }
 
 
 )
 
 func Ldmain() {
+       Bso = bio.BufWriter(os.Stdout)
+
        Ctxt = linknew(SysArch)
        Ctxt.Diag = Diag
-       Ctxt.Bso = &Bso
+       Ctxt.Bso = Bso
 
-       Bso = *bio.BufWriter(os.Stdout)
        Debug = [128]int{}
        nerrors = 0
        outfile = ""
        obj.Flagparse(usage)
 
        startProfile()
-       Ctxt.Bso = &Bso
+       Ctxt.Bso = Bso
        Ctxt.Debugvlog = int32(Debug['v'])
        if flagShared != 0 {
                if Buildmode == BuildmodeUnset {
        }
 
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "HEADER = -H%d -T0x%x -D0x%x -R0x%x\n", HEADTYPE, uint64(INITTEXT), uint64(INITDAT), uint32(INITRND))
+               fmt.Fprintf(Bso, "HEADER = -H%d -T0x%x -D0x%x -R0x%x\n", HEADTYPE, uint64(INITTEXT), uint64(INITDAT), uint32(INITRND))
        }
        Bso.Flush()
 
        hostlink()
        archive()
        if Debug['v'] != 0 {
-               fmt.Fprintf(&Bso, "%5.2f cpu time\n", obj.Cputime())
-               fmt.Fprintf(&Bso, "%d symbols\n", len(Ctxt.Allsym))
-               fmt.Fprintf(&Bso, "%d liveness data\n", liveness)
+               fmt.Fprintf(Bso, "%5.2f cpu time\n", obj.Cputime())
+               fmt.Fprintf(Bso, "%d symbols\n", len(Ctxt.Allsym))
+               fmt.Fprintf(Bso, "%d liveness data\n", liveness)
        }
 
        Bso.Flush()
 
 
 func asmb() {
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f asmb\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f asmb\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
 
        if ld.Segrodata.Filelen > 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
                }
                ld.Bso.Flush()
 
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f datblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f datblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
        if ld.Debug['s'] == 0 {
                // TODO: rationalize
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f sym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f sym\n", obj.Cputime())
                }
                ld.Bso.Flush()
                switch ld.HEADTYPE {
                default:
                        if ld.Iself {
                                if ld.Debug['v'] != 0 {
-                                       fmt.Fprintf(&ld.Bso, "%5.2f elfsym\n", obj.Cputime())
+                                       fmt.Fprintf(ld.Bso, "%5.2f elfsym\n", obj.Cputime())
                                }
                                ld.Asmelfsym()
                                ld.Cflush()
 
        ld.Ctxt.Cursym = nil
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f header\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f header\n", obj.Cputime())
        }
        ld.Bso.Flush()
        ld.Cseek(0)
 
 
 func asmb() {
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f asmb\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f asmb\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
 
        if ld.Segrodata.Filelen > 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
                }
                ld.Bso.Flush()
 
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f datblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f datblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
        if ld.Debug['s'] == 0 {
                // TODO: rationalize
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f sym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f sym\n", obj.Cputime())
                }
                ld.Bso.Flush()
                switch ld.HEADTYPE {
                default:
                        if ld.Iself {
                                if ld.Debug['v'] != 0 {
-                                       fmt.Fprintf(&ld.Bso, "%5.2f elfsym\n", obj.Cputime())
+                                       fmt.Fprintf(ld.Bso, "%5.2f elfsym\n", obj.Cputime())
                                }
                                ld.Asmelfsym()
                                ld.Cflush()
 
        ld.Ctxt.Cursym = nil
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f header\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f header\n", obj.Cputime())
        }
        ld.Bso.Flush()
        ld.Cseek(0)
 
 
 func asmb() {
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f asmb\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f asmb\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
 
        if ld.Segrodata.Filelen > 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
                }
                ld.Bso.Flush()
 
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f datblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f datblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
                        ld.Diag("unsupported executable format")
                }
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f sym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f sym\n", obj.Cputime())
                }
                ld.Bso.Flush()
                symo = uint32(ld.Segdwarf.Fileoff + ld.Segdwarf.Filelen)
 
                ld.Cseek(int64(symo))
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f elfsym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f elfsym\n", obj.Cputime())
                }
                ld.Asmelfsym()
                ld.Cflush()
                ld.Cwrite(ld.Elfstrdat)
 
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f dwarf\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f dwarf\n", obj.Cputime())
                }
 
                if ld.Linkmode == ld.LinkExternal {
 
        ld.Ctxt.Cursym = nil
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f header\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f header\n", obj.Cputime())
        }
        ld.Bso.Flush()
        ld.Cseek(0)
 
 
 func asmb() {
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f asmb\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f asmb\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
 
        if ld.Segrodata.Filelen > 0 {
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f rodatblk\n", obj.Cputime())
                }
                ld.Bso.Flush()
 
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f datblk\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f datblk\n", obj.Cputime())
        }
        ld.Bso.Flush()
 
        if ld.Debug['s'] == 0 {
                // TODO: rationalize
                if ld.Debug['v'] != 0 {
-                       fmt.Fprintf(&ld.Bso, "%5.2f sym\n", obj.Cputime())
+                       fmt.Fprintf(ld.Bso, "%5.2f sym\n", obj.Cputime())
                }
                ld.Bso.Flush()
                switch ld.HEADTYPE {
                default:
                        if ld.Iself {
                                if ld.Debug['v'] != 0 {
-                                       fmt.Fprintf(&ld.Bso, "%5.2f elfsym\n", obj.Cputime())
+                                       fmt.Fprintf(ld.Bso, "%5.2f elfsym\n", obj.Cputime())
                                }
                                ld.Asmelfsym()
                                ld.Cflush()
 
                case obj.Hwindows:
                        if ld.Debug['v'] != 0 {
-                               fmt.Fprintf(&ld.Bso, "%5.2f dwarf\n", obj.Cputime())
+                               fmt.Fprintf(ld.Bso, "%5.2f dwarf\n", obj.Cputime())
                        }
 
                case obj.Hdarwin:
        }
 
        if ld.Debug['v'] != 0 {
-               fmt.Fprintf(&ld.Bso, "%5.2f headr\n", obj.Cputime())
+               fmt.Fprintf(ld.Bso, "%5.2f headr\n", obj.Cputime())
        }
        ld.Bso.Flush()
        ld.Cseek(0)