testMul.js 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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 ui4mul = ui4.mul;
  11. var globImportui4 = ui4check(imports.g1);
  12. var ui4g1 = ui4(1065353216, 1073741824, 1077936128, 1082130432); // global var initialized
  13. var ui4g2 = ui4(6531634, 74182444, 779364128, 821730432);
  14. var loopCOUNT = 3;
  15. var i4 = stdlib.SIMD.Int32x4;
  16. var i4check = i4.check;
  17. var i4fu4 = i4.fromUint32x4Bits;
  18. function testMulLocal()
  19. {
  20. var a = ui4(8488484, 4848848, 29975939, 9493872);
  21. var b = ui4(99372621, 18848392, 888288822, 1000010012);
  22. var result = ui4(0, 0, 0, 0);
  23. var loopIndex = 0;
  24. while ( (loopIndex|0) < (loopCOUNT|0)) {
  25. result = ui4mul(a, b);
  26. loopIndex = (loopIndex + 1) | 0;
  27. }
  28. return i4check(i4fu4(result));
  29. }
  30. function testMulGlobal()
  31. {
  32. var result = ui4(0, 0, 0, 0);
  33. var loopIndex = 0;
  34. while ((loopIndex | 0) < (loopCOUNT | 0)) {
  35. result = ui4mul(ui4g1, ui4g2);
  36. loopIndex = (loopIndex + 1) | 0;
  37. }
  38. return i4check(i4fu4(result));
  39. }
  40. function testMulGlobalImport()
  41. {
  42. var a = ui4(8488484, 4848848, 29975939, 9493872);
  43. var result = ui4(0, 0, 0, 0);
  44. var loopIndex = 0;
  45. while ((loopIndex | 0) < (loopCOUNT | 0)) {
  46. result = ui4mul(globImportui4, a);
  47. loopIndex = (loopIndex + 1) | 0;
  48. }
  49. return i4check(i4fu4(result));
  50. }
  51. return {testMulLocal:testMulLocal, testMulGlobal:testMulGlobal, testMulGlobalImport:testMulGlobalImport};
  52. }
  53. var m = asmModule(this, { g1: SIMD.Uint32x4(100, 1073741824, 1028, 102) });
  54. var ret1 = SIMD.Uint32x4.fromInt32x4Bits(m.testMulLocal());
  55. var ret2 = SIMD.Uint32x4.fromInt32x4Bits(m.testMulGlobal());
  56. var ret3 = SIMD.Uint32x4.fromInt32x4Bits(m.testMulGlobalImport());
  57. equalSimd([4211364052, 378760832, 1840974754, 1974380608], ret1, SIMD.Uint32x4, "Test Mul");
  58. equalSimd([1728053248, 0, 3355443200, 1073741824], ret2, SIMD.Uint32x4, "Test Mul");
  59. equalSimd([848848400, 0, 750494220, 968374944], ret3, SIMD.Uint32x4, "Test Mul");
  60. print("PASS");