Skip to content

Commit

Permalink
Fix: LDP STP negative offset was wrong due to auto instead of int64_t
Browse files Browse the repository at this point in the history
  • Loading branch information
xusine committed Dec 3, 2024
1 parent 3844f67 commit a64c475
Showing 1 changed file with 4 additions and 4 deletions.
8 changes: 4 additions & 4 deletions components/Decoder/encodings/LoadStore.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -455,8 +455,8 @@ LDP(archcode const& aFetchedOpcode, uint32_t aCPU, int64_t aSequenceNo, int32_t
*/
bool is_signed = (opc & 0x1) == 0x1;
uint32_t size = 8 << (scale + 1);
auto sizeOfEachPair = size / 2;
auto sizeOfEachPairInBytes = sizeOfEachPair / 8;
int64_t sizeOfEachPair = size / 2;
int64_t sizeOfEachPairInBytes = sizeOfEachPair / 8;
eSize sz = dbSize(size / 2);

if ((((opc & 1) == 1) && L == 0) || opc == 3 || (is_signed && index == kNoOffset)) {
Expand Down Expand Up @@ -564,8 +564,8 @@ STP(archcode const& aFetchedOpcode, uint32_t aCPU, int64_t aSequenceNo, int32_t
uint32_t scale = 2 + extract32(opc, 1, 1);
// bool is_signed = ( opc & 1 ) != 0;
int size = 8 << (scale + 1);
auto sizeOfEachPair = size / 2;
auto sizeOfEachPairInBytes = sizeOfEachPair / 8;
int64_t sizeOfEachPair = size / 2;
int64_t sizeOfEachPairInBytes = sizeOfEachPair / 8;
eSize sz = dbSize(size / 2);

if ((((opc & 1) == 1) && L == 0) || opc == 3) { return unallocated_encoding(aFetchedOpcode, aCPU, aSequenceNo); }
Expand Down

0 comments on commit a64c475

Please sign in to comment.