testAddSub.js 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. //-------------------------------------------------------------------------------------------------------
  2. // Copyright (C) Microsoft Corporation and contributors. All rights reserved.
  3. // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information.
  4. //-------------------------------------------------------------------------------------------------------
  5. this.WScript.LoadScriptFile("..\\UnitTestFramework\\SimdJsHelpers.js");
  6. function asmModule(stdlib, imports) {
  7. "use asm";
  8. var ui4 = stdlib.SIMD.Uint32x4;
  9. var ui4check = ui4.check;
  10. var ui4add = ui4.add;
  11. var ui4sub = ui4.sub;
  12. var globImportui4 = ui4check(imports.g1);
  13. var ui4g1 = ui4(1065353216, 1073741824,1077936128, 1082130432); // global var initialized
  14. var ui4g2 = ui4(6531634, 74182444, 779364128, 821730432);
  15. var loopCOUNT = 3;
  16. var i4 = stdlib.SIMD.Int32x4;
  17. var i4check = i4.check;
  18. var i4fu4 = i4.fromUint32x4Bits;
  19. function testAddLocal()
  20. {
  21. var a = ui4(8488484, 4848848, 29975939, 9493872);
  22. var b = ui4(99372621, 18848392, 888288822, 1000010012);
  23. var result = ui4(0, 0, 0, 0);
  24. var loopIndex = 0;
  25. while ( (loopIndex|0) < (loopCOUNT|0)) {
  26. result = ui4add(a, b);
  27. loopIndex = (loopIndex + 1) | 0;
  28. }
  29. return i4check(i4fu4(result));
  30. }
  31. function testSubLocal()
  32. {
  33. var a = ui4(8488484, 4848848, 29975939, 9493872);
  34. var b = ui4(99372621, 18848392, 888288822, 1000010012);
  35. var result = ui4(0, 0, 0, 0);
  36. var loopIndex = 0;
  37. while ( (loopIndex|0) < (loopCOUNT|0)) {
  38. result = ui4sub(a, b);
  39. loopIndex = (loopIndex + 1) | 0;
  40. }
  41. return i4check(i4fu4(result));
  42. }
  43. function testAddGlobal()
  44. {
  45. var result = ui4(0, 0, 0, 0);
  46. var loopIndex = 0;
  47. while ( (loopIndex|0) < (loopCOUNT|0)) {
  48. result = ui4add(ui4g1, ui4g2);
  49. loopIndex = (loopIndex + 1) | 0;
  50. }
  51. return i4check(i4fu4(result));
  52. }
  53. function testSubGlobal()
  54. {
  55. var result = ui4(0, 0, 0, 0);
  56. var loopIndex = 0;
  57. while ( (loopIndex|0) < (loopCOUNT|0)) {
  58. result = ui4sub(ui4g1, ui4g2);
  59. loopIndex = (loopIndex + 1) | 0;
  60. }
  61. return i4check(i4fu4(result));
  62. }
  63. function testAddGlobalImport()
  64. {
  65. var a = ui4(8488484, 4848848, 29975939, 9493872);
  66. var result = ui4(0, 0, 0, 0);
  67. var loopIndex = 0;
  68. while ( (loopIndex|0) < (loopCOUNT|0)) {
  69. result = ui4add(globImportui4, a);
  70. loopIndex = (loopIndex + 1) | 0;
  71. }
  72. return i4check(i4fu4(result));
  73. }
  74. function testSubGlobalImport()
  75. {
  76. var a = ui4(8488484, 4848848, 29975939, 9493872);
  77. var result = ui4(0, 0, 0, 0);
  78. var loopIndex = 0;
  79. while ( (loopIndex|0) < (loopCOUNT|0)) {
  80. result = ui4sub(globImportui4, a);
  81. loopIndex = (loopIndex + 1) | 0;
  82. }
  83. return i4check(i4fu4(result));
  84. }
  85. return { testAddLocal: testAddLocal, testSubLocal: testSubLocal, testAddGlobal: testAddGlobal, testSubGlobal: testSubGlobal, testAddGlobalImport: testAddGlobalImport, testSubGlobalImport: testSubGlobalImport };
  86. }
  87. var m = asmModule(this, {g1:SIMD.Uint32x4(100, 1073741824, 1028, 102)});
  88. var ret1 = SIMD.Uint32x4.fromInt32x4Bits(m.testAddLocal());
  89. var ret2 = SIMD.Uint32x4.fromInt32x4Bits(m.testSubLocal());
  90. var ret3 = SIMD.Uint32x4.fromInt32x4Bits(m.testAddGlobal());
  91. var ret4 = SIMD.Uint32x4.fromInt32x4Bits(m.testSubGlobal());
  92. var ret5 = SIMD.Uint32x4.fromInt32x4Bits(m.testAddGlobalImport());
  93. var ret6 = SIMD.Uint32x4.fromInt32x4Bits(m.testSubGlobalImport());
  94. equalSimd([107861105, 23697240, 918264761, 1009503884], ret1, SIMD.Uint32x4, "Func1");
  95. equalSimd([4204083159, 4280967752, 3436654413, 3304451156], ret2, SIMD.Uint32x4, "Func2");
  96. equalSimd([1071884850, 1147924268, 1857300256, 1903860864], ret3, SIMD.Uint32x4, "Func3");
  97. equalSimd([1058821582, 999559380, 298572000, 260400000], ret4, SIMD.Uint32x4, "Func4");
  98. equalSimd([8488584, 1078590672, 29976967, 9493974], ret5, SIMD.Uint32x4, "Func5");
  99. equalSimd([4286478912, 1068892976, 4264992385, 4285473526], ret6, SIMD.Uint32x4, "Func6");
  100. print("PASS");