insts

package
v2.0.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 17, 2022 License: MIT Imports: 10 Imported by: 21

Documentation

Overview

Package insts provides the definition for GCN3 instructions.

Index

Constants

View Source
const (
	InvalidOperantType = iota
	RegOperand
	FloatOperand
	IntOperand
	LiteralConstant
)

Operand types

View Source
const (
	InvalidRegType = iota
	PC
	V0
	V1
	V2
	V3
	V4
	V5
	V6
	V7
	V8
	V9
	V10
	V11
	V12
	V13
	V14
	V15
	V16
	V17
	V18
	V19
	V20
	V21
	V22
	V23
	V24
	V25
	V26
	V27
	V28
	V29
	V30
	V31
	V32
	V33
	V34
	V35
	V36
	V37
	V38
	V39
	V40
	V41
	V42
	V43
	V44
	V45
	V46
	V47
	V48
	V49
	V50
	V51
	V52
	V53
	V54
	V55
	V56
	V57
	V58
	V59
	V60
	V61
	V62
	V63
	V64
	V65
	V66
	V67
	V68
	V69
	V70
	V71
	V72
	V73
	V74
	V75
	V76
	V77
	V78
	V79
	V80
	V81
	V82
	V83
	V84
	V85
	V86
	V87
	V88
	V89
	V90
	V91
	V92
	V93
	V94
	V95
	V96
	V97
	V98
	V99
	V100
	V101
	V102
	V103
	V104
	V105
	V106
	V107
	V108
	V109
	V110
	V111
	V112
	V113
	V114
	V115
	V116
	V117
	V118
	V119
	V120
	V121
	V122
	V123
	V124
	V125
	V126
	V127
	V128
	V129
	V130
	V131
	V132
	V133
	V134
	V135
	V136
	V137
	V138
	V139
	V140
	V141
	V142
	V143
	V144
	V145
	V146
	V147
	V148
	V149
	V150
	V151
	V152
	V153
	V154
	V155
	V156
	V157
	V158
	V159
	V160
	V161
	V162
	V163
	V164
	V165
	V166
	V167
	V168
	V169
	V170
	V171
	V172
	V173
	V174
	V175
	V176
	V177
	V178
	V179
	V180
	V181
	V182
	V183
	V184
	V185
	V186
	V187
	V188
	V189
	V190
	V191
	V192
	V193
	V194
	V195
	V196
	V197
	V198
	V199
	V200
	V201
	V202
	V203
	V204
	V205
	V206
	V207
	V208
	V209
	V210
	V211
	V212
	V213
	V214
	V215
	V216
	V217
	V218
	V219
	V220
	V221
	V222
	V223
	V224
	V225
	V226
	V227
	V228
	V229
	V230
	V231
	V232
	V233
	V234
	V235
	V236
	V237
	V238
	V239
	V240
	V241
	V242
	V243
	V244
	V245
	V246
	V247
	V248
	V249
	V250
	V251
	V252
	V253
	V254
	V255
	S0
	S1
	S2
	S3
	S4
	S5
	S6
	S7
	S8
	S9
	S10
	S11
	S12
	S13
	S14
	S15
	S16
	S17
	S18
	S19
	S20
	S21
	S22
	S23
	S24
	S25
	S26
	S27
	S28
	S29
	S30
	S31
	S32
	S33
	S34
	S35
	S36
	S37
	S38
	S39
	S40
	S41
	S42
	S43
	S44
	S45
	S46
	S47
	S48
	S49
	S50
	S51
	S52
	S53
	S54
	S55
	S56
	S57
	S58
	S59
	S60
	S61
	S62
	S63
	S64
	S65
	S66
	S67
	S68
	S69
	S70
	S71
	S72
	S73
	S74
	S75
	S76
	S77
	S78
	S79
	S80
	S81
	S82
	S83
	S84
	S85
	S86
	S87
	S88
	S89
	S90
	S91
	S92
	S93
	S94
	S95
	S96
	S97
	S98
	S99
	S100
	S101
	EXEC
	EXECLO
	EXECHI
	EXECZ
	VCC
	VCCLO
	VCCHI
	VCCZ
	SCC
	FlatSratch
	FlatSratchLo
	FlatSratchHi
	XnackMask
	XnackMaskLo
	XnackMaskHi
	Status
	Mode
	M0
	Trapsts
	Tba
	TbaLo
	TbaHi
	Tma
	TmaLo
	TmaHi
	Timp0
	Timp1
	Timp2
	Timp3
	Timp4
	Timp5
	Timp6
	Timp7
	Timp8
	Timp9
	Timp10
	Timp11
	VMCNT
	EXPCNT
	LGKMCNT
)

All the registers

Variables

View Source
var FormatTable map[FormatType]*Format

FormatTable is a table that uses FormatType to find detailed format information about the format.

View Source
var Regs = map[RegType]*Reg{}/* 400 elements not displayed */

Regs are a list of all registers

Functions

func BytesToUint32

func BytesToUint32(data []byte) uint32

BytesToUint32 decode a uint32 number from bytes

func BytesToUint64

func BytesToUint64(data []byte) uint64

BytesToUint64 decode a uint64 number from bytes

func BytesToUint8

func BytesToUint8(data []byte) uint8

BytesToUint8 decode a uint32 number from bytes

func Uint32ToBytes

func Uint32ToBytes(num uint32) []byte

Uint32ToBytes returns the bytes representation of a uint32 value

func Uint64ToBytes

func Uint64ToBytes(num uint64) []byte

Uint64ToBytes returns the bytes representation of a uint64 value

func Uint8ToBytes

func Uint8ToBytes(num uint8) []byte

Uint8ToBytes returns the bytes representation of a uint32 value

Types

type Disassembler

type Disassembler struct {
	// contains filtered or unexported fields
}

Disassembler is the unit that can decode .hsaco file

func NewDisassembler

func NewDisassembler() *Disassembler

NewDisassembler creates a new disassembler

func (*Disassembler) Decode

func (d *Disassembler) Decode(buf []byte) (*Inst, error)

Decode parses the head of the buffer and returns the next instruction

func (*Disassembler) Disassemble

func (d *Disassembler) Disassemble(
	file *elf.File,
	filename string,
	w io.Writer,
)

Disassemble take a binary file as an input and put the assembly code in a writer

type ExeUnit

type ExeUnit int

ExeUnit defines which execution unit should execute the instruction

const (
	ExeUnitVALU ExeUnit = iota
	ExeUnitScalar
	ExeUnitVMem
	ExeUnitBranch
	ExeUnitLDS
	ExeUnitGDS
	ExeUnitSpecial
)

Defines all possible execution units

type Format

type Format struct {
	FormatType        FormatType
	FormatName        string
	Encoding          uint32
	Mask              uint32
	ByteSizeExLiteral int
	OpcodeLow         uint8
	OpcodeHigh        uint8
}

Format defines the possible microcode format of instructions

type FormatType

type FormatType int

FormatType is a enumeration of all the instruction formats defined by GCN3

const (
	SOP2 FormatType = iota
	SOPK
	SOP1
	SOPC
	SOPP
	SMEM
	VOP2
	VOP1
	VOP3a
	VOP3b
	VOPC
	VINTRP
	DS
	MUBUF
	MTBUF
	MIMG
	EXP
	FLAT
)

All the GCN3 instruction formats

type HsaCo

type HsaCo struct {
	*HsaCoHeader
	Data []byte
}

An HsaCo is the kernel code to be executed on an AMD GPU

func NewHsaCo

func NewHsaCo() *HsaCo

NewHsaCo creates a zero-filled HsaCo object

func NewHsaCoFromData

func NewHsaCoFromData(data []byte) *HsaCo

NewHsaCoFromData creates an HsaCo with the provided data

func (*HsaCo) InstructionData

func (o *HsaCo) InstructionData() []byte

InstructionData returns the instruction binaries in the HsaCo

type HsaCoHeader

type HsaCoHeader struct {
	CodeVersionMajor                uint32
	CodeVersionMinor                uint32
	MachineKind                     uint16
	MachineVersionMajor             uint16
	MachineVersionMinor             uint16
	MachineVersionStepping          uint16
	KernelCodeEntryByteOffset       uint64
	KernelCodePrefetchByteOffset    uint64
	KernelCodePrefetchByteSize      uint64
	MaxScratchBackingMemoryByteSize uint64
	ComputePgmRsrc1                 uint32
	ComputePgmRsrc2                 uint32
	Flags                           uint32
	WIPrivateSegmentByteSize        uint32
	WGGroupSegmentByteSize          uint32
	GDSSegmentByteSize              uint32
	KernargSegmentByteSize          uint64
	WGFBarrierCount                 uint32
	WFSgprCount                     uint16
	WIVgprCount                     uint16
	ReservedVgprFirst               uint16
	ReservedVgprCount               uint16
	ReservedSgprFirst               uint16
	ReservedSgprCount               uint16
	DebugWfPrivateSegmentOffsetSgpr uint16
	DebugPrivateSegmentBufferSgpr   uint16
	KernargSegmentAlignment         uint8
	GroupSegmentAlignment           uint8
	PrivateSegmentAlignment         uint8
	WavefrontSize                   uint8
	CallConvention                  uint32
	Reserved                        [12]byte
	RuntimeLoaderKernelSymbol       uint64
	ControlDirective                [128]byte
}

