Path: blob/main/cranelift/assembler-x64/meta/src/instructions/recip.rs
1693 views
use crate::dsl::{Feature::*, Inst, Length::*, Location::*};1use crate::dsl::{align, fmt, inst, r, rex, vex, w};23#[rustfmt::skip] // Keeps instructions on a single line.4pub fn list() -> Vec<Inst> {5vec![6inst("rcpps", fmt("RM", [w(xmm1), r(align(xmm_m128))]), rex([0x0F, 0x53]).r(), (_64b | compat) & sse).alt(avx, "vrcpps_rm"),7inst("rcpss", fmt("RM", [w(xmm1), r(xmm_m32)]), rex([0xF3, 0x0F, 0x53]).r(), (_64b | compat) & sse),8inst("rsqrtps", fmt("RM", [w(xmm1), r(align(xmm_m128))]), rex([0x0F, 0x52]).r(), (_64b | compat) & sse).alt(avx, "vrsqrtps_rm"),9inst("rsqrtss", fmt("RM", [w(xmm1), r(xmm_m32)]), rex([0xF3, 0x0F, 0x52]).r(), (_64b | compat) & sse),1011inst("vrcpps", fmt("RM", [w(xmm1), r(xmm_m128)]), vex(L128)._0f().op(0x53).r(), (_64b | compat) & avx),12inst("vrcpss", fmt("RVM", [w(xmm1), r(xmm2), r(xmm_m32)]), vex(LIG)._f3()._0f().op(0x53).r(), (_64b | compat) & avx),13inst("vrsqrtps", fmt("RM", [w(xmm1), r(xmm_m128)]), vex(L128)._0f().op(0x52).r(), (_64b | compat) & avx),14inst("vrsqrtss", fmt("RVM", [w(xmm1), r(xmm2), r(xmm_m32)]), vex(LIG)._f3()._0f().op(0x52).r(), (_64b | compat) & avx),15]16}171819