1 // See LICENSE for license details.
3 // This little program finds occurrences of strings like
5 // in its input, then replaces them with the disassembly
6 // enclosed hexadecimal number, interpreted as a RISC-V
10 #include "extension.h"
14 #include <fesvr/option_parser.h>
17 int main(int argc
, char** argv
)
22 std::function
<extension_t
*()> extension
;
23 option_parser_t parser
;
24 parser
.option(0, "extension", 1, [&](const char* s
){
25 if (!extensions().count(s
))
26 fprintf(stderr
, "unknown extension %s!\n", s
), exit(-1);
27 extension
= extensions()[s
];
29 for (auto disasm_insn
: extension()->get_disasms())
30 d
.add_insn(disasm_insn
);
33 while (getline(cin
, s
))
35 for (size_t start
= 0; (start
= s
.find("DASM(", start
)) != string::npos
; )
37 size_t end
= s
.find(')', start
);
38 if (end
== string::npos
)
41 size_t numstart
= start
+ strlen("DASM(");
42 uint32_t n
= strtoul(&s
[numstart
], NULL
, 16);
44 string dis
= d
.disassemble(*(insn_t
*)&n
);
46 s
= s
.substr(0, start
) + dis
+ s
.substr(end
+1);
47 start
+= dis
.length();