package loong64

import "cmd/internal/obj/loong64"

Index

Constants

const (
	NSNAME = 8
	NSYM   = 50
	NREG   = 32 // number of general registers
	NFREG  = 32 // number of floating point registers
	NVREG  = 32 // number of LSX registers
	NXREG  = 32 // number of LASX registers
)
const (
	REG_R0 = obj.RBaseLOONG64 + iota // must be a multiple of 32
	REG_R1
	REG_R2
	REG_R3
	REG_R4
	REG_R5
	REG_R6
	REG_R7
	REG_R8
	REG_R9
	REG_R10
	REG_R11
	REG_R12
	REG_R13
	REG_R14
	REG_R15
	REG_R16
	REG_R17
	REG_R18
	REG_R19
	REG_R20
	REG_R21
	REG_R22
	REG_R23
	REG_R24
	REG_R25
	REG_R26
	REG_R27
	REG_R28
	REG_R29
	REG_R30
	REG_R31

	REG_F0 // must be a multiple of 32
	REG_F1
	REG_F2
	REG_F3
	REG_F4
	REG_F5
	REG_F6
	REG_F7
	REG_F8
	REG_F9
	REG_F10
	REG_F11
	REG_F12
	REG_F13
	REG_F14
	REG_F15
	REG_F16
	REG_F17
	REG_F18
	REG_F19
	REG_F20
	REG_F21
	REG_F22
	REG_F23
	REG_F24
	REG_F25
	REG_F26
	REG_F27
	REG_F28
	REG_F29
	REG_F30
	REG_F31

	REG_FCSR0 // must be a multiple of 32
	REG_FCSR1
	REG_FCSR2
	REG_FCSR3 // only four registers are needed
	REG_FCSR4
	REG_FCSR5
	REG_FCSR6
	REG_FCSR7
	REG_FCSR8
	REG_FCSR9
	REG_FCSR10
	REG_FCSR11
	REG_FCSR12
	REG_FCSR13
	REG_FCSR14
	REG_FCSR15
	REG_FCSR16
	REG_FCSR17
	REG_FCSR18
	REG_FCSR19
	REG_FCSR20
	REG_FCSR21
	REG_FCSR22
	REG_FCSR23
	REG_FCSR24
	REG_FCSR25
	REG_FCSR26
	REG_FCSR27
	REG_FCSR28
	REG_FCSR29
	REG_FCSR30
	REG_FCSR31

	REG_FCC0 // must be a multiple of 32
	REG_FCC1
	REG_FCC2
	REG_FCC3
	REG_FCC4
	REG_FCC5
	REG_FCC6
	REG_FCC7 // only eight registers are needed
	REG_FCC8
	REG_FCC9
	REG_FCC10
	REG_FCC11
	REG_FCC12
	REG_FCC13
	REG_FCC14
	REG_FCC15
	REG_FCC16
	REG_FCC17
	REG_FCC18
	REG_FCC19
	REG_FCC20
	REG_FCC21
	REG_FCC22
	REG_FCC23
	REG_FCC24
	REG_FCC25
	REG_FCC26
	REG_FCC27
	REG_FCC28
	REG_FCC29
	REG_FCC30
	REG_FCC31

	// LSX: 128-bit vector register
	REG_V0
	REG_V1
	REG_V2
	REG_V3
	REG_V4
	REG_V5
	REG_V6
	REG_V7
	REG_V8
	REG_V9
	REG_V10
	REG_V11
	REG_V12
	REG_V13
	REG_V14
	REG_V15
	REG_V16
	REG_V17
	REG_V18
	REG_V19
	REG_V20
	REG_V21
	REG_V22
	REG_V23
	REG_V24
	REG_V25
	REG_V26
	REG_V27
	REG_V28
	REG_V29
	REG_V30
	REG_V31

	// LASX: 256-bit vector register
	REG_X0
	REG_X1
	REG_X2
	REG_X3
	REG_X4
	REG_X5
	REG_X6
	REG_X7
	REG_X8
	REG_X9
	REG_X10
	REG_X11
	REG_X12
	REG_X13
	REG_X14
	REG_X15
	REG_X16
	REG_X17
	REG_X18
	REG_X19
	REG_X20
	REG_X21
	REG_X22
	REG_X23
	REG_X24
	REG_X25
	REG_X26
	REG_X27
	REG_X28
	REG_X29
	REG_X30
	REG_X31

	REG_SPECIAL = REG_FCSR0

	REGZERO = REG_R0 // set to zero
	REGLINK = REG_R1
	REGSP   = REG_R3
	REGRT1  = REG_R20 // reserved for runtime, duffzero and duffcopy
	REGRT2  = REG_R21 // reserved for runtime, duffcopy
	REGCTXT = REG_R29 // context for closures
	REGG    = REG_R22 // G in loong64
	REGTMP  = REG_R30 // used by the assembler
	FREGRET = REG_F0  // not use
)
const (
	// mark flags
	LABEL  = 1 << 0
	LEAF   = 1 << 1
	SYNC   = 1 << 2
	BRANCH = 1 << 3
)
const (
	// arrangement types
	ARNG_32B int16 = iota
	ARNG_16H
	ARNG_8W
	ARNG_4V
	ARNG_2Q
	ARNG_16B
	ARNG_8H
	ARNG_4W
	ARNG_2V
	ARNG_B
	ARNG_H
	ARNG_W
	ARNG_V
	ARNG_BU
	ARNG_HU
	ARNG_WU
	ARNG_VU
)

Arrangement for Loong64 SIMD instructions

const (
	LSX int16 = iota
	LASX
)

LoongArch64 SIMD extension type

const (
	REG_ARNG = obj.RBaseLOONG64 + (1 << 10) + (iota << 11) // Vn.<T>
	REG_ELEM                                               // Vn.<T>[index]
	REG_ELEM_END
)

bits 0-4 indicates register: Vn or Xn bits 5-9 indicates arrangement: <T> bits 10 indicates SMID type: 0: LSX, 1: LASX

const (
	EXT_REG_SHIFT = 0
	EXT_REG_MASK  = 0x1f

	EXT_TYPE_SHIFT = 5
	EXT_TYPE_MASK  = 0x1f

	EXT_SIMDTYPE_SHIFT = 10
	EXT_SIMDTYPE_MASK  = 0x1
)
const (
	C_NONE = iota
	C_REG
	C_FREG
	C_FCSRREG
	C_FCCREG
	C_VREG
	C_XREG
	C_ARNG // Vn.<T>
	C_ELEM // Vn.<T>[index]

	C_ZCON
	C_U1CON      // 1 bit unsigned constant
	C_U2CON      // 2 bit unsigned constant
	C_U3CON      // 3 bit unsigned constant
	C_U4CON      // 4 bit unsigned constant
	C_U5CON      // 5 bit unsigned constant
	C_U6CON      // 6 bit unsigned constant
	C_U7CON      // 7 bit unsigned constant
	C_U8CON      // 8 bit unsigned constant
	C_S5CON      // 5 bit signed constant
	C_US12CON    // same as C_S12CON, increase the priority of C_S12CON in special cases.
	C_UU12CON    // same as C_U12CON, increase the priority of C_U12CON in special cases.
	C_S12CON     // 12 bit signed constant, -0x800 < v <= 0x7ff
	C_U12CON     // 12 bit unsigned constant, 0 < v <= 0xfff
	C_12CON      // 12 bit signed constant, or 12 bit unsigned constant
	C_S13CON20_0 // 13 bit signed constant, low 12 bits 0
	C_S13CON     // 13 bit signed constant
	C_U13CON20_0 // 13 bit unsigned constant, low 12 bits 0
	C_U13CON     // 13 bit unsigned constant
	C_13CON      // 13 bit signed constant, or 13 bit unsigned constant
	C_U15CON     // 15 bit unsigned constant
	C_U15CON20_0 // 15 bit unsigned constant, low 12 bits 0
	C_32CON20_0  // 32 bit signed, low 12 bits 0
	C_32CON      // other 32 bit signed

	// 64 bit signed, lo32 bits 0, hi20 bits are not 0, hi12 bits can
	// be obtained by sign extension of the hi20 bits.
	C_DCON20S_0
	// 64 bit signed, lo52 bits 0, hi12 bits are not 0.
	C_DCON12_0
	// 64 bit signed, lo32 bits 0, hi32 bits are not 0.
	C_DCON32_0
	// 64 bit signed, lo12 bits 0, lo20 bits are not 0, hi20 bits can be
	// obtained by sign extension of the lo20 bits, other bits are not 0.
	C_DCON12_20S
	// 64 bit signed, lo12 bits 0, hi20 bits are not 0, hi12 bits can be
	// obtained by sign extension of the hi20 bits, other bits are not 0.
	C_DCON20S_20
	// 64 bit signed, lo12 bits 0, other bits are not 0.
	C_DCON32_20
	// 64 bit signed, lo12 bits are not 0, 12~51 bits can be obtained
	// by sign extension of the lo12 bits, other bits are not 0.
	C_DCON12_12S
	// 64 bit signed, hi20 bits and lo12 bits are not 0, hi12 bits can
	// be obtained by sign extension of the hi20 bits, lo20 bits can
	// be obtained by sign extension of the lo12 bits.
	C_DCON20S_12S
	// 64 bit signed, lo12 bits are not 0, lo20 bits can be obtained by sign
	// extension of the lo12 bits, other bits are not 0.
	C_DCON32_12S
	// 64 bit signed, lo20 and lo12 bits are not 0, hi20 bits can be obtained by sign
	// extension of the lo20 bits. other bits are not 0.
	C_DCON12_32S
	// 64 bit signed, hi20 bits are not 0, hi12 bits can be obtained by sign
	// extension of the hi20 bits, lo32 bits are not 0.
	C_DCON20S_32
	// 64 bit signed, 12~51 bits 0, other bits are not 0.
	C_DCON12_12U
	// 64 bit signed, lo20 bits 0, hi20 bits are not 0, hi12 bits can be
	// obtained by sign extension of the hi20 bits, lo12 bits are not 0.
	C_DCON20S_12U
	// 64 bit signed, lo20 bits 0, other bits are not 0.
	C_DCON32_12U
	// other 64
	C_DCON

	C_SACON   // $n(REG) where n <= int12
	C_LACON   // $n(REG) where int12 < n <= int32
	C_DACON   // $n(REG) where int32 < n
	C_EXTADDR // external symbol address
	C_BRAN
	C_SAUTO
	C_LAUTO
	C_ZOREG
	C_SOREG
	C_LOREG
	C_ROFF // register offset
	C_ADDR
	C_TLS_LE
	C_TLS_IE
	C_GOTADDR
	C_TEXTSIZE

	C_GOK
	C_NCLASS // must be the last
)
const (
	AABSD = obj.ABaseLoong64 + obj.A_ARCHSPECIFIC + iota
	AABSF
	AADD
	AADDD
	AADDF
	AADDU

	AADDW
	AAND
	ABEQ
	ABGEZ
	ABLEZ
	ABGTZ
	ABLTZ
	ABFPF
	ABFPT

	ABNE
	ABREAK

	ACMPEQD
	ACMPEQF

	ACMPGED // ACMPGED -> fcmp.sle.d
	ACMPGEF // ACMPGEF -> fcmp.sle.s
	ACMPGTD // ACMPGTD -> fcmp.slt.d
	ACMPGTF // ACMPGTF -> fcmp.slt.s

	ALU12IW
	ALU32ID
	ALU52ID
	APCALAU12I
	APCADDU12I
	AJIRL
	ABGE
	ABLT
	ABLTU
	ABGEU

	ADIV
	ADIVD
	ADIVF
	ADIVU
	ADIVW

	ALL
	ALLV

	ALUI

	AMOVB
	AMOVBU

	AMOVD
	AMOVDF
	AMOVDW
	AMOVF
	AMOVFD
	AMOVFW

	AMOVH
	AMOVHU
	AMOVW

	AMOVWD
	AMOVWF

	AMUL
	AMULD
	AMULF
	AMULU
	AMULH
	AMULHU
	AMULW
	ANEGD
	ANEGF

	ANEGW
	ANEGV

	ANOOP // hardware nop
	ANOR
	AOR
	AREM
	AREMU

	ARFE

	ASC
	ASCV

	ASGT
	ASGTU

	ASLL
	ASQRTD
	ASQRTF
	ASRA
	ASRL
	AROTR
	ASUB
	ASUBD
	ASUBF

	ASUBU
	ASUBW
	ADBAR
	ASYSCALL

	ATEQ
	ATNE

	AWORD

	AXOR

	AMASKEQZ
	AMASKNEZ

	// 64-bit
	AMOVV

	ASLLV
	ASRAV
	ASRLV
	AROTRV
	ADIVV
	ADIVVU

	AREMV
	AREMVU

	AMULV
	AMULVU
	AMULHV
	AMULHVU
	AADDV
	AADDVU
	ASUBV
	ASUBVU

	// 64-bit FP
	ATRUNCFV
	ATRUNCDV
	ATRUNCFW
	ATRUNCDW

	AMOVWU
	AMOVFV
	AMOVDV
	AMOVVF
	AMOVVD

	// 2.2.1.8
	AORN
	AANDN

	// 2.2.7. Atomic Memory Access Instructions
	AAMSWAPB
	AAMSWAPH
	AAMSWAPW
	AAMSWAPV
	AAMCASB
	AAMCASH
	AAMCASW
	AAMCASV
	AAMADDW
	AAMADDV
	AAMANDW
	AAMANDV
	AAMORW
	AAMORV
	AAMXORW
	AAMXORV
	AAMMAXW
	AAMMAXV
	AAMMINW
	AAMMINV
	AAMMAXWU
	AAMMAXVU
	AAMMINWU
	AAMMINVU
	AAMSWAPDBB
	AAMSWAPDBH
	AAMSWAPDBW
	AAMSWAPDBV
	AAMCASDBB
	AAMCASDBH
	AAMCASDBW
	AAMCASDBV
	AAMADDDBW
	AAMADDDBV
	AAMANDDBW
	AAMANDDBV
	AAMORDBW
	AAMORDBV
	AAMXORDBW
	AAMXORDBV
	AAMMAXDBW
	AAMMAXDBV
	AAMMINDBW
	AAMMINDBV
	AAMMAXDBWU
	AAMMAXDBVU
	AAMMINDBWU
	AAMMINDBVU

	// 2.2.3.1
	AEXTWB
	AEXTWH

	// 2.2.3.2
	ACLOW
	ACLOV
	ACLZW
	ACLZV
	ACTOW
	ACTOV
	ACTZW
	ACTZV

	// 2.2.3.4
	AREVBV
	AREVB2W
	AREVB4H
	AREVB2H

	// 2.2.3.5
	AREVH2W
	AREVHV

	// 2.2.3.6
	ABITREV4B
	ABITREV8B

	// 2.2.3.7
	ABITREVW
	ABITREVV

	// 2.2.3.8
	ABSTRINSW
	ABSTRINSV

	// 2.2.3.9
	ABSTRPICKW
	ABSTRPICKV

	// 2.2.5.4. Prefetch Instructions
	APRELD
	APRELDX

	// 2.2.9. CRC Check Instructions
	ACRCWBW
	ACRCWHW
	ACRCWWW
	ACRCWVW
	ACRCCWBW
	ACRCCWHW
	ACRCCWWW
	ACRCCWVW

	// 2.2.10. Other Miscellaneous Instructions
	ARDTIMELW
	ARDTIMEHW
	ARDTIMED
	ACPUCFG

	// 3.2.1.2
	AFMADDF
	AFMADDD
	AFMSUBF
	AFMSUBD
	AFNMADDF
	AFNMADDD
	AFNMSUBF
	AFNMSUBD

	// 3.2.1.3
	AFMINF
	AFMIND
	AFMAXF
	AFMAXD

	// 3.2.1.4
	AFMAXAF
	AFMAXAD
	AFMINAF
	AFMINAD

	// 3.2.1.7
	AFCOPYSGF
	AFCOPYSGD
	AFSCALEBF
	AFSCALEBD
	AFLOGBF
	AFLOGBD

	// 3.2.1.8
	AFCLASSF
	AFCLASSD

	// 3.2.3.2
	AFFINTFW
	AFFINTFV
	AFFINTDW
	AFFINTDV
	AFTINTWF
	AFTINTWD
	AFTINTVF
	AFTINTVD

	// 3.2.3.3
	AFTINTRPWF
	AFTINTRPWD
	AFTINTRPVF
	AFTINTRPVD
	AFTINTRMWF
	AFTINTRMWD
	AFTINTRMVF
	AFTINTRMVD
	AFTINTRZWF
	AFTINTRZWD
	AFTINTRZVF
	AFTINTRZVD
	AFTINTRNEWF
	AFTINTRNEWD
	AFTINTRNEVF
	AFTINTRNEVD

	// LSX and LASX memory access instructions
	AVMOVQ
	AXVMOVQ

	// LSX and LASX arithmetic instructions
	AVADDB
	AVADDH
	AVADDW
	AVADDV
	AVADDQ
	AXVADDB
	AXVADDH
	AXVADDW
	AXVADDV
	AXVADDQ
	AVSUBB
	AVSUBH
	AVSUBW
	AVSUBV
	AVSUBQ
	AXVSUBB
	AXVSUBH
	AXVSUBW
	AXVSUBV
	AXVSUBQ
	AVADDBU
	AVADDHU
	AVADDWU
	AVADDVU
	AVSUBBU
	AVSUBHU
	AVSUBWU
	AVSUBVU
	AXVADDBU
	AXVADDHU
	AXVADDWU
	AXVADDVU
	AXVSUBBU
	AXVSUBHU
	AXVSUBWU
	AXVSUBVU

	// LSX and LASX Bit-manipulation Instructions
	AVANDB
	AVORB
	AVXORB
	AVNORB
	AXVANDB
	AXVORB
	AXVXORB
	AXVNORB
	AVANDV
	AVORV
	AVXORV
	AVNORV
	AVANDNV
	AVORNV
	AXVANDV
	AXVORV
	AXVXORV
	AXVNORV
	AXVANDNV
	AXVORNV

	AVPCNTB
	AVPCNTH
	AVPCNTW
	AVPCNTV
	AXVPCNTB
	AXVPCNTH
	AXVPCNTW
	AXVPCNTV

	// LSX and LASX integer comparison instruction
	AVSEQB
	AXVSEQB
	AVSEQH
	AXVSEQH
	AVSEQW
	AXVSEQW
	AVSEQV
	AXVSEQV

	// LSX and LASX integer div and mod instructions
	AVDIVB
	AVDIVH
	AVDIVW
	AVDIVV
	AVDIVBU
	AVDIVHU
	AVDIVWU
	AVDIVVU
	AVMODB
	AVMODH
	AVMODW
	AVMODV
	AVMODBU
	AVMODHU
	AVMODWU
	AVMODVU
	AXVDIVB
	AXVDIVH
	AXVDIVW
	AXVDIVV
	AXVDIVBU
	AXVDIVHU
	AXVDIVWU
	AXVDIVVU
	AXVMODB
	AXVMODH
	AXVMODW
	AXVMODV
	AXVMODBU
	AXVMODHU
	AXVMODWU
	AXVMODVU

	// LSX and LASX shift operation instructions
	AVSLLB
	AVSLLH
	AVSLLW
	AVSLLV
	AVSRLB
	AVSRLH
	AVSRLW
	AVSRLV
	AVSRAB
	AVSRAH
	AVSRAW
	AVSRAV
	AVROTRB
	AVROTRH
	AVROTRW
	AVROTRV
	AXVSLLB
	AXVSLLH
	AXVSLLW
	AXVSLLV
	AXVSRLB
	AXVSRLH
	AXVSRLW
	AXVSRLV
	AXVSRAB
	AXVSRAH
	AXVSRAW
	AXVSRAV
	AXVROTRB
	AXVROTRH
	AXVROTRW
	AXVROTRV

	// LSX and LASX move and shuffle instructions
	AVILVLB
	AVILVLH
	AVILVLW
	AVILVLV
	AVILVHB
	AVILVHH
	AVILVHW
	AVILVHV
	AXVILVLB
	AXVILVLH
	AXVILVLW
	AXVILVLV
	AXVILVHB
	AXVILVHH
	AXVILVHW
	AXVILVHV

	// LSX and LASX integer mul instructions
	AVMULB
	AVMULH
	AVMULW
	AVMULV
	AVMUHB
	AVMUHH
	AVMUHW
	AVMUHV
	AVMUHBU
	AVMUHHU
	AVMUHWU
	AVMUHVU
	AXVMULB
	AXVMULH
	AXVMULW
	AXVMULV
	AXVMUHB
	AXVMUHH
	AXVMUHW
	AXVMUHV
	AXVMUHBU
	AXVMUHHU
	AXVMUHWU
	AXVMUHVU

	// LSX and LASX floating point instructions
	AVFSQRTF
	AVFSQRTD
	AVFRECIPF
	AVFRECIPD
	AVFRSQRTF
	AVFRSQRTD
	AXVFSQRTF
	AXVFSQRTD
	AXVFRECIPF
	AXVFRECIPD
	AXVFRSQRTF
	AXVFRSQRTD

	AVADDF
	AVADDD
	AVSUBF
	AVSUBD
	AVMULF
	AVMULD
	AVDIVF
	AVDIVD
	AXVADDF
	AXVADDD
	AXVSUBF
	AXVSUBD
	AXVMULF
	AXVMULD
	AXVDIVF
	AXVDIVD

	AVFCLASSF
	AVFCLASSD
	AXVFCLASSF
	AXVFCLASSD

	// LSX and LASX floating point conversion instructions
	AVFRINTRNEF
	AVFRINTRNED
	AVFRINTRZF
	AVFRINTRZD
	AVFRINTRPF
	AVFRINTRPD
	AVFRINTRMF
	AVFRINTRMD
	AVFRINTF
	AVFRINTD
	AXVFRINTRNEF
	AXVFRINTRNED
	AXVFRINTRZF
	AXVFRINTRZD
	AXVFRINTRPF
	AXVFRINTRPD
	AXVFRINTRMF
	AXVFRINTRMD
	AXVFRINTF
	AXVFRINTD

	// LSX and LASX integer neg instructions
	AVNEGB
	AVNEGH
	AVNEGW
	AVNEGV
	AXVNEGB
	AXVNEGH
	AXVNEGW
	AXVNEGV

	// LSX and LASX mul instructions that operate on even or odd positions
	AVMULWEVHB
	AVMULWEVWH
	AVMULWEVVW
	AVMULWEVQV
	AVMULWODHB
	AVMULWODWH
	AVMULWODVW
	AVMULWODQV
	AVMULWEVHBU
	AVMULWEVWHU
	AVMULWEVVWU
	AVMULWEVQVU
	AVMULWODHBU
	AVMULWODWHU
	AVMULWODVWU
	AVMULWODQVU
	AXVMULWEVHB
	AXVMULWEVWH
	AXVMULWEVVW
	AXVMULWEVQV
	AXVMULWODHB
	AXVMULWODWH
	AXVMULWODVW
	AXVMULWODQV
	AXVMULWEVHBU
	AXVMULWEVWHU
	AXVMULWEVVWU
	AXVMULWEVQVU
	AXVMULWODHBU
	AXVMULWODWHU
	AXVMULWODVWU
	AXVMULWODQVU
	AVMULWEVHBUB
	AVMULWEVWHUH
	AVMULWEVVWUW
	AVMULWEVQVUV
	AVMULWODHBUB
	AVMULWODWHUH
	AVMULWODVWUW
	AVMULWODQVUV
	AXVMULWEVHBUB
	AXVMULWEVWHUH
	AXVMULWEVVWUW
	AXVMULWEVQVUV
	AXVMULWODHBUB
	AXVMULWODWHUH
	AXVMULWODVWUW
	AXVMULWODQVUV

	AVSHUF4IB
	AVSHUF4IH
	AVSHUF4IW
	AVSHUF4IV
	AXVSHUF4IB
	AXVSHUF4IH
	AXVSHUF4IW
	AXVSHUF4IV

	AVSETEQV
	AVSETNEV
	AVSETANYEQB
	AVSETANYEQH
	AVSETANYEQW
	AVSETANYEQV
	AVSETALLNEB
	AVSETALLNEH
	AVSETALLNEW
	AVSETALLNEV
	AXVSETEQV
	AXVSETNEV
	AXVSETANYEQB
	AXVSETANYEQH
	AXVSETANYEQW
	AXVSETANYEQV
	AXVSETALLNEB
	AXVSETALLNEH
	AXVSETALLNEW
	AXVSETALLNEV

	ALAST

	// aliases
	AJMP = obj.AJMP
	AJAL = obj.ACALL
	ARET = obj.ARET
)
const (
	ALL1 = iota
	ALL0
	ST1
	ST0
)

The constants here define the data characteristics within the bit field range.

ALL1: The data in the bit field is all 1
ALL0: The data in the bit field is all 0
ST1: The data in the bit field starts with 1, but not all 1
ST0: The data in the bit field starts with 0, but not all 0
const (
	BIG = 2046
)
const (
	FuncAlign = 4
)
const (
	NOTUSETMP = 1 << iota // p expands to multiple instructions, but does NOT use REGTMP

)
const (
	REG_LAST = REG_ELEM_END // the last defined register
)

Variables

var Anames = []string{ /* 571 elements not displayed */

}
var LOONG64DWARFRegisters = map[int16]int16{}
var Linkloong64 = obj.LinkArch{
	Arch:           sys.ArchLoong64,
	Init:           buildop,
	Preprocess:     preprocess,
	Assemble:       span0,
	Progedit:       progedit,
	DWARFRegisters: LOONG64DWARFRegisters,
}

Functions

func DRconv

func DRconv(a int) string

func IsAtomicInst

func IsAtomicInst(as obj.As) bool

func OP_12IRR

func OP_12IRR(op uint32, i uint32, r2 uint32, r3 uint32) uint32

func OP_12IR_5I

func OP_12IR_5I(op uint32, i1 uint32, r2 uint32, i2 uint32) uint32

func OP_15I

func OP_15I(op uint32, i uint32) uint32

func OP_16IRR

func OP_16IRR(op uint32, i uint32, r2 uint32, r3 uint32) uint32

func OP_16IR_5I

func OP_16IR_5I(op uint32, i uint32, r2 uint32) uint32

func OP_3IRR

func OP_3IRR(op uint32, i uint32, r2 uint32, r3 uint32) uint32

func OP_4IRR

func OP_4IRR(op uint32, i uint32, r2 uint32, r3 uint32) uint32

func OP_5IRR

func OP_5IRR(op uint32, i uint32, r2 uint32, r3 uint32) uint32

func OP_6IRR

func OP_6IRR(op uint32, i uint32, r2 uint32, r3 uint32) uint32

func OP_8IRR

func OP_8IRR(op uint32, i uint32, r2 uint32, r3 uint32) uint32

func OP_B_BL

func OP_B_BL(op uint32, i uint32) uint32

Encoding for the 'b' or 'bl' instruction.

func OP_IR

func OP_IR(op uint32, i uint32, r2 uint32) uint32

func OP_IRIR

func OP_IRIR(op uint32, i1 uint32, r2 uint32, i3 uint32, r4 uint32) uint32

i1 -> msb r2 -> rj i3 -> lsb r4 -> rd

func OP_RR

func OP_RR(op uint32, r2 uint32, r3 uint32) uint32

r2 -> rj r3 -> rd

func OP_RRR

func OP_RRR(op uint32, r1 uint32, r2 uint32, r3 uint32) uint32

r1 -> rk r2 -> rj r3 -> rd

func OP_RRRR

func OP_RRRR(op uint32, r1 uint32, r2 uint32, r3 uint32, r4 uint32) uint32

Types

type Optab

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

Source Files

a.out.go anames.go asm.go cnames.go doc.go list.go obj.go

Version
v1.25.0-rc.1
Published
Jun 11, 2025
Platform
darwin/amd64
Imports
10 packages
Last checked
5 minutes ago

Tools for package owners.