mirror of
https://github.com/riscv-software-src/riscv-isa-sim.git
synced 2025-10-14 02:07:30 +08:00
Merge pull request #2094 from chihminchao/enhance-amo-disasm
disasm: show the acquire and release attribute to amo instructions
This commit is contained in:
@@ -643,7 +643,17 @@ static void NOINLINE add_fstore_insn(disassembler_t* d, const char* name, uint32
|
||||
|
||||
static void NOINLINE add_xamo_insn(disassembler_t* d, const char* name, uint32_t match, uint32_t mask)
|
||||
{
|
||||
d->add_insn(new disasm_insn_t(name, match, mask, {&xrd, &xrs2, &base_only_address}));
|
||||
const char *suffix[] = {"", ".rl", ".aq", ".aqrl"};
|
||||
char new_name[128];
|
||||
uint32_t new_mask = mask | (0x3 << 25);
|
||||
uint32_t new_match;
|
||||
|
||||
for (uint32_t idx = 0; idx < sizeof(suffix) / sizeof(suffix[0]); ++idx) {
|
||||
snprintf(new_name, sizeof(new_name), "%s%s", name, suffix[idx]);
|
||||
new_match = match | (idx << 25);
|
||||
|
||||
d->add_insn(new disasm_insn_t(new_name, new_match, new_mask, {&xrd, &xrs2, &base_only_address}));
|
||||
}
|
||||
}
|
||||
|
||||
static void NOINLINE add_xlr_insn(disassembler_t* d, const char* name, uint32_t match, uint32_t mask)
|
||||
|
Reference in New Issue
Block a user