| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- //-------------------------------------------------------------------------------------------------------
- // 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.
- //-------------------------------------------------------------------------------------------------------
- this.WScript.LoadScriptFile("..\\UnitTestFramework\\SimdJsHelpers.js");
- function asmModule(stdlib, imports) {
- "use asm";
- var i8 = stdlib.SIMD.Int16x8;
- var i8check = i8.check;
- var i8splat = i8.splat;
- var gval = 20;
- var loopCOUNT = 3;
- function splat1()
- {
- var a = i8(0, 0, 0, 0, 0, 0, 0, 0);
- var loopIndex = 0;
- while ((loopIndex | 0) < (loopCOUNT | 0)) {
- a = i8splat(100);
- loopIndex = (loopIndex + 1) | 0;
- }
- return i8check(a);
- }
-
- function splat2()
- {
- var a = i8(0, 0, 0, 0, 0, 0, 0, 0);
- var loopIndex = 0;
- while ((loopIndex | 0) < (loopCOUNT | 0)) {
- a = i8splat(value() | 0);
- loopIndex = (loopIndex + 1) | 0;
- }
- return i8check(a);
- }
- function splat3()
- {
- var a = i8(0, 0, 0, 0, 0, 0, 0, 0);
- var loopIndex = 0;
- while ((loopIndex | 0) < (loopCOUNT | 0)) {
- a = i8splat(gval);
- loopIndex = (loopIndex + 1) | 0;
- }
- return i8check(a);
- }
-
- function value()
- {
- var ret = 1;
- var i = 0;
-
- for (i = 0; (i | 0) < 100; i = (i + 1) | 0)
- ret = (ret + i) | 0;
- return ret | 0;
- }
-
- return {func1:splat1, func2:splat2, func3:splat3};
- }
- var m = asmModule(this, {g1:SIMD.Int16x8(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16)});
- var ret1 = m.func1(SIMD.Int16x8(1, 2, 3, 4, 5, 6, 7, 8), SIMD.Float32x4(1, 2, 3, 4)/*, SIMD.Float64x2(1, 2, 3, 4)*/);
- var ret2 = m.func2(SIMD.Int16x8(1, 2, 3, 4, 5, 6, 7, 8), SIMD.Float32x4(1, 2, 3, 4)/*, SIMD.Float64x2(1, 2, 3, 4)*/);
- var ret3 = m.func3(SIMD.Int16x8(1, 2, 3, 4, 5, 6, 7, 8), SIMD.Float32x4(1, 2, 3, 4)/*, SIMD.Float64x2(1, 2, 3, 4)*/);
- equalSimd([100, 100, 100, 100, 100, 100, 100, 100], ret1, SIMD.Int16x8, "");
- equalSimd([4951, 4951, 4951, 4951, 4951, 4951, 4951, 4951], ret2, SIMD.Int16x8, "");
- equalSimd([20, 20, 20, 20, 20, 20, 20, 20], ret3, SIMD.Int16x8, "");
- print("PASS");
|