HsaCoHeader contains the header information of an HSACO

func (*HsaCoHeader) EnableExceptionAddressWatch

func (h *HsaCoHeader) EnableExceptionAddressWatch() bool

EnableExceptionAddressWatch enable exception address watch

func (*HsaCoHeader) EnableExceptionMemoryViolation

func (h *HsaCoHeader) EnableExceptionMemoryViolation() bool

EnableExceptionMemoryViolation enable exception memory violation

func (*HsaCoHeader) EnableSgprDispatchID

func (h *HsaCoHeader) EnableSgprDispatchID() bool

EnableSgprDispatchID enables dispatch ID

func (*HsaCoHeader) EnableSgprDispatchPtr

func (h *HsaCoHeader) EnableSgprDispatchPtr() bool

EnableSgprDispatchPtr enables dispatch ptr

func (*HsaCoHeader) EnableSgprFlatScratchInit

func (h *HsaCoHeader) EnableSgprFlatScratchInit() bool

EnableSgprFlatScratchInit enables init

func (*HsaCoHeader) EnableSgprGridWorkGroupCountX

func (h *HsaCoHeader) EnableSgprGridWorkGroupCountX() bool

EnableSgprGridWorkGroupCountX enables wg countx

func (*HsaCoHeader) EnableSgprGridWorkGroupCountY

func (h *HsaCoHeader) EnableSgprGridWorkGroupCountY() bool

EnableSgprGridWorkGroupCountY enables wg county

func (*HsaCoHeader) EnableSgprGridWorkGroupCountZ

func (h *HsaCoHeader) EnableSgprGridWorkGroupCountZ() bool

EnableSgprGridWorkGroupCountZ enables wg countz

func (*HsaCoHeader) EnableSgprKernelArgSegmentPtr

func (h *HsaCoHeader) EnableSgprKernelArgSegmentPtr() bool

EnableSgprKernelArgSegmentPtr enables

func (*HsaCoHeader) EnableSgprPrivateSegementSize

func (h *HsaCoHeader) EnableSgprPrivateSegementSize() bool

EnableSgprPrivateSegementSize enables size

func (*HsaCoHeader) EnableSgprPrivateSegmentBuffer

func (h *HsaCoHeader) EnableSgprPrivateSegmentBuffer() bool

EnableSgprPrivateSegmentBuffer checks if the private segment buffer information need to write into the SGPR

func (*HsaCoHeader) EnableSgprPrivateSegmentWaveByteOffset

func (h *HsaCoHeader) EnableSgprPrivateSegmentWaveByteOffset() bool

EnableSgprPrivateSegmentWaveByteOffset enable wavebyteoffset

func (*HsaCoHeader) EnableSgprQueuePtr

func (h *HsaCoHeader) EnableSgprQueuePtr() bool

EnableSgprQueuePtr enables queue ptr

func (*HsaCoHeader) EnableSgprWorkGroupIDX

func (h *HsaCoHeader) EnableSgprWorkGroupIDX() bool

EnableSgprWorkGroupIDX enable idx

func (*HsaCoHeader) EnableSgprWorkGroupIDY

func (h *HsaCoHeader) EnableSgprWorkGroupIDY() bool

EnableSgprWorkGroupIDY enable idy

func (*HsaCoHeader) EnableSgprWorkGroupIDZ

func (h *HsaCoHeader) EnableSgprWorkGroupIDZ() bool

EnableSgprWorkGroupIDZ enable idz

func (*HsaCoHeader) EnableSgprWorkGroupInfo

func (h *HsaCoHeader) EnableSgprWorkGroupInfo() bool

EnableSgprWorkGroupInfo enable wg info

func (*HsaCoHeader) EnableVgprWorkItemID

func (h *HsaCoHeader) EnableVgprWorkItemID() uint32

EnableVgprWorkItemID checks if the setup of the work-item is enabled

func (*HsaCoHeader) Info

func (h *HsaCoHeader) Info() string

Info prints the human readable information that is carried by the HsaCoHeader

func (*HsaCoHeader) Priority

func (h *HsaCoHeader) Priority() uint32

Priority returns the priority of the kernel

func (*HsaCoHeader) UserSgprCount

func (h *HsaCoHeader) UserSgprCount() uint32

UserSgprCount returns user sgpr

func (*HsaCoHeader) WavefrontSgprCount

func (h *HsaCoHeader) WavefrontSgprCount() uint32

WavefrontSgprCount returns the number of SGPRs used by each wavefront

func (*HsaCoHeader) WorkItemVgprCount

func (h *HsaCoHeader) WorkItemVgprCount() uint32

WorkItemVgprCount returns the number of VGPRs used by each work-item

type Inst

type Inst struct {
	*Format
	*InstType
	ByteSize int
	PC       uint64

	Src0 *Operand
	Src1 *Operand
	Src2 *Operand
	Dst  *Operand
	SDst *Operand // For VOP3b

	Addr   *Operand
	Data   *Operand
	Data1  *Operand
	Base   *Operand
	Offset *Operand
	SImm16 *Operand

	Abs                 int
	Omod                int
	Neg                 int
	Offset0             uint32
	Offset1             uint32
	SystemLevelCoherent bool
	GlobalLevelCoherent bool
	TextureFailEnable   bool
	Imm                 bool
	Clamp               bool
	GDS                 bool
	VMCNT               int
	LKGMCNT             int

	//Fields for SDWA extensions
	IsSdwa    bool
	DstSel    SDWASelect
	DstUnused SDWAUnused
	Src0Sel   SDWASelect
	Src0Sext  bool
	Src0Neg   bool
	Src0Abs   bool
	Src1Sel   SDWASelect
	Src1Sext  bool
	Src1Neg   bool
	Src1Abs   bool
	Src2Neg   bool
	Src2Abs   bool
}

An Inst is a GCN3 instruction

func NewInst

func NewInst() *Inst

NewInst creates a zero-filled instruction

func (Inst) String

func (i Inst) String(file *elf.File) string

String returns the disassembly of an instruction

type InstType

type InstType struct {
	InstName  string
	Opcode    Opcode
	Format    *Format
	ID        int
	ExeUnit   ExeUnit
	DSTWidth  int
	SRC0Width int
	SRC1Width int
	SRC2Width int
	SDSTWidth int
}

A InstType represents an instruction type. For example s_barrier instruction is a instruction type

type Opcode

type Opcode uint16

Opcode is the opcode of a GCN3 Instruction

type Operand

type Operand struct {
	Code            int
	OperandType     OperandType
	Register        *Reg
	RegCount        int // for cases like v[0:3]
	FloatValue      float64
	IntValue        int64
	LiteralConstant uint32
}

An Operand is an operand

func NewFloatOperand

func NewFloatOperand(code int, value float64) *Operand

NewFloatOperand returns a new operand of an floating point type

func NewIntOperand

func NewIntOperand(code int, value int64) *Operand

NewIntOperand returns a new operand of an integer type

func NewRegOperand

func NewRegOperand(code int, reg RegType, count int) *Operand

NewRegOperand returns a new operand of register type

func NewSRegOperand

func NewSRegOperand(code int, index int, count int) *Operand

NewSRegOperand returns a new operand of s register type

func NewVRegOperand

func NewVRegOperand(code int, index int, count int) *Operand

NewVRegOperand returns a new operand of v register type

func (Operand) String

func (o Operand) String() string

type OperandType

type OperandType int

OperandType represents the type of an operand. It can be Reg, Float, Int ...

type Reg

type Reg struct {
	RegType  RegType
	Name     string
	ByteSize int
	IsBool   bool
}

Reg is the representation of a register

func SReg

func SReg(index int) *Reg

SReg returns a scalar register object given a certain index

func VReg

func VReg(index int) *Reg

VReg returns a vector register object given a certain index

func (*Reg) IsSReg

func (r *Reg) IsSReg() bool

IsSReg checks if a register is a scalar register

func (*Reg) IsVReg

func (r *Reg) IsVReg() bool

IsVReg checks if a register is a vector register

func (*Reg) RegIndex

func (r *Reg) RegIndex() int

RegIndex returns the index of the index in the s-series or the v-series. If the register is not s or v register, -1 is returned.

type RegType

type RegType int

RegType is the register type

type SDWASelect

type SDWASelect uint32

SDWASelect defines the sub-dword selection type

const (
	SDWASelectByte0 SDWASelect = 0x000000ff
	SDWASelectByte1 SDWASelect = 0x0000ff00
	SDWASelectByte2 SDWASelect = 0x00ff0000
	SDWASelectByte3 SDWASelect = 0xff000000
	SDWASelectWord0 SDWASelect = 0x0000ffff
	SDWASelectWord1 SDWASelect = 0xffff0000
	SDWASelectDWord SDWASelect = 0xffffffff
)

Defines all possible sub-dword selection type

type SDWAUnused

type SDWAUnused uint8

SDWAUnused defines how to deal with unused bits

const (
	SDWAUnusedPad      SDWAUnused = 0
	SDWAUnusedSEXT     SDWAUnused = 1
	SDWAUnusedPreserve SDWAUnused = 2
)

Defines all possible SDWA unused options

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL