akirilov-arm opened PR #1992 from InstSize
to main
:
As discussed in #1748, the main issue with the
InstSize
enum was that it was used both for GPR and SIMD & FP operands, even though machine instructions do not mix them in general (as in a destination register is either a GPR or not). As a result it had methods such assf_bit()
that made sense only for one type of operand.Another issue was that the enum name was not reflecting its purpose accurately - it was meant to represent an instruction operand size, not an instruction size, which is fixed in A64 (always 4 bytes).
Now the enum is split into one for GPR operands and another for scalar SIMD & FP operands.
akirilov-arm updated PR #1992 from InstSize
to main
:
As discussed in #1748, the main issue with the
InstSize
enum was that it was used both for GPR and SIMD & FP operands, even though machine instructions do not mix them in general (as in a destination register is either a GPR or not). As a result it had methods such assf_bit()
that made sense only for one type of operand.Another issue was that the enum name was not reflecting its purpose accurately - it was meant to represent an instruction operand size, not an instruction size, which is fixed in A64 (always 4 bytes).
Now the enum is split into one for GPR operands and another for scalar SIMD & FP operands.
cfallin submitted PR Review.
cfallin submitted PR Review.
cfallin created PR Review Comment:
Perhaps use a
match
here, and panic ifbits
isn't exactly 8 / 16 / 32 / 64 / 128? I'm not sure what it would mean to have (e.g.) a 24-bit scalar...
cfallin created PR Review Comment:
Doc-comment here indicating that it returns encoding bits
akirilov-arm updated PR #1992 from InstSize
to main
:
As discussed in #1748, the main issue with the
InstSize
enum was that it was used both for GPR and SIMD & FP operands, even though machine instructions do not mix them in general (as in a destination register is either a GPR or not). As a result it had methods such assf_bit()
that made sense only for one type of operand.Another issue was that the enum name was not reflecting its purpose accurately - it was meant to represent an instruction operand size, not an instruction size, which is fixed in A64 (always 4 bytes).
Now the enum is split into one for GPR operands and another for scalar SIMD & FP operands.
akirilov-arm submitted PR Review.
akirilov-arm created PR Review Comment:
This just mirrors the original logic in
InstSize
. Anyway, I figured out a way to express it succinctly.
cfallin merged PR #1992.
Last updated: Jan 24 2025 at 00:11 UTC