summaryrefslogtreecommitdiff
path: root/chromium/v8/src/execution/s390
diff options
context:
space:
mode:
authorAllan Sandfeld Jensen <allan.jensen@qt.io>2020-10-12 14:27:29 +0200
committerAllan Sandfeld Jensen <allan.jensen@qt.io>2020-10-13 09:35:20 +0000
commitc30a6232df03e1efbd9f3b226777b07e087a1122 (patch)
treee992f45784689f373bcc38d1b79a239ebe17ee23 /chromium/v8/src/execution/s390
parent7b5b123ac58f58ffde0f4f6e488bcd09aa4decd3 (diff)
downloadqtwebengine-chromium-85-based.tar.gz
BASELINE: Update Chromium to 85.0.4183.14085-based
Change-Id: Iaa42f4680837c57725b1344f108c0196741f6057 Reviewed-by: Allan Sandfeld Jensen <allan.jensen@qt.io>
Diffstat (limited to 'chromium/v8/src/execution/s390')
-rw-r--r--chromium/v8/src/execution/s390/simulator-s390.cc92
1 files changed, 68 insertions, 24 deletions
diff --git a/chromium/v8/src/execution/s390/simulator-s390.cc b/chromium/v8/src/execution/s390/simulator-s390.cc
index f41288f6a96..85688f861ce 100644
--- a/chromium/v8/src/execution/s390/simulator-s390.cc
+++ b/chromium/v8/src/execution/s390/simulator-s390.cc
@@ -785,9 +785,10 @@ void Simulator::EvalTableInit() {
V(vlc, VLC, 0xE7DE) /* type = VRR_A VECTOR LOAD COMPLEMENT */ \
V(vsel, VSEL, 0xE78D) /* type = VRR_E VECTOR SELECT */ \
V(vperm, VPERM, 0xE78C) /* type = VRR_E VECTOR PERMUTE */ \
- V(vtm, VTM, 0xE7D8) /* type = VRR_A VECTOR TEST UNDER MASK */ \
- V(vesl, VESL, 0xE730) /* type = VRS_A VECTOR ELEMENT SHIFT LEFT */ \
- V(veslv, VESLV, 0xE770) /* type = VRR_C VECTOR ELEMENT SHIFT LEFT */ \
+ V(vbperm, VBPERM, 0xE785) /* type = VRR_C VECTOR BIT PERMUTE */ \
+ V(vtm, VTM, 0xE7D8) /* type = VRR_A VECTOR TEST UNDER MASK */ \
+ V(vesl, VESL, 0xE730) /* type = VRS_A VECTOR ELEMENT SHIFT LEFT */ \
+ V(veslv, VESLV, 0xE770) /* type = VRR_C VECTOR ELEMENT SHIFT LEFT */ \
V(vesrl, VESRL, \
0xE738) /* type = VRS_A VECTOR ELEMENT SHIFT RIGHT LOGICAL */ \
V(vesrlv, VESRLV, \
@@ -3702,6 +3703,34 @@ EVALUATE(VPERM) {
return length;
}
+EVALUATE(VBPERM) {
+ DCHECK_OPCODE(VBPERM);
+ DECODE_VRR_C_INSTRUCTION(r1, r2, r3, m6, m5, m4);
+ USE(m4);
+ USE(m5);
+ USE(m6);
+ uint16_t result_bits = 0;
+ for (int i = 0; i < kSimd128Size; i++) {
+ result_bits <<= 1;
+ uint8_t selected_bit_index = get_simd_register_by_lane<uint8_t>(r3, i);
+ unsigned __int128 src_bits =
+ *(reinterpret_cast<__int128*>(get_simd_register(r2).int8));
+ if (selected_bit_index < (kSimd128Size * kBitsPerByte)) {
+ unsigned __int128 bit_value =
+ (src_bits << selected_bit_index) >> (kSimd128Size * kBitsPerByte - 1);
+ result_bits |= bit_value;
+ }
+ }
+ set_simd_register_by_lane<uint64_t>(r1, 0, 0);
+ set_simd_register_by_lane<uint64_t>(r1, 1, 0);
+ // Write back in bytes to avoid endianness problems.
+ set_simd_register_by_lane<uint8_t>(r1, 6,
+ static_cast<uint8_t>(result_bits >> 8));
+ set_simd_register_by_lane<uint8_t>(
+ r1, 7, static_cast<uint8_t>((result_bits << 8) >> 8));
+ return length;
+}
+
EVALUATE(VSEL) {
DCHECK_OPCODE(VSEL);
DECODE_VRR_E_INSTRUCTION(r1, r2, r3, r4, m6, m5);
@@ -3977,33 +4006,35 @@ EVALUATE(VFNMS) {
#undef VECTOR_FP_MULTIPLY_QFMS_OPERATION
template <class T, class Operation>
-void VectorFPMaxMin(void* dst, void* src1, void* src2, Operation op) {
+void VectorFPMaxMin(void* dst, void* src1, void* src2, int mode, Operation op) {
T* dst_ptr = reinterpret_cast<T*>(dst);
T* src1_ptr = reinterpret_cast<T*>(src1);
T* src2_ptr = reinterpret_cast<T*>(src2);
for (size_t i = 0; i < kSimd128Size / sizeof(T); i++) {
T src1_val = *(src1_ptr + i);
T src2_val = *(src2_ptr + i);
- T value = op(src1_val, src2_val);
- // using Java's Max Min functions
- if (isnan(src1_val) || isnan(src2_val)) {
- value = NAN;
- }
+ T value = op(src1_val, src2_val, mode);
memcpy(dst_ptr + i, &value, sizeof(T));
}
}
-#define VECTOR_FP_MAX_MIN_FOR_TYPE(type, op) \
+#define VECTOR_FP_MAX_MIN_FOR_TYPE(type, op, std_op) \
VectorFPMaxMin<type>(&get_simd_register(r1), &get_simd_register(r2), \
- &get_simd_register(r3), [](type a, type b) { \
- if (signbit(b) op signbit(a)) \
+ &get_simd_register(r3), m6, \
+ [](type a, type b, int mode) { \
+ if (mode == 3) { \
+ return std::std_op(a, b); \
+ } \
+ if (isnan(a) || isnan(b)) \
+ return static_cast<type>(NAN); \
+ else if (signbit(b) op signbit(a)) \
return a; \
else if (signbit(b) != signbit(a)) \
return b; \
return (a op b) ? a : b; \
});
-#define VECTOR_FP_MAX_MIN(op) \
+#define VECTOR_FP_MAX_MIN(op, std_op) \
switch (m4) { \
case 2: \
if (m5 == 8) { \
@@ -4012,8 +4043,7 @@ void VectorFPMaxMin(void* dst, void* src1, void* src2, Operation op) {
set_simd_register_by_lane<float>(r1, 0, (src1 op src2) ? src1 : src2); \
} else { \
DCHECK_EQ(m5, 0); \
- DCHECK_EQ(m6, 1); \
- VECTOR_FP_MAX_MIN_FOR_TYPE(float, op) \
+ VECTOR_FP_MAX_MIN_FOR_TYPE(float, op, std_op) \
} \
break; \
case 3: \
@@ -4024,8 +4054,7 @@ void VectorFPMaxMin(void* dst, void* src1, void* src2, Operation op) {
(src1 op src2) ? src1 : src2); \
} else { \
DCHECK_EQ(m5, 0); \
- DCHECK_EQ(m6, 1); \
- VECTOR_FP_MAX_MIN_FOR_TYPE(double, op) \
+ VECTOR_FP_MAX_MIN_FOR_TYPE(double, op, std_op) \
} \
break; \
default: \
@@ -4037,8 +4066,7 @@ EVALUATE(VFMIN) {
DCHECK(CpuFeatures::IsSupported(VECTOR_ENHANCE_FACILITY_1));
DCHECK_OPCODE(VFMIN);
DECODE_VRR_C_INSTRUCTION(r1, r2, r3, m6, m5, m4);
- USE(m6);
- VECTOR_FP_MAX_MIN(<) // NOLINT
+ VECTOR_FP_MAX_MIN(<, min) // NOLINT
return length;
}
@@ -4047,7 +4075,7 @@ EVALUATE(VFMAX) {
DCHECK_OPCODE(VFMAX);
DECODE_VRR_C_INSTRUCTION(r1, r2, r3, m6, m5, m4);
USE(m6);
- VECTOR_FP_MAX_MIN(>) // NOLINT
+ VECTOR_FP_MAX_MIN(>, max) // NOLINT
return length;
}
@@ -4224,24 +4252,39 @@ EVALUATE(VFSQ) {
return length;
}
+#define ROUNDING_SWITCH(type) \
+ switch (m5) { \
+ case 4: \
+ set_simd_register_by_lane<type>(r1, i, nearbyint(value)); \
+ break; \
+ case 5: \
+ set_simd_register_by_lane<type>(r1, i, trunc(value)); \
+ break; \
+ case 6: \
+ set_simd_register_by_lane<type>(r1, i, ceil(value)); \
+ break; \
+ case 7: \
+ set_simd_register_by_lane<type>(r1, i, floor(value)); \
+ break; \
+ default: \
+ UNREACHABLE(); \
+ }
EVALUATE(VFI) {
DCHECK_OPCODE(VFI);
DECODE_VRR_A_INSTRUCTION(r1, r2, m5, m4, m3);
USE(m4);
- USE(m5);
- DCHECK_EQ(m5, 5);
switch (m3) {
case 2:
DCHECK(CpuFeatures::IsSupported(VECTOR_ENHANCE_FACILITY_1));
for (int i = 0; i < 4; i++) {
float value = get_simd_register_by_lane<float>(r2, i);
- set_simd_register_by_lane<float>(r1, i, trunc(value));
+ ROUNDING_SWITCH(float)
}
break;
case 3:
for (int i = 0; i < 2; i++) {
double value = get_simd_register_by_lane<double>(r2, i);
- set_simd_register_by_lane<double>(r1, i, trunc(value));
+ ROUNDING_SWITCH(double)
}
break;
default:
@@ -4249,6 +4292,7 @@ EVALUATE(VFI) {
}
return length;
}
+#undef ROUNDING_SWITCH
EVALUATE(DUMY) {
DCHECK_OPCODE(DUMY);