| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- //-------------------------------------------------------------------------------------------------------
- // Copyright (C) Microsoft Corporation and contributors. All rights reserved.
- // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information.
- //-------------------------------------------------------------------------------------------------------
- #include "RuntimeLanguagePch.h"
- #if defined(_M_ARM32_OR_ARM64)
- namespace Js
- {
- SIMDValue SIMDUint8x16Operation::OpUint8x16(uint8 values[])
- {
- SIMDValue result;
- for (uint i = 0; i < 16; i++)
- {
- result.u8[i] = values[i];
- }
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpMin(const SIMDValue& aValue, const SIMDValue& bValue)
- {
- SIMDValue result;
- for (uint idx = 0; idx < 16; ++idx)
- {
- result.u8[idx] = (aValue.u8[idx] < bValue.u8[idx]) ? aValue.u8[idx] : bValue.u8[idx];
- }
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpMax(const SIMDValue& aValue, const SIMDValue& bValue)
- {
- SIMDValue result;
- for (uint idx = 0; idx < 16; ++idx)
- {
- result.u8[idx] = (aValue.u8[idx] > bValue.u8[idx]) ? aValue.u8[idx] : bValue.u8[idx];
- }
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpLessThan(const SIMDValue& aValue, const SIMDValue& bValue) //arun::ToDo return bool types
- {
- SIMDValue result;
- for (uint idx = 0; idx < 16; ++idx)
- {
- result.u8[idx] = (aValue.u8[idx] < bValue.u8[idx]) ? 0xff : 0x0;
- }
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpLessThanOrEqual(const SIMDValue& aValue, const SIMDValue& bValue) //arun::ToDo return bool types
- {
- SIMDValue result;
- for (uint idx = 0; idx < 16; ++idx)
- {
- result.u8[idx] = (aValue.u8[idx] <= bValue.u8[idx]) ? 0xff : 0x0;
- }
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpGreaterThanOrEqual(const SIMDValue& aValue, const SIMDValue& bValue)
- {
- SIMDValue result;
- result = SIMDUint8x16Operation::OpLessThan(aValue, bValue);
- result = SIMDInt32x4Operation::OpNot(result);
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpGreaterThan(const SIMDValue& aValue, const SIMDValue& bValue)
- {
- SIMDValue result;
- result = SIMDUint8x16Operation::OpLessThanOrEqual(aValue, bValue);
- result = SIMDInt32x4Operation::OpNot(result);
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpShiftRightByScalar(const SIMDValue& value, int count)
- {
- SIMDValue result;
- count = count & SIMDUtils::SIMDGetShiftAmountMask(1);
- for (uint idx = 0; idx < 16; ++idx)
- {
- result.u8[idx] = (value.u8[idx] >> count);
- }
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpAddSaturate(const SIMDValue& aValue, const SIMDValue& bValue)
- {
- SIMDValue result;
- for (uint idx = 0; idx < 16; ++idx)
- {
- uint16 a = (uint16)aValue.u8[idx];
- uint16 b = (uint16)bValue.u8[idx];
- result.u8[idx] = ((a + b) > MAXUINT8) ? MAXUINT8 : (uint8)(a + b);
- }
- return result;
- }
- SIMDValue SIMDUint8x16Operation::OpSubSaturate(const SIMDValue& aValue, const SIMDValue& bValue)
- {
- SIMDValue result;
- for (uint idx = 0; idx < 16; ++idx)
- {
- int a = (int)aValue.u8[idx];
- int b = (int)bValue.u8[idx];
- result.u8[idx] = ((a - b) < 0) ? 0 : (uint8)(a - b);
- }
- return result;
- }
- }
- #endif
|