func (s *Sym2) IsGoType() bool { return s.Flag()&SymFlagGoType != 0 }
func (s *Sym2) TopFrame() bool { return s.Flag()&SymFlagTopFrame != 0 }
+func (s *Sym2) SetName(x string, w *Writer) {
+ binary.LittleEndian.PutUint32(s[:], uint32(len(x)))
+ binary.LittleEndian.PutUint32(s[4:], w.stringOff(x))
+}
+
+func (s *Sym2) SetABI(x uint16) { binary.LittleEndian.PutUint16(s[8:], x) }
+func (s *Sym2) SetType(x uint8) { s[10] = x }
+func (s *Sym2) SetFlag(x uint8) { s[11] = x }
+func (s *Sym2) SetSiz(x uint32) { binary.LittleEndian.PutUint32(s[12:], x) }
+func (s *Sym2) SetAlign(x uint32) { binary.LittleEndian.PutUint32(s[16:], x) }
+
+func (s *Sym2) Write(w *Writer) { w.Bytes(s[:]) }
+
// Symbol reference.
type SymRef struct {
PkgIdx uint32
r.SetSym(sym)
}
+func (r *Reloc2) Write(w *Writer) { w.Bytes(r[:]) }
+
// Aux symbol info.
type Aux struct {
Type uint8
return SymRef{binary.LittleEndian.Uint32(a[1:]), binary.LittleEndian.Uint32(a[5:])}
}
+func (a *Aux2) SetType(x uint8) { a[0] = x }
+func (a *Aux2) SetSym(x SymRef) {
+ binary.LittleEndian.PutUint32(a[1:], x.PkgIdx)
+ binary.LittleEndian.PutUint32(a[5:], x.SymIdx)
+}
+
+func (a *Aux2) Write(w *Writer) { w.Bytes(a[:]) }
+
type Writer struct {
wr *bio.Writer
stringMap map[string]uint32
w.RawString(s)
}
-func (w *Writer) StringRef(s string) {
+func (w *Writer) stringOff(s string) uint32 {
off, ok := w.stringMap[s]
if !ok {
panic(fmt.Sprintf("writeStringRef: string not added: %q", s))
}
+ return off
+}
+
+func (w *Writer) StringRef(s string) {
w.Uint32(uint32(len(s)))
- w.Uint32(off)
+ w.Uint32(w.stringOff(s))
}
func (w *Writer) RawString(s string) {
if s.Func != nil {
align = uint32(s.Func.Align)
}
- o := goobj2.Sym{
- Name: name,
- ABI: abi,
- Type: uint8(s.Type),
- Flag: flag,
- Siz: uint32(s.Size),
- Align: align,
- }
+ var o goobj2.Sym2
+ o.SetName(name, w.Writer)
+ o.SetABI(abi)
+ o.SetType(uint8(s.Type))
+ o.SetFlag(flag)
+ o.SetSiz(uint32(s.Size))
+ o.SetAlign(align)
o.Write(w.Writer)
}
}
func (w *writer) Reloc(r *Reloc) {
- o := goobj2.Reloc{
- Off: r.Off,
- Siz: r.Siz,
- Type: uint8(r.Type),
- Add: r.Add,
- Sym: makeSymRef(r.Sym),
- }
+ var o goobj2.Reloc2
+ o.SetOff(r.Off)
+ o.SetSiz(r.Siz)
+ o.SetType(uint8(r.Type))
+ o.SetAdd(r.Add)
+ o.SetSym(makeSymRef(r.Sym))
+ o.Write(w.Writer)
+}
+
+func (w *writer) aux1(typ uint8, rs *LSym) {
+ var o goobj2.Aux2
+ o.SetType(typ)
+ o.SetSym(makeSymRef(rs))
o.Write(w.Writer)
}
func (w *writer) Aux(s *LSym) {
if s.Gotype != nil {
- o := goobj2.Aux{
- Type: goobj2.AuxGotype,
- Sym: makeSymRef(s.Gotype),
- }
- o.Write(w.Writer)
+ w.aux1(goobj2.AuxGotype, s.Gotype)
}
if s.Func != nil {
- o := goobj2.Aux{
- Type: goobj2.AuxFuncInfo,
- Sym: makeSymRef(s.Func.FuncInfoSym),
- }
- o.Write(w.Writer)
+ w.aux1(goobj2.AuxFuncInfo, s.Func.FuncInfoSym)
for _, d := range s.Func.Pcln.Funcdata {
- o := goobj2.Aux{
- Type: goobj2.AuxFuncdata,
- Sym: makeSymRef(d),
- }
- o.Write(w.Writer)
+ w.aux1(goobj2.AuxFuncdata, d)
}
if s.Func.dwarfInfoSym != nil && s.Func.dwarfInfoSym.Size != 0 {
- o := goobj2.Aux{
- Type: goobj2.AuxDwarfInfo,
- Sym: makeSymRef(s.Func.dwarfInfoSym),
- }
- o.Write(w.Writer)
+ w.aux1(goobj2.AuxDwarfInfo, s.Func.dwarfInfoSym)
}
if s.Func.dwarfLocSym != nil && s.Func.dwarfLocSym.Size != 0 {
- o := goobj2.Aux{
- Type: goobj2.AuxDwarfLoc,
- Sym: makeSymRef(s.Func.dwarfLocSym),
- }
- o.Write(w.Writer)
+ w.aux1(goobj2.AuxDwarfLoc, s.Func.dwarfLocSym)
}
if s.Func.dwarfRangesSym != nil && s.Func.dwarfRangesSym.Size != 0 {
- o := goobj2.Aux{
- Type: goobj2.AuxDwarfRanges,
- Sym: makeSymRef(s.Func.dwarfRangesSym),
- }
- o.Write(w.Writer)
+ w.aux1(goobj2.AuxDwarfRanges, s.Func.dwarfRangesSym)
}
if s.Func.dwarfDebugLinesSym != nil && s.Func.dwarfDebugLinesSym.Size != 0 {
- o := goobj2.Aux{
- Type: goobj2.AuxDwarfLines,
- Sym: makeSymRef(s.Func.dwarfDebugLinesSym),
- }
- o.Write(w.Writer)
+ w.aux1(goobj2.AuxDwarfLines, s.Func.dwarfDebugLinesSym)
}
}
}