Commit 0eca1c7b authored by Milad Fa's avatar Milad Fa Committed by Commit Bot

PPC [simd]: Add vector load, store and splat to Sim

This CL also adds and makes use of the __int128 data type to help
with vector loads and stores.

Change-Id: I0d02eddcedfe17d12eadd214e205b693fa7ebe53
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2720459Reviewed-by: 's avatarJunliang Yan <junyan@redhat.com>
Commit-Queue: Milad Fa <mfarazma@redhat.com>
Cr-Commit-Position: refs/heads/master@{#73059}
parent 47ffa7a5
...@@ -2313,11 +2313,17 @@ void Simulator::ExecuteGeneric(Instruction* instr) { ...@@ -2313,11 +2313,17 @@ void Simulator::ExecuteGeneric(Instruction* instr) {
break; break;
} }
case MTVSRD: { case MTVSRD: {
DCHECK(!instr->Bit(0));
int frt = instr->RTValue(); int frt = instr->RTValue();
int ra = instr->RAValue(); int ra = instr->RAValue();
int64_t ra_val = get_register(ra); int64_t ra_val = get_register(ra);
set_d_register(frt, ra_val); if (!instr->Bit(0)) {
// if double reg (TX=0).
set_d_register(frt, ra_val);
} else {
// if simd reg (TX=1).
set_simd_register_by_lane<int64_t>(frt, 0,
static_cast<int64_t>(ra_val));
}
break; break;
} }
case MTVSRWA: { case MTVSRWA: {
...@@ -3712,7 +3718,62 @@ void Simulator::ExecuteGeneric(Instruction* instr) { ...@@ -3712,7 +3718,62 @@ void Simulator::ExecuteGeneric(Instruction* instr) {
set_d_register_from_double(frt, frt_val); set_d_register_from_double(frt, frt_val);
return; return;
} }
// Vector instructions.
#define FOR_EACH_LANE(i, type) \
for (uint32_t i = 0; i < kSimd128Size / sizeof(type); i++)
case STVX: {
int vrs = instr->RSValue();
int ra = instr->RAValue();
int rb = instr->RBValue();
intptr_t ra_val = ra == 0 ? 0 : get_register(ra);
intptr_t rb_val = get_register(rb);
__int128 vrs_val =
*(reinterpret_cast<__int128*>(get_simd_register(vrs).int8));
WriteQW((ra_val + rb_val) & 0xFFFFFFFFFFFFFFF0, vrs_val);
break;
}
case LXVD: {
int xt = instr->RTValue();
int ra = instr->RAValue();
int rb = instr->RBValue();
intptr_t ra_val = ra == 0 ? 0 : get_register(ra);
intptr_t rb_val = get_register(rb);
set_simd_register_by_lane<int64_t>(xt, 0, ReadDW(ra_val + rb_val));
set_simd_register_by_lane<int64_t>(
xt, 1, ReadDW(ra_val + rb_val + kSystemPointerSize));
break;
}
case STXVD: {
int xs = instr->RSValue();
int ra = instr->RAValue();
int rb = instr->RBValue();
intptr_t ra_val = ra == 0 ? 0 : get_register(ra);
intptr_t rb_val = get_register(rb);
WriteDW(ra_val + rb_val, get_simd_register_by_lane<int64_t>(xs, 0));
WriteDW(ra_val + rb_val + kSystemPointerSize,
get_simd_register_by_lane<int64_t>(xs, 1));
break;
}
#define VSPLT(type) \
uint32_t uim = instr->Bits(20, 16); \
int vrt = instr->RTValue(); \
int vrb = instr->RBValue(); \
type value = get_simd_register_by_lane<type>(vrb, uim); \
FOR_EACH_LANE(i, type) { set_simd_register_by_lane<type>(vrt, i, value); }
case VSPLTW: {
VSPLT(int32_t)
break;
}
case VSPLTH: {
VSPLT(int16_t)
break;
}
case VSPLTB: {
VSPLT(int8_t)
break;
}
#undef VSPLT
#undef FOR_EACH_LANE
default: { default: {
UNIMPLEMENTED(); UNIMPLEMENTED();
break; break;
......
...@@ -322,10 +322,12 @@ class Simulator : public SimulatorBase { ...@@ -322,10 +322,12 @@ class Simulator : public SimulatorBase {
} }
} }
#define RW_VAR_LIST(V) \ #define RW_VAR_LIST(V) \
V(DWU, uint64_t) \ V(QWU, unsigned __int128) \
V(DW, int64_t) \ V(QW, __int128) \
V(WU, uint32_t) \ V(DWU, uint64_t) \
V(DW, int64_t) \
V(WU, uint32_t) \
V(W, int32_t) V(HU, uint16_t) V(H, int16_t) V(BU, uint8_t) V(B, int8_t) V(W, int32_t) V(HU, uint16_t) V(H, int16_t) V(BU, uint8_t) V(B, int8_t)
#define GENERATE_RW_FUNC(size, type) \ #define GENERATE_RW_FUNC(size, type) \
......
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