Imports #
"cmd/compile/internal/base"
"cmd/compile/internal/bitvec"
"cmd/compile/internal/types"
"cmd/internal/obj"
"encoding/binary"
"cmd/compile/internal/base"
"cmd/compile/internal/ir"
"cmd/internal/obj"
"cmd/internal/src"
"internal/abi"
"cmd/compile/internal/base"
"cmd/compile/internal/bitvec"
"cmd/compile/internal/types"
"cmd/internal/obj"
"encoding/binary"
"cmd/compile/internal/base"
"cmd/compile/internal/ir"
"cmd/internal/obj"
"cmd/internal/src"
"internal/abi"
StackMapDontCare indicates that the stack map index at a Value doesn't matter. This is a sentinel value that should never be emitted to the PCDATA stream. We use -1000 because that's obviously never a valid stack index (but -1 is).
const StackMapDontCare StackMapIndex = *ast.UnaryExpr
var sharedProgArray = *ast.CallExpr
type StackMapIndex int
Progs accumulates Progs for a function and converts them into machine code.
type Progs struct {
Text *obj.Prog
Next *obj.Prog
PC int64
Pos src.XPos
CurFunc *ir.Func
Cache []obj.Prog
CacheIndex int
NextLive StackMapIndex
PrevLive StackMapIndex
NextUnsafe bool
PrevUnsafe bool
}
func (pp *Progs) Append(p *obj.Prog, as obj.As, ftype obj.AddrType, freg int16, foffset int64, ttype obj.AddrType, treg int16, toffset int64) *obj.Prog
BitVec writes the contents of bv into s as sequence of bytes in little-endian order, and returns the next unused offset.
func BitVec(s *obj.LSym, off int, bv bitvec.BitVec) int
func Bool(s *obj.LSym, off int, v bool) int
func (pp *Progs) Clear(p *obj.Prog)
Flush converts from pp to machine code.
func (pp *Progs) Flush()
Free clears pp and any associated resources.
func (pp *Progs) Free()
func Global(s *obj.LSym, width int32, flags int16)
LosesStmtMark reports whether a prog with op as loses its statement mark on the way to DWARF. The attributes from some opcodes are lost in translation. TODO: this is an artifact of how funcpctab combines information for instructions at a single PC. Should try to fix it there.
func LosesStmtMark(as obj.As) bool
func (pp *Progs) NewProg() *obj.Prog
NewProgs returns a new Progs for fn. worker indicates which of the backend workers will use the Progs.
func NewProgs(fn *ir.Func, worker int) *Progs
Prog adds a Prog with instruction As to pp.
func (pp *Progs) Prog(as obj.As) *obj.Prog
func (pp *Progs) SetText(fn *ir.Func)
func (s StackMapIndex) StackMapValid() bool
func SymPtr(s *obj.LSym, off int, x *obj.LSym, xoff int) int
func SymPtrOff(s *obj.LSym, off int, x *obj.LSym) int
func SymPtrWeak(s *obj.LSym, off int, x *obj.LSym, xoff int) int
func SymPtrWeakOff(s *obj.LSym, off int, x *obj.LSym) int
func Uint16(s *obj.LSym, off int, v uint16) int
func Uint32(s *obj.LSym, off int, v uint32) int
Uint8 writes an unsigned byte v into s at offset off, and returns the next unused offset (i.e., off+1).
func Uint8(s *obj.LSym, off int, v uint8) int
UintN writes an unsigned integer v of size wid bytes into s at offset off, and returns the next unused offset.
func UintN(s *obj.LSym, off int, v uint64, wid int) int
func Uintptr(s *obj.LSym, off int, v uint64) int
Uvarint writes a varint v into s at offset off, and returns the next unused offset.
func Uvarint(s *obj.LSym, off int, v uint64) int
Generated with Arrow