Browse Source

properly sign-extend instructions in spike-dasm

pull/18/head
Andrew Waterman 11 years ago
parent
commit
d8022e9eda
  1. 7
      spike_main/spike-dasm.cc

7
spike_main/spike-dasm.cc

@ -31,8 +31,13 @@ int main(int argc, char** argv)
if (end == string::npos)
break;
char* endp;
size_t numstart = start + strlen("DASM(");
insn_bits_t bits = strtoull(&s[numstart], NULL, 16);
int64_t bits = strtoull(&s[numstart], &endp, 16);
size_t nbits = 4 * (endp - &s[numstart]);
if (nbits < 64)
bits = bits << (64 - nbits) >> (64 - nbits);
string dis = d.disassemble(bits);
s = s.substr(0, start) + dis + s.substr(end+1);
start += dis.length();

Loading…
Cancel
Save