timjrd edited issue #6958:
Feature
Use
Uimm64
forUnaryImm::imm
instead ofImm64
, sinceUnaryImm::imm
is now always encoding an unsigned integer; following #6850 & #3059.Benefit
Make it clear that
UnaryImm::imm
must be interpreted as an unsigned integer; or that it should be reinterpreted as a signed integer if necessary, taking into account the actual bit-length of the encoded value. For example, since #6850, the immediate oficonst.i32 -2
is encoded inUnaryImm::imm
as0xffff_fffe
, and not-2
, despite being stored in a signed 64-bit integer.Implementation
Change the type, listen to the complaints of the compiler, and address tests breakage.
I would like to try to address this issue, if it's suitable for a compiler beginner with limited time resource.
Alternatives
Keep using
Imm64
since the verifier is already rejecting incorrect encodings.
timjrd commented on issue #6958:
:wave: might be of interest for @bjorn3 and @jameysharp
timjrd edited issue #6958:
Feature
Use
Uimm64
forUnaryImm::imm
instead ofImm64
, sinceUnaryImm::imm
is now always encoding an unsigned integer; following #6850 & #3059.Benefit
Make it clear that
UnaryImm::imm
must be interpreted as an unsigned integer; or that it should be reinterpreted as a signed integer, taking into account the actual bit-length of the encoded value. For example, since #6850, the immediate oficonst.i32 -2
is encoded inUnaryImm::imm
as0xffff_fffe
, and not-2
, despite being stored in a signed 64-bit integer.Implementation
Change the type, listen to the complaints of the compiler, and address tests breakage.
I would like to try to address this issue, if it's suitable for a compiler beginner with limited time resource.
Alternatives
Keep using
Imm64
since the verifier is already rejecting incorrect encodings.
timjrd edited issue #6958:
Feature
Use
Uimm64
forUnaryImm::imm
instead ofImm64
, sinceUnaryImm::imm
is now always encoding an unsigned integer; following #6850 & #3059.Benefit
Make it clear that
UnaryImm::imm
must be interpreted as an unsigned integer; or that it should be reinterpreted as a signed integer, taking into account the actual bit-length of the encoded value. For example, since #6850, the immediate oficonst.i32 -2
is encoded inUnaryImm::imm
as0xffff_fffe
, and not-2
, despite being stored in a signed 64-bit integer.Implementation
Change the type, listen to the complaints of the type checker, and address tests breakage.
I would like to try to address this issue, if it's suitable for a compiler beginner with limited time resource.
Alternatives
Keep using
Imm64
since the verifier is already rejecting incorrect encodings.
timjrd edited issue #6958:
Feature
Use
Uimm64
forUnaryImm::imm
instead ofImm64
, sinceUnaryImm::imm
is now always encoding an unsigned integer; following #6850 & #3059.Benefit
Make it clear that
UnaryImm::imm
must be interpreted as an unsigned integer; or that it should be reinterpreted as a signed integer with respect to the actual bit-length of the encoded value. For example, since #6850, the immediate oficonst.i32 -2
is encoded inUnaryImm::imm
as0xffff_fffe
, and not-2
, despite being stored in a signed 64-bit integer.Implementation
Change the type, listen to the complaints of the type checker, and address tests breakage.
I would like to try to address this issue, if it's suitable for a compiler beginner with limited time resource.
Alternatives
Keep using
Imm64
since the verifier is already rejecting incorrect encodings.
Last updated: Jan 24 2025 at 00:11 UTC