aboutsummaryrefslogtreecommitdiff
path: root/riscv/riscv-dis.cc
blob: 62d522e32080e2dcf1b05c6c30f16ab9f9429383 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// See LICENSE for license details.

// This little program finds occurrences of strings like
//  DASM(ffabc013)
// in its input, then replaces them with the disassembly
// enclosed hexadecimal number, interpreted as a RISC-V
// instruction.

#include "disasm.h"
#include <iostream>
#include <string>
#include <cstdint>
using namespace std;

int main()
{
  string s;
  disassembler d;

  while (getline(cin, s))
  {
    for (size_t start = 0; (start = s.find("DASM(", start)) != string::npos; )
    {
      size_t end = s.find(')', start);
      if (end == string::npos)
        break;

      size_t numstart = start + strlen("DASM(");
      uint32_t n = strtoul(&s[numstart], NULL, 16);

      string dis = d.disassemble(*(insn_t*)&n);

      s = s.substr(0, start) + dis + s.substr(end+1);
      start += dis.length();
    }

    cout << s << '\n';
  }

  return 0;
}