cranelift::prelude::isa::aarch64::inst

Enum Inst

pub enum Inst {
Show 137 variants Nop0, Nop4, AluRRR { alu_op: ALUOp, size: OperandSize, rd: Writable<Reg>, rn: Reg, rm: Reg, }, AluRRRR { alu_op: ALUOp3, size: OperandSize, rd: Writable<Reg>, rn: Reg, rm: Reg, ra: Reg, }, AluRRImm12 { alu_op: ALUOp, size: OperandSize, rd: Writable<Reg>, rn: Reg, imm12: Imm12, }, AluRRImmLogic { alu_op: ALUOp, size: OperandSize, rd: Writable<Reg>, rn: Reg, imml: ImmLogic, }, AluRRImmShift { alu_op: ALUOp, size: OperandSize, rd: Writable<Reg>, rn: Reg, immshift: ImmShift, }, AluRRRShift { alu_op: ALUOp, size: OperandSize, rd: Writable<Reg>, rn: Reg, rm: Reg, shiftop: ShiftOpAndAmt, }, AluRRRExtend { alu_op: ALUOp, size: OperandSize, rd: Writable<Reg>, rn: Reg, rm: Reg, extendop: ExtendOp, }, BitRR { op: BitOp, size: OperandSize, rd: Writable<Reg>, rn: Reg, }, ULoad8 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, SLoad8 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, ULoad16 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, SLoad16 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, ULoad32 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, SLoad32 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, ULoad64 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, Store8 { rd: Reg, mem: AMode, flags: MemFlags, }, Store16 { rd: Reg, mem: AMode, flags: MemFlags, }, Store32 { rd: Reg, mem: AMode, flags: MemFlags, }, Store64 { rd: Reg, mem: AMode, flags: MemFlags, }, StoreP64 { rt: Reg, rt2: Reg, mem: PairAMode, flags: MemFlags, }, LoadP64 { rt: Writable<Reg>, rt2: Writable<Reg>, mem: PairAMode, flags: MemFlags, }, Mov { size: OperandSize, rd: Writable<Reg>, rm: Reg, }, MovFromPReg { rd: Writable<Reg>, rm: PReg, }, MovToPReg { rd: PReg, rm: Reg, }, MovWide { op: MoveWideOp, rd: Writable<Reg>, imm: MoveWideConst, size: OperandSize, }, MovK { rd: Writable<Reg>, rn: Reg, imm: MoveWideConst, size: OperandSize, }, Extend { rd: Writable<Reg>, rn: Reg, signed: bool, from_bits: u8, to_bits: u8, }, CSel { rd: Writable<Reg>, cond: Cond, rn: Reg, rm: Reg, }, CSNeg { rd: Writable<Reg>, cond: Cond, rn: Reg, rm: Reg, }, CSet { rd: Writable<Reg>, cond: Cond, }, CSetm { rd: Writable<Reg>, cond: Cond, }, CCmp { size: OperandSize, rn: Reg, rm: Reg, nzcv: NZCV, cond: Cond, }, CCmpImm { size: OperandSize, rn: Reg, imm: UImm5, nzcv: NZCV, cond: Cond, }, AtomicRMWLoop { ty: Type, op: AtomicRMWLoopOp, flags: MemFlags, addr: Reg, operand: Reg, oldval: Writable<Reg>, scratch1: Writable<Reg>, scratch2: Writable<Reg>, }, AtomicCASLoop { ty: Type, flags: MemFlags, addr: Reg, expected: Reg, replacement: Reg, oldval: Writable<Reg>, scratch: Writable<Reg>, }, AtomicRMW { op: AtomicRMWOp, rs: Reg, rt: Writable<Reg>, rn: Reg, ty: Type, flags: MemFlags, }, AtomicCAS { rd: Writable<Reg>, rs: Reg, rt: Reg, rn: Reg, ty: Type, flags: MemFlags, }, LoadAcquire { access_ty: Type, rt: Writable<Reg>, rn: Reg, flags: MemFlags, }, StoreRelease { access_ty: Type, rt: Reg, rn: Reg, flags: MemFlags, }, Fence, Csdb, FpuMove32 { rd: Writable<Reg>, rn: Reg, }, FpuMove64 { rd: Writable<Reg>, rn: Reg, }, FpuMove128 { rd: Writable<Reg>, rn: Reg, }, FpuMoveFromVec { rd: Writable<Reg>, rn: Reg, idx: u8, size: VectorSize, }, FpuExtend { rd: Writable<Reg>, rn: Reg, size: ScalarSize, }, FpuRR { fpu_op: FPUOp1, size: ScalarSize, rd: Writable<Reg>, rn: Reg, }, FpuRRR { fpu_op: FPUOp2, size: ScalarSize, rd: Writable<Reg>, rn: Reg, rm: Reg, }, FpuRRI { fpu_op: FPUOpRI, rd: Writable<Reg>, rn: Reg, }, FpuRRIMod { fpu_op: FPUOpRIMod, rd: Writable<Reg>, ri: Reg, rn: Reg, }, FpuRRRR { fpu_op: FPUOp3, size: ScalarSize, rd: Writable<Reg>, rn: Reg, rm: Reg, ra: Reg, }, FpuCmp { size: ScalarSize, rn: Reg, rm: Reg, }, FpuLoad16 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, FpuStore16 { rd: Reg, mem: AMode, flags: MemFlags, }, FpuLoad32 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, FpuStore32 { rd: Reg, mem: AMode, flags: MemFlags, }, FpuLoad64 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, FpuStore64 { rd: Reg, mem: AMode, flags: MemFlags, }, FpuLoad128 { rd: Writable<Reg>, mem: AMode, flags: MemFlags, }, FpuStore128 { rd: Reg, mem: AMode, flags: MemFlags, }, FpuLoadP64 { rt: Writable<Reg>, rt2: Writable<Reg>, mem: PairAMode, flags: MemFlags, }, FpuStoreP64 { rt: Reg, rt2: Reg, mem: PairAMode, flags: MemFlags, }, FpuLoadP128 { rt: Writable<Reg>, rt2: Writable<Reg>, mem: PairAMode, flags: MemFlags, }, FpuStoreP128 { rt: Reg, rt2: Reg, mem: PairAMode, flags: MemFlags, }, FpuToInt { op: FpuToIntOp, rd: Writable<Reg>, rn: Reg, }, IntToFpu { op: IntToFpuOp, rd: Writable<Reg>, rn: Reg, }, FpuCSel16 { rd: Writable<Reg>, rn: Reg, rm: Reg, cond: Cond, }, FpuCSel32 { rd: Writable<Reg>, rn: Reg, rm: Reg, cond: Cond, }, FpuCSel64 { rd: Writable<Reg>, rn: Reg, rm: Reg, cond: Cond, }, FpuRound { op: FpuRoundMode, rd: Writable<Reg>, rn: Reg, }, MovToFpu { rd: Writable<Reg>, rn: Reg, size: ScalarSize, }, FpuMoveFPImm { rd: Writable<Reg>, imm: ASIMDFPModImm, size: ScalarSize, }, MovToVec { rd: Writable<Reg>, ri: Reg, rn: Reg, idx: u8, size: VectorSize, }, MovFromVec { rd: Writable<Reg>, rn: Reg, idx: u8, size: ScalarSize, }, MovFromVecSigned { rd: Writable<Reg>, rn: Reg, idx: u8, size: VectorSize, scalar_size: OperandSize, }, VecDup { rd: Writable<Reg>, rn: Reg, size: VectorSize, }, VecDupFromFpu { rd: Writable<Reg>, rn: Reg, size: VectorSize, lane: u8, }, VecDupFPImm { rd: Writable<Reg>, imm: ASIMDFPModImm, size: VectorSize, }, VecDupImm { rd: Writable<Reg>, imm: ASIMDMovModImm, invert: bool, size: VectorSize, }, VecExtend { t: VecExtendOp, rd: Writable<Reg>, rn: Reg, high_half: bool, lane_size: ScalarSize, }, VecMovElement { rd: Writable<Reg>, ri: Reg, rn: Reg, dest_idx: u8, src_idx: u8, size: VectorSize, }, VecRRLong { op: VecRRLongOp, rd: Writable<Reg>, rn: Reg, high_half: bool, }, VecRRNarrowLow { op: VecRRNarrowOp, rd: Writable<Reg>, rn: Reg, lane_size: ScalarSize, }, VecRRNarrowHigh { op: VecRRNarrowOp, rd: Writable<Reg>, ri: Reg, rn: Reg, lane_size: ScalarSize, }, VecRRPair { op: VecPairOp, rd: Writable<Reg>, rn: Reg, }, VecRRRLong { alu_op: VecRRRLongOp, rd: Writable<Reg>, rn: Reg, rm: Reg, high_half: bool, }, VecRRRLongMod { alu_op: VecRRRLongModOp, rd: Writable<Reg>, ri: Reg, rn: Reg, rm: Reg, high_half: bool, }, VecRRPairLong { op: VecRRPairLongOp, rd: Writable<Reg>, rn: Reg, }, VecRRR { alu_op: VecALUOp, rd: Writable<Reg>, rn: Reg, rm: Reg, size: VectorSize, }, VecRRRMod { alu_op: VecALUModOp, rd: Writable<Reg>, ri: Reg, rn: Reg, rm: Reg, size: VectorSize, }, VecFmlaElem { alu_op: VecALUModOp, rd: Writable<Reg>, ri: Reg, rn: Reg, rm: Reg, size: VectorSize, idx: u8, }, VecMisc { op: VecMisc2, rd: Writable<Reg>, rn: Reg, size: VectorSize, }, VecLanes { op: VecLanesOp, rd: Writable<Reg>, rn: Reg, size: VectorSize, }, VecShiftImm { op: VecShiftImmOp, rd: Writable<Reg>, rn: Reg, size: VectorSize, imm: u8, }, VecShiftImmMod { op: VecShiftImmModOp, rd: Writable<Reg>, ri: Reg, rn: Reg, size: VectorSize, imm: u8, }, VecExtract { rd: Writable<Reg>, rn: Reg, rm: Reg, imm4: u8, }, VecTbl { rd: Writable<Reg>, rn: Reg, rm: Reg, }, VecTblExt { rd: Writable<Reg>, ri: Reg, rn: Reg, rm: Reg, }, VecTbl2 { rd: Writable<Reg>, rn: Reg, rn2: Reg, rm: Reg, }, VecTbl2Ext { rd: Writable<Reg>, ri: Reg, rn: Reg, rn2: Reg, rm: Reg, }, VecLoadReplicate { rd: Writable<Reg>, rn: Reg, size: VectorSize, flags: MemFlags, }, VecCSel { rd: Writable<Reg>, rn: Reg, rm: Reg, cond: Cond, }, MovToNZCV { rn: Reg, }, MovFromNZCV { rd: Writable<Reg>, }, Call { info: Box<CallInfo<ExternalName>>, }, CallInd { info: Box<CallInfo<Reg>>, }, ReturnCall { info: Box<ReturnCallInfo<ExternalName>>, }, ReturnCallInd { info: Box<ReturnCallInfo<Reg>>, }, Args { args: Vec<ArgPair>, }, Rets { rets: Vec<RetPair>, }, Ret, AuthenticatedRet { key: APIKey, is_hint: bool, }, Jump { dest: BranchTarget, }, CondBr { taken: BranchTarget, not_taken: BranchTarget, kind: CondBrKind, }, TestBitAndBranch { kind: TestBitAndBranchKind, taken: BranchTarget, not_taken: BranchTarget, rn: Reg, bit: u8, }, TrapIf { kind: CondBrKind, trap_code: TrapCode, }, IndirectBr { rn: Reg, targets: Vec<MachLabel>, }, Brk, Udf { trap_code: TrapCode, }, Adr { rd: Writable<Reg>, off: i32, }, Adrp { rd: Writable<Reg>, off: i32, }, Word4 { data: u32, }, Word8 { data: u64, }, JTSequence { default: MachLabel, targets: Box<Vec<MachLabel>>, ridx: Reg, rtmp1: Writable<Reg>, rtmp2: Writable<Reg>, }, LoadExtName { rd: Writable<Reg>, name: Box<ExternalName>, offset: i64, }, LoadAddr { rd: Writable<Reg>, mem: AMode, }, Paci { key: APIKey, }, Xpaclri, Bti { targets: BranchTargetType, }, EmitIsland { needed_space: u32, }, ElfTlsGetAddr { symbol: Box<ExternalName>, rd: Writable<Reg>, tmp: Writable<Reg>, }, MachOTlsGetAddr { symbol: ExternalName, rd: Writable<Reg>, }, Unwind { inst: UnwindInst, }, DummyUse { reg: Reg, }, StackProbeLoop { start: Writable<Reg>, end: Reg, step: Imm12, },
}
Expand description

Internal type MInst: defined at src/isa/aarch64/inst.isle line 1.

Variants§

§

Nop0

§

Nop4

§

AluRRR

Fields

§alu_op: ALUOp
§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§

AluRRRR

Fields

§alu_op: ALUOp3
§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§ra: Reg
§

AluRRImm12

Fields

§alu_op: ALUOp
§rd: Writable<Reg>
§rn: Reg
§imm12: Imm12
§

AluRRImmLogic

Fields

§alu_op: ALUOp
§rd: Writable<Reg>
§rn: Reg
§

AluRRImmShift

Fields

§alu_op: ALUOp
§rd: Writable<Reg>
§rn: Reg
§immshift: ImmShift
§

AluRRRShift

Fields

§alu_op: ALUOp
§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§

AluRRRExtend

Fields

§alu_op: ALUOp
§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§extendop: ExtendOp
§

BitRR

Fields

§rd: Writable<Reg>
§rn: Reg
§

ULoad8

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

SLoad8

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

ULoad16

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

SLoad16

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

ULoad32

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

SLoad32

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

ULoad64

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

Store8

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

Store16

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

Store32

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

Store64

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

StoreP64

Fields

§rt: Reg
§rt2: Reg
§flags: MemFlags
§

LoadP64

Fields

§rt: Writable<Reg>
§rt2: Writable<Reg>
§flags: MemFlags
§

Mov

Fields

§rd: Writable<Reg>
§rm: Reg
§

MovFromPReg

Fields

§rd: Writable<Reg>
§rm: PReg
§

MovToPReg

Fields

§rd: PReg
§rm: Reg
§

MovWide

Fields

§rd: Writable<Reg>
§

MovK

Fields

§rd: Writable<Reg>
§rn: Reg
§

Extend

Fields

§rd: Writable<Reg>
§rn: Reg
§signed: bool
§from_bits: u8
§to_bits: u8
§

CSel

Fields

§rd: Writable<Reg>
§cond: Cond
§rn: Reg
§rm: Reg
§

CSNeg

Fields

§rd: Writable<Reg>
§cond: Cond
§rn: Reg
§rm: Reg
§

CSet

Fields

§rd: Writable<Reg>
§cond: Cond
§

CSetm

Fields

§rd: Writable<Reg>
§cond: Cond
§

CCmp

Fields

§rn: Reg
§rm: Reg
§nzcv: NZCV
§cond: Cond
§

CCmpImm

Fields

§rn: Reg
§imm: UImm5
§nzcv: NZCV
§cond: Cond
§

AtomicRMWLoop

Fields

§ty: Type
§flags: MemFlags
§addr: Reg
§operand: Reg
§oldval: Writable<Reg>
§scratch1: Writable<Reg>
§scratch2: Writable<Reg>
§

AtomicCASLoop

Fields

§ty: Type
§flags: MemFlags
§addr: Reg
§expected: Reg
§replacement: Reg
§oldval: Writable<Reg>
§scratch: Writable<Reg>
§

AtomicRMW

Fields

§rs: Reg
§rt: Writable<Reg>
§rn: Reg
§ty: Type
§flags: MemFlags
§

AtomicCAS

Fields

§rd: Writable<Reg>
§rs: Reg
§rt: Reg
§rn: Reg
§ty: Type
§flags: MemFlags
§

LoadAcquire

Fields

§access_ty: Type
§rt: Writable<Reg>
§rn: Reg
§flags: MemFlags
§

StoreRelease

Fields

§access_ty: Type
§rt: Reg
§rn: Reg
§flags: MemFlags
§

Fence

§

Csdb

§

FpuMove32

Fields

§rd: Writable<Reg>
§rn: Reg
§

FpuMove64

Fields

§rd: Writable<Reg>
§rn: Reg
§

FpuMove128

Fields

§rd: Writable<Reg>
§rn: Reg
§

FpuMoveFromVec

Fields

§rd: Writable<Reg>
§rn: Reg
§idx: u8
§

FpuExtend

Fields

§rd: Writable<Reg>
§rn: Reg
§

FpuRR

Fields

§fpu_op: FPUOp1
§rd: Writable<Reg>
§rn: Reg
§

FpuRRR

Fields

§fpu_op: FPUOp2
§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§

FpuRRI

Fields

§fpu_op: FPUOpRI
§rd: Writable<Reg>
§rn: Reg
§

FpuRRIMod

Fields

§fpu_op: FPUOpRIMod
§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§

FpuRRRR

Fields

§fpu_op: FPUOp3
§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§ra: Reg
§

FpuCmp

Fields

§rn: Reg
§rm: Reg
§

FpuLoad16

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

FpuStore16

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

FpuLoad32

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

FpuStore32

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

FpuLoad64

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

FpuStore64

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

FpuLoad128

Fields

§rd: Writable<Reg>
§mem: AMode
§flags: MemFlags
§

FpuStore128

Fields

§rd: Reg
§mem: AMode
§flags: MemFlags
§

FpuLoadP64

Fields

§rt: Writable<Reg>
§rt2: Writable<Reg>
§flags: MemFlags
§

FpuStoreP64

Fields

§rt: Reg
§rt2: Reg
§flags: MemFlags
§

FpuLoadP128

Fields

§rt: Writable<Reg>
§rt2: Writable<Reg>
§flags: MemFlags
§

FpuStoreP128

Fields

§rt: Reg
§rt2: Reg
§flags: MemFlags
§

FpuToInt

Fields

§rd: Writable<Reg>
§rn: Reg
§

IntToFpu

Fields

§rd: Writable<Reg>
§rn: Reg
§

FpuCSel16

Fields

§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§cond: Cond
§

FpuCSel32

Fields

§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§cond: Cond
§

FpuCSel64

Fields

§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§cond: Cond
§

FpuRound

Fields

§rd: Writable<Reg>
§rn: Reg
§

MovToFpu

Fields

§rd: Writable<Reg>
§rn: Reg
§

FpuMoveFPImm

Fields

§rd: Writable<Reg>
§

MovToVec

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§idx: u8
§

MovFromVec

Fields

§rd: Writable<Reg>
§rn: Reg
§idx: u8
§

MovFromVecSigned

Fields

§rd: Writable<Reg>
§rn: Reg
§idx: u8
§scalar_size: OperandSize
§

VecDup

Fields

§rd: Writable<Reg>
§rn: Reg
§

VecDupFromFpu

Fields

§rd: Writable<Reg>
§rn: Reg
§lane: u8
§

VecDupFPImm

Fields

§rd: Writable<Reg>
§

VecDupImm

Fields

§rd: Writable<Reg>
§invert: bool
§

VecExtend

Fields

§rd: Writable<Reg>
§rn: Reg
§high_half: bool
§lane_size: ScalarSize
§

VecMovElement

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§dest_idx: u8
§src_idx: u8
§

VecRRLong

Fields

§rd: Writable<Reg>
§rn: Reg
§high_half: bool
§

VecRRNarrowLow

Fields

§rd: Writable<Reg>
§rn: Reg
§lane_size: ScalarSize
§

VecRRNarrowHigh

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§lane_size: ScalarSize
§

VecRRPair

Fields

§rd: Writable<Reg>
§rn: Reg
§

VecRRRLong

Fields

§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§high_half: bool
§

VecRRRLongMod

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§rm: Reg
§high_half: bool
§

VecRRPairLong

Fields

§rd: Writable<Reg>
§rn: Reg
§

VecRRR

Fields

§alu_op: VecALUOp
§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§

VecRRRMod

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§rm: Reg
§

VecFmlaElem

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§rm: Reg
§idx: u8
§

VecMisc

Fields

§rd: Writable<Reg>
§rn: Reg
§

VecLanes

Fields

§rd: Writable<Reg>
§rn: Reg
§

VecShiftImm

Fields

§rd: Writable<Reg>
§rn: Reg
§imm: u8
§

VecShiftImmMod

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§imm: u8
§

VecExtract

Fields

§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§imm4: u8
§

VecTbl

Fields

§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§

VecTblExt

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§rm: Reg
§

VecTbl2

Fields

§rd: Writable<Reg>
§rn: Reg
§rn2: Reg
§rm: Reg
§

VecTbl2Ext

Fields

§rd: Writable<Reg>
§ri: Reg
§rn: Reg
§rn2: Reg
§rm: Reg
§

VecLoadReplicate

Fields

§rd: Writable<Reg>
§rn: Reg
§flags: MemFlags
§

VecCSel

Fields

§rd: Writable<Reg>
§rn: Reg
§rm: Reg
§cond: Cond
§

MovToNZCV

Fields

§rn: Reg
§

MovFromNZCV

Fields

§rd: Writable<Reg>
§

Call

Fields

§info: Box<CallInfo<ExternalName>>
§

CallInd

Fields

§info: Box<CallInfo<Reg>>
§

ReturnCall

§

ReturnCallInd

Fields

§info: Box<ReturnCallInfo<Reg>>
§

Args

Fields

§args: Vec<ArgPair>
§

Rets

Fields

§rets: Vec<RetPair>
§

Ret

§

AuthenticatedRet

Fields

§is_hint: bool
§

Jump

Fields

§

CondBr

Fields

§not_taken: BranchTarget
§

TestBitAndBranch

Fields

§not_taken: BranchTarget
§rn: Reg
§bit: u8
§

TrapIf

Fields

§trap_code: TrapCode
§

IndirectBr

Fields

§rn: Reg
§targets: Vec<MachLabel>
§

Brk

§

Udf

Fields

§trap_code: TrapCode
§

Adr

Fields

§rd: Writable<Reg>
§off: i32
§

Adrp

Fields

§rd: Writable<Reg>
§off: i32
§

Word4

Fields

§data: u32
§

Word8

Fields

§data: u64
§

JTSequence

Fields

§default: MachLabel
§targets: Box<Vec<MachLabel>>
§ridx: Reg
§rtmp1: Writable<Reg>
§rtmp2: Writable<Reg>
§

LoadExtName

Fields

§rd: Writable<Reg>
§offset: i64
§

LoadAddr

Fields

§rd: Writable<Reg>
§mem: AMode
§

Paci

Fields

§

Xpaclri

§

Bti

Fields

§

EmitIsland

Fields

§needed_space: u32
§

ElfTlsGetAddr

Fields

§rd: Writable<Reg>
§tmp: Writable<Reg>
§

MachOTlsGetAddr

Fields

§rd: Writable<Reg>
§

Unwind

Fields

§

DummyUse

Fields

§reg: Reg
§

StackProbeLoop

Fields

§start: Writable<Reg>
§end: Reg
§step: Imm12

Implementations§

§

impl MInst

pub fn load_constant<F>( rd: Writable<Reg>, value: u64, alloc_tmp: &mut F, ) -> SmallVec<[MInst; 4]>
where F: FnMut(Type) -> Writable<Reg>,

Create an instruction that loads a constant, using one of several options (MOVZ, MOVN, logical immediate, or constant pool).

pub fn gen_load( into_reg: Writable<Reg>, mem: AMode, ty: Type, flags: MemFlags, ) -> MInst

Generic constructor for a load (zero-extending where appropriate).

pub fn gen_store(mem: AMode, from_reg: Reg, ty: Type, flags: MemFlags) -> MInst

Generic constructor for a store.

pub fn mem_type(&self) -> Option<Type>

What type does this load or store instruction access in memory? When uimm12 encoding is used, the size of this type is the amount that immediate offsets are scaled by.

Trait Implementations§

§

impl Clone for MInst

§

fn clone(&self) -> MInst

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl Debug for MInst

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

impl MachInst for MInst

§

const TRAP_OPCODE: &'static [u8]

Byte representation of a trap opcode which is inserted by MachBuffer during its defer_trap method.
§

type ABIMachineSpec = AArch64MachineDeps

The ABI machine spec for this MachInst.
§

type LabelUse = LabelUse

A label-use kind: a type that describes the types of label references that can occur in an instruction.
§

fn get_operands(&mut self, collector: &mut impl OperandVisitor)

Return the registers referenced by this machine instruction along with the modes of reference (use, def, modify).
§

fn is_move(&self) -> Option<(Writable<Reg>, Reg)>

If this is a simple move, return the (source, destination) tuple of registers.
§

fn is_included_in_clobbers(&self) -> bool

Should this instruction be included in the clobber-set?
§

fn is_trap(&self) -> bool

Is this an unconditional trap?
§

fn is_args(&self) -> bool

Is this an “args” pseudoinst?
§

fn is_term(&self) -> MachTerminator

Is this a terminator (branch or ret)? If so, return its type (ret/uncond/cond) and target if applicable.
§

fn is_mem_access(&self) -> bool

Does this instruction access memory?
§

fn gen_move(to_reg: Writable<Reg>, from_reg: Reg, ty: Type) -> MInst

Generate a move.
§

fn is_safepoint(&self) -> bool

Is this a safepoint?
§

fn gen_dummy_use(reg: Reg) -> MInst

Generate a dummy instruction that will keep a value alive but has no other purpose.
§

fn gen_nop(preferred_size: usize) -> MInst

Generate a NOP. The preferred_size parameter allows the caller to request a NOP of that size, or as close to it as possible. The machine backend may return a NOP whose binary encoding is smaller than the preferred size, but must not return a NOP that is larger. However, the instruction must have a nonzero size if preferred_size is nonzero.
§

fn rc_for_type( ty: Type, ) -> Result<(&'static [RegClass], &'static [Type]), CodegenError>

Determine register class(es) to store the given Cranelift type, and the Cranelift type actually stored in the underlying register(s). May return an error if the type isn’t supported by this backend. Read more
§

fn canonical_type_for_rc(rc: RegClass) -> Type

Get an appropriate type that can fully hold a value in a given register class. This may not be the only type that maps to that class, but when used with gen_move() or the ABI trait’s load/spill constructors, it should produce instruction(s) that move the entire register contents.
§

fn gen_jump(target: MachLabel) -> MInst

Generate a jump to another target. Used during lowering of control flow.
§

fn worst_case_size() -> u32

What is the worst-case instruction size emitted by this instruction type?
§

fn ref_type_regclass(_: &Flags) -> RegClass

What is the register class used for reference types (GC-observable pointers)? Can be dependent on compilation flags.
§

fn gen_block_start( is_indirect_branch_target: bool, is_forward_edge_cfi_enabled: bool, ) -> Option<MInst>

Generate an instruction that must appear at the beginning of a basic block, if any. Note that the return value must not be subject to register allocation.
§

fn function_alignment() -> FunctionAlignment

Returns a description of the alignment required for functions for this architecture.
§

fn gen_imm_u64(_value: u64, _dst: Writable<Reg>) -> Option<Self>

Generate a store of an immediate 64-bit integer to a register. Used by the control plane to generate random instructions.
§

fn gen_imm_f64( _value: f64, _tmp: Writable<Reg>, _dst: Writable<Reg>, ) -> SmallVec<[Self; 2]>

Generate a store of an immediate 64-bit integer to a register. Used by the control plane to generate random instructions. The tmp register may be used by architectures which don’t support writing immediate values to floating point registers directly.
§

fn align_basic_block(offset: u32) -> u32

Align a basic block offset (from start of function). By default, no alignment occurs.
§

fn is_low_level_branch(&self) -> bool

Is this a low-level, one-way branch, not meant for use in a VCode body? These instructions are meant to be used only when directly emitted, i.e. when MachInst is used as an assembler library.
§

impl MachInstEmit for MInst

§

type State = EmitState

Persistent state carried across emit invocations.
§

type Info = EmitInfo

Constant information used in emit invocations.
§

fn emit( &self, sink: &mut MachBuffer<MInst>, emit_info: &<MInst as MachInstEmit>::Info, state: &mut EmitState, )

Emit the instruction.
§

fn pretty_print_inst( &self, state: &mut <MInst as MachInstEmit>::State, ) -> String

Pretty-print the instruction.
§

impl MachInstEmitState<MInst> for EmitState

§

fn new(abi: &Callee<AArch64MachineDeps>, ctrl_plane: ControlPlane) -> EmitState

Create a new emission state given the ABI object.
§

fn pre_safepoint(&mut self, user_stack_map: Option<UserStackMap>)

Update the emission state before emitting an instruction that is a safepoint.
§

fn ctrl_plane_mut(&mut self) -> &mut ControlPlane

The emission state holds ownership of a control plane, so it doesn’t have to be passed around explicitly too much. ctrl_plane_mut may be used if temporary access to the control plane is needed by some other function that doesn’t have access to the emission state.
§

fn take_ctrl_plane(self) -> ControlPlane

Used to continue using a control plane after the emission state is not needed anymore.
§

fn frame_layout(&self) -> &FrameLayout

The [FrameLayout] for the function currently being compiled.
§

fn on_new_block(&mut self)

A hook that triggers when first emitting a new block. It is guaranteed to be called before any instructions are emitted.

Auto Trait Implementations§

§

impl Freeze for MInst

§

impl RefUnwindSafe for MInst

§

impl Send for MInst

§

impl Sync for MInst

§

impl Unpin for MInst

§

impl UnwindSafe for MInst

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.