Port Fcopysign..FcvtToSintSat to ISLE (AArch64) (#4753)
* Port `Fcopysign`..``FcvtToSintSat` to ISLE (AArch64)
Ported the existing implementations of the following opcodes to ISLE on
AArch64:
- `Fcopysign`
- Also introduced missing support for `fcopysign` on vector values, as
per the docs.
- This introduces the vector encoding for the `SLI` machine
instruction.
- `FcvtToUint`
- `FcvtToSint`
- `FcvtFromUint`
- `FcvtFromSint`
- `FcvtToUintSat`
- `FcvtToSintSat`
Copyright (c) 2022 Arm Limited
* Document helpers and abstract conversion checks
This commit is contained in:
@@ -2033,6 +2033,50 @@ impl MachInstEmit for Inst {
|
||||
let rd_enc = machreg_to_vec(rd.to_reg());
|
||||
sink.put4(template | (immh_immb << 16) | (rn_enc << 5) | rd_enc);
|
||||
}
|
||||
&Inst::VecShiftImmMod {
|
||||
op,
|
||||
rd,
|
||||
rn,
|
||||
size,
|
||||
imm,
|
||||
} => {
|
||||
let rd = allocs.next_writable(rd);
|
||||
let rn = allocs.next(rn);
|
||||
let (is_shr, mut template) = match op {
|
||||
VecShiftImmModOp::Sli => (false, 0b_001_011110_0000_000_010101_00000_00000_u32),
|
||||
};
|
||||
if size.is_128bits() {
|
||||
template |= 0b1 << 30;
|
||||
}
|
||||
let imm = imm as u32;
|
||||
// Deal with the somewhat strange encoding scheme for, and limits on,
|
||||
// the shift amount.
|
||||
let immh_immb = match (size.lane_size(), is_shr) {
|
||||
(ScalarSize::Size64, true) if imm >= 1 && imm <= 64 => {
|
||||
0b_1000_000_u32 | (64 - imm)
|
||||
}
|
||||
(ScalarSize::Size32, true) if imm >= 1 && imm <= 32 => {
|
||||
0b_0100_000_u32 | (32 - imm)
|
||||
}
|
||||
(ScalarSize::Size16, true) if imm >= 1 && imm <= 16 => {
|
||||
0b_0010_000_u32 | (16 - imm)
|
||||
}
|
||||
(ScalarSize::Size8, true) if imm >= 1 && imm <= 8 => {
|
||||
0b_0001_000_u32 | (8 - imm)
|
||||
}
|
||||
(ScalarSize::Size64, false) if imm <= 63 => 0b_1000_000_u32 | imm,
|
||||
(ScalarSize::Size32, false) if imm <= 31 => 0b_0100_000_u32 | imm,
|
||||
(ScalarSize::Size16, false) if imm <= 15 => 0b_0010_000_u32 | imm,
|
||||
(ScalarSize::Size8, false) if imm <= 7 => 0b_0001_000_u32 | imm,
|
||||
_ => panic!(
|
||||
"aarch64: Inst::VecShiftImmMod: emit: invalid op/size/imm {:?}, {:?}, {:?}",
|
||||
op, size, imm
|
||||
),
|
||||
};
|
||||
let rn_enc = machreg_to_vec(rn);
|
||||
let rd_enc = machreg_to_vec(rd.to_reg());
|
||||
sink.put4(template | (immh_immb << 16) | (rn_enc << 5) | rd_enc);
|
||||
}
|
||||
&Inst::VecExtract { rd, rn, rm, imm4 } => {
|
||||
let rd = allocs.next_writable(rd);
|
||||
let rn = allocs.next(rn);
|
||||
|
||||
Reference in New Issue
Block a user