Commit b81d3838 authored by Junliang Yan's avatar Junliang Yan Committed by V8 LUCI CQ

ppc: Add STHBRX to assembler/disasm/simulator

Change-Id: Ie092921e4a9c1e4a0acee827f73570f3f9617712
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2971557Reviewed-by: 's avatarMilad Fa <mfarazma@redhat.com>
Commit-Queue: Junliang Yan <junyan@redhat.com>
Cr-Commit-Position: refs/heads/master@{#75261}
parent b90cf282
...@@ -1244,6 +1244,8 @@ using Instr = uint32_t; ...@@ -1244,6 +1244,8 @@ using Instr = uint32_t;
V(stdbrx, STDBRX, 0x7C000528) \ V(stdbrx, STDBRX, 0x7C000528) \
/* Store Word Byte-Reverse Indexed */ \ /* Store Word Byte-Reverse Indexed */ \
V(stwbrx, STWBRX, 0x7C00052C) \ V(stwbrx, STWBRX, 0x7C00052C) \
/* Store Halfword Byte-Reverse Indexed */ \
V(sthbrx, STHBRX, 0x7C00072C) \
/* Load Vector Indexed */ \ /* Load Vector Indexed */ \
V(lvx, LVX, 0x7C0000CE) \ V(lvx, LVX, 0x7C0000CE) \
/* Store Vector Indexed */ \ /* Store Vector Indexed */ \
...@@ -1314,8 +1316,6 @@ using Instr = uint32_t; ...@@ -1314,8 +1316,6 @@ using Instr = uint32_t;
V(nand, NAND, 0x7C0003B8) \ V(nand, NAND, 0x7C0003B8) \
/* Parity Word */ \ /* Parity Word */ \
V(prtyw, PRTYW, 0x7C000134) \ V(prtyw, PRTYW, 0x7C000134) \
/* Store Halfword Byte-Reverse Indexed */ \
V(sthbrx, STHBRX, 0x7C00072C) \
/* Synchronize */ \ /* Synchronize */ \
V(sync, SYNC, 0x7C0004AC) \ V(sync, SYNC, 0x7C0004AC) \
/* Trap Word */ \ /* Trap Word */ \
......
...@@ -1117,6 +1117,10 @@ void Decoder::DecodeExt2(Instruction* instr) { ...@@ -1117,6 +1117,10 @@ void Decoder::DecodeExt2(Instruction* instr) {
Format(instr, "stwbrx 'rs, 'ra, 'rb"); Format(instr, "stwbrx 'rs, 'ra, 'rb");
return; return;
} }
case STHBRX: {
Format(instr, "sthbrx 'rs, 'ra, 'rb");
return;
}
case MTCRF: { case MTCRF: {
Format(instr, "mtcrf 'FXM, 'rs"); Format(instr, "mtcrf 'FXM, 'rs");
return; return;
......
...@@ -2981,6 +2981,16 @@ void Simulator::ExecuteGeneric(Instruction* instr) { ...@@ -2981,6 +2981,16 @@ void Simulator::ExecuteGeneric(Instruction* instr) {
WriteW(ra_val + rb_val, __builtin_bswap32(rs_val)); WriteW(ra_val + rb_val, __builtin_bswap32(rs_val));
break; break;
} }
case STHBRX: {
int rs = instr->RSValue();
int ra = instr->RAValue();
int rb = instr->RBValue();
intptr_t ra_val = ra == 0 ? 0 : get_register(ra);
intptr_t rs_val = get_register(rs);
intptr_t rb_val = get_register(rb);
WriteH(ra_val + rb_val, __builtin_bswap16(rs_val));
break;
}
case STDX: case STDX:
case STDUX: { case STDUX: {
int rs = instr->RSValue(); int rs = instr->RSValue();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment