Path: blob/main/cranelift/assembler-x64/meta/src/instructions/pack.rs
1693 views
use crate::dsl::{Feature::*, Inst, Length::*, Location::*};1use crate::dsl::{align, fmt, inst, r, rex, rw, vex, w};23#[rustfmt::skip] // Keeps instructions on a single line.4pub fn list() -> Vec<Inst> {5vec![6// Convert packed signed integers into smaller signed integers using7// saturation to handle overflow (e.g., `0x7F` or `0x80` when converting8// from word to byte).9inst("packsswb", fmt("A", [rw(xmm1), r(align(xmm_m128))]), rex([0x66, 0x0F, 0x63]), (_64b | compat) & sse2).alt(avx, "vpacksswb_b"),10inst("packssdw", fmt("A", [rw(xmm1), r(align(xmm_m128))]), rex([0x66, 0x0F, 0x6B]), (_64b | compat) & sse2).alt(avx, "vpackssdw_b"),11inst("vpacksswb", fmt("B", [w(xmm1), r(xmm2), r(xmm_m128)]), vex(L128)._66()._0f().op(0x63), (_64b | compat) & avx),12inst("vpackssdw", fmt("B", [w(xmm1), r(xmm2), r(xmm_m128)]), vex(L128)._66()._0f().op(0x6B), (_64b | compat) & avx),13// Convert packed signed integers into smaller unsigned integers using14// unsigned saturation to handle overflow (e.g., `0xFF` or `0x00` when15// converting from word to byte).16inst("packuswb", fmt("A", [rw(xmm1), r(align(xmm_m128))]), rex([0x66, 0x0F, 0x67]), (_64b | compat) & sse2).alt(avx, "vpackuswb_b"),17inst("packusdw", fmt("A", [rw(xmm1), r(align(xmm_m128))]), rex([0x66, 0x0F, 0x38, 0x2B]), (_64b | compat) & sse41).alt(avx, "vpackusdw_b"),18inst("vpackuswb", fmt("B", [w(xmm1), r(xmm2), r(xmm_m128)]), vex(L128)._66()._0f().op(0x67), (_64b | compat) & avx),19inst("vpackusdw", fmt("B", [w(xmm1), r(xmm2), r(xmm_m128)]), vex(L128)._66()._0f38().op(0x2B), (_64b | compat) & avx),20]21}222324