Adding tests for the StoreFence/Prefetch* APIs and the new Sse scalar overloads.
authorTanner Gooding <tagoo@outlook.com>
Sat, 3 Feb 2018 17:30:11 +0000 (09:30 -0800)
committerTanner Gooding <tagoo@outlook.com>
Tue, 6 Feb 2018 05:52:56 +0000 (21:52 -0800)
tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch.cs [new file with mode: 0644]
tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch_r.csproj [new file with mode: 0644]
tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch_ro.csproj [new file with mode: 0644]
tests/src/JIT/HardwareIntrinsics/X86/Sse/ReciprocalScalar.cs
tests/src/JIT/HardwareIntrinsics/X86/Sse/ReciprocalSqrtScalar.cs
tests/src/JIT/HardwareIntrinsics/X86/Sse/SqrtScalar.cs
tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence.cs [new file with mode: 0644]
tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence_r.csproj [new file with mode: 0644]
tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence_ro.csproj [new file with mode: 0644]

diff --git a/tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch.cs b/tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch.cs
new file mode 100644 (file)
index 0000000..d14c555
--- /dev/null
@@ -0,0 +1,88 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT license.
+// See the LICENSE file in the project root for more information.
+//
+
+using System;
+using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
+using System.Runtime.Intrinsics.X86;
+using System.Runtime.Intrinsics;
+
+namespace IntelHardwareIntrinsicTest
+{
+    class Program
+    {
+        const int Pass = 100;
+        const int Fail = 0;
+
+        static unsafe int Main(string[] args)
+        {
+            int testResult = Pass;
+
+            if (Sse.IsSupported)
+            {
+                using (TestTable<float> floatTable = new TestTable<float>(new float[4] { 1, -5, 100, 3 }))
+                {
+                    try
+                    {
+                        Sse.Prefetch0(floatTable.inArrayPtr);
+                    }
+                    catch
+                    {
+                        testResult = Fail;
+                    }
+
+                    try
+                    {
+                        Sse.Prefetch1(floatTable.inArrayPtr);
+                    }
+                    catch
+                    {
+                        testResult = Fail;
+                    }
+
+                    try
+                    {
+                        Sse.Prefetch2(floatTable.inArrayPtr);
+                    }
+                    catch
+                    {
+                        testResult = Fail;
+                    }
+
+                    try
+                    {
+                        Sse.PrefetchNonTemporal(floatTable.inArrayPtr);
+                    }
+                    catch
+                    {
+                        testResult = Fail;
+                    }
+                }
+            }
+
+            return testResult;
+        }
+
+        public unsafe struct TestTable<T> : IDisposable where T : struct
+        {
+            public T[] inArray;
+
+            public void* inArrayPtr => inHandle.AddrOfPinnedObject().ToPointer();
+
+            GCHandle inHandle;
+            public TestTable(T[] a)
+            {
+                this.inArray = a;
+
+                inHandle = GCHandle.Alloc(inArray, GCHandleType.Pinned);
+            }
+
+            public void Dispose()
+            {
+                inHandle.Free();
+            }
+        }
+    }
+}
diff --git a/tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch_r.csproj b/tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch_r.csproj
new file mode 100644 (file)
index 0000000..5d916be
--- /dev/null
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.props))\dir.props" />
+  <PropertyGroup>
+    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
+    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
+    <SchemaVersion>2.0</SchemaVersion>
+    <ProjectGuid>{95DFC527-4DC1-495E-97D7-E94EE1F7140D}</ProjectGuid>
+    <OutputType>Exe</OutputType>
+    <ProjectTypeGuids>{786C830F-07A1-408B-BD7F-6EE04809D6DB};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
+    <SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\..\</SolutionDir>
+    <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
+  </PropertyGroup>
+  <!-- Default configurations to help VS understand the configurations -->
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "></PropertyGroup>
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' " />
+  <ItemGroup>
+    <CodeAnalysisDependentAssemblyPaths Condition=" '$(VS100COMNTOOLS)' != '' " Include="$(VS100COMNTOOLS)..\IDE\PrivateAssemblies">
+      <Visible>False</Visible>
+    </CodeAnalysisDependentAssemblyPaths>
+  </ItemGroup>
+  <PropertyGroup>
+    <DebugType>None</DebugType>
+    <Optimize></Optimize>
+  </PropertyGroup>
+  <ItemGroup>
+    <Service Include="{82A7F48D-3B50-4B1E-B82E-3ADA8210C358}" />
+  </ItemGroup>
+  <ItemGroup>
+    <Compile Include="Prefetch.cs" />
+  </ItemGroup>
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.targets))\dir.targets" />
+  <PropertyGroup Condition=" '$(MsBuildProjectDirOverride)' != '' "></PropertyGroup>
+</Project>
diff --git a/tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch_ro.csproj b/tests/src/JIT/HardwareIntrinsics/X86/Sse/Prefetch_ro.csproj
new file mode 100644 (file)
index 0000000..c5cb8ee
--- /dev/null
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.props))\dir.props" />
+  <PropertyGroup>
+    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
+    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
+    <SchemaVersion>2.0</SchemaVersion>
+    <ProjectGuid>{95DFC527-4DC1-495E-97D7-E94EE1F7140D}</ProjectGuid>
+    <OutputType>Exe</OutputType>
+    <ProjectTypeGuids>{786C830F-07A1-408B-BD7F-6EE04809D6DB};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
+    <SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\..\</SolutionDir>
+    <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
+  </PropertyGroup>
+  <!-- Default configurations to help VS understand the configurations -->
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "></PropertyGroup>
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' " />
+  <ItemGroup>
+    <CodeAnalysisDependentAssemblyPaths Condition=" '$(VS100COMNTOOLS)' != '' " Include="$(VS100COMNTOOLS)..\IDE\PrivateAssemblies">
+      <Visible>False</Visible>
+    </CodeAnalysisDependentAssemblyPaths>
+  </ItemGroup>
+  <PropertyGroup>
+    <DebugType>None</DebugType>
+    <Optimize>True</Optimize>
+  </PropertyGroup>
+  <ItemGroup>
+    <Service Include="{82A7F48D-3B50-4B1E-B82E-3ADA8210C358}" />
+  </ItemGroup>
+  <ItemGroup>
+    <Compile Include="Prefetch.cs" />
+  </ItemGroup>
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.targets))\dir.targets" />
+  <PropertyGroup Condition=" '$(MsBuildProjectDirOverride)' != '' "></PropertyGroup>
+</Project>
index 7758114..a2db543 100644 (file)
@@ -24,18 +24,17 @@ namespace IntelHardwareIntrinsicTest
             {
                 using (TestTable<float> floatTable = new TestTable<float>(new float[4] { 1, -5, 100, 0 }, new float[4]))
                 {
-
-                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArrayPtr);
+                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArray1Ptr);
                     var vf2 = Sse.ReciprocalScalar(vf1);
                     Unsafe.Write(floatTable.outArrayPtr, vf2);
 
-                    if (!floatTable.CheckResult((x, y) => {
-                        var expected = 1 / x[0];
-                        return ((Math.Abs(expected - y[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
-                             || (float.IsNaN(expected) && float.IsNaN(y[0]))
-                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(y[0]))
-                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(y[0])))
-                            && (y[1] == x[1]) && (y[2] == x[2]) && (y[3] == x[3]);
+                    if (!floatTable.CheckResult((x, y, z) => {
+                        var expected = 1 / y[0];
+                        return ((Math.Abs(expected - z[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
+                             || (float.IsNaN(expected) && float.IsNaN(z[0]))
+                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(z[0]))
+                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(z[0])))
+                            && (z[1] == x[1]) && (z[2] == x[2]) && (z[3] == x[3]);
                     }))
                     {
                         Console.WriteLine("SSE ReciprocalScalar failed on float:");
@@ -47,41 +46,74 @@ namespace IntelHardwareIntrinsicTest
                         testResult = Fail;
                     }
                 }
-            }
 
+                using (TestTable<float> floatTable = new TestTable<float>(new float[4] { 1, -5, 100, 0 }, new float[4] { 22, -1, -50, 0 }, new float[4]))
+                {
+                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArray1Ptr);
+                    var vf2 = Unsafe.Read<Vector128<float>>(floatTable.inArray2Ptr);
+                    var vf3 = Sse.ReciprocalScalar(vf1, vf2);
+                    Unsafe.Write(floatTable.outArrayPtr, vf3);
+
+                    if (!floatTable.CheckResult((x, y, z) => {
+                        var expected = 1 / y[0];
+                        return ((Math.Abs(expected - z[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
+                             || (float.IsNaN(expected) && float.IsNaN(z[0]))
+                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(z[0]))
+                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(z[0])))
+                            && (z[1] == x[1]) && (z[2] == x[2]) && (z[3] == x[3]);
+                    }))
+                    {
+                        Console.WriteLine("SSE ReciprocalScalar failed on float:");
+                        foreach (var item in floatTable.outArray)
+                        {
+                            Console.Write(item + ", ");
+                        }
+                        Console.WriteLine();
+                        testResult = Fail;
+                    }
+                }
+            }
 
             return testResult;
         }
 
         public unsafe struct TestTable<T> : IDisposable where T : struct
         {
-            public T[] inArray;
+            public T[] inArray1;
+            public T[] inArray2;
             public T[] outArray;
 
-            public void* inArrayPtr => inHandle.AddrOfPinnedObject().ToPointer();
+            public void* inArray1Ptr => inHandle1.AddrOfPinnedObject().ToPointer();
+            public void* inArray2Ptr => inHandle2.AddrOfPinnedObject().ToPointer();
             public void* outArrayPtr => outHandle.AddrOfPinnedObject().ToPointer();
 
-            GCHandle inHandle;
+            GCHandle inHandle1;
+            GCHandle inHandle2;
             GCHandle outHandle;
-            public TestTable(T[] a, T[] b)
+            public TestTable(T[] a, T[] b) : this(a, a, b)
+            {
+            }
+            public TestTable(T[] a, T[] b, T[] c)
             {
-                this.inArray = a;
-                this.outArray = b;
+                this.inArray1 = a;
+                this.inArray2 = b;
+                this.outArray = c;
 
-                inHandle = GCHandle.Alloc(inArray, GCHandleType.Pinned);
+                inHandle1 = GCHandle.Alloc(inArray1, GCHandleType.Pinned);
+                inHandle2 = GCHandle.Alloc(inArray2, GCHandleType.Pinned);
                 outHandle = GCHandle.Alloc(outArray, GCHandleType.Pinned);
             }
-            public bool CheckResult(Func<T[], T[], bool> check)
+            public bool CheckResult(Func<T[], T[], T[], bool> check)
             {
-                return check(inArray, outArray);
+                return check(inArray1, inArray2, outArray);
             }
 
             public void Dispose()
             {
-                inHandle.Free();
+                inHandle1.Free();
+                inHandle2.Free();
                 outHandle.Free();
             }
         }
-
     }
 }
index 669e51b..30be5f4 100644 (file)
@@ -24,18 +24,17 @@ namespace IntelHardwareIntrinsicTest
             {
                 using (TestTable<float> floatTable = new TestTable<float>(new float[4] { 1, -5, 100, 0 }, new float[4]))
                 {
-
-                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArrayPtr);
+                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArray1Ptr);
                     var vf2 = Sse.ReciprocalSqrtScalar(vf1);
                     Unsafe.Write(floatTable.outArrayPtr, vf2);
 
-                    if (!floatTable.CheckResult((x, y) => {
-                        var expected = 1 / MathF.Sqrt(x[0]);
-                        return ((Math.Abs(expected - y[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
-                             || (float.IsNaN(expected) && float.IsNaN(y[0]))
-                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(y[0]))
-                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(y[0])))
-                            && (y[1] == x[1]) && (y[2] == x[2]) && (y[3] == x[3]);
+                    if (!floatTable.CheckResult((x, y, z) => {
+                        var expected = 1 / MathF.Sqrt(y[0]);
+                        return ((Math.Abs(expected - z[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
+                             || (float.IsNaN(expected) && float.IsNaN(z[0]))
+                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(z[0]))
+                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(z[0])))
+                            && (z[1] == x[1]) && (z[2] == x[2]) && (z[3] == x[3]);
                     }))
                     {
                         Console.WriteLine("SSE ReciprocalSqrtScalar failed on float:");
@@ -47,41 +46,74 @@ namespace IntelHardwareIntrinsicTest
                         testResult = Fail;
                     }
                 }
-            }
 
+                using (TestTable<float> floatTable = new TestTable<float>(new float[4] { 1, -5, 100, 0 }, new float[4] { 22, -1, -50, 0 }, new float[4]))
+                {
+                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArray1Ptr);
+                    var vf2 = Unsafe.Read<Vector128<float>>(floatTable.inArray2Ptr);
+                    var vf3 = Sse.ReciprocalSqrtScalar(vf1, vf2);
+                    Unsafe.Write(floatTable.outArrayPtr, vf3);
+
+                    if (!floatTable.CheckResult((x, y, z) => {
+                        var expected = 1 / MathF.Sqrt(y[0]);
+                        return ((Math.Abs(expected - z[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
+                             || (float.IsNaN(expected) && float.IsNaN(z[0]))
+                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(z[0]))
+                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(z[0])))
+                            && (z[1] == x[1]) && (z[2] == x[2]) && (z[3] == x[3]);
+                    }))
+                    {
+                        Console.WriteLine("SSE ReciprocalSqrtScalar failed on float:");
+                        foreach (var item in floatTable.outArray)
+                        {
+                            Console.Write(item + ", ");
+                        }
+                        Console.WriteLine();
+                        testResult = Fail;
+                    }
+                }
+            }
 
             return testResult;
         }
 
         public unsafe struct TestTable<T> : IDisposable where T : struct
         {
-            public T[] inArray;
+            public T[] inArray1;
+            public T[] inArray2;
             public T[] outArray;
 
-            public void* inArrayPtr => inHandle.AddrOfPinnedObject().ToPointer();
+            public void* inArray1Ptr => inHandle1.AddrOfPinnedObject().ToPointer();
+            public void* inArray2Ptr => inHandle2.AddrOfPinnedObject().ToPointer();
             public void* outArrayPtr => outHandle.AddrOfPinnedObject().ToPointer();
 
-            GCHandle inHandle;
+            GCHandle inHandle1;
+            GCHandle inHandle2;
             GCHandle outHandle;
-            public TestTable(T[] a, T[] b)
+            public TestTable(T[] a, T[] b) : this(a, a, b)
+            {
+            }
+            public TestTable(T[] a, T[] b, T[] c)
             {
-                this.inArray = a;
-                this.outArray = b;
+                this.inArray1 = a;
+                this.inArray2 = b;
+                this.outArray = c;
 
-                inHandle = GCHandle.Alloc(inArray, GCHandleType.Pinned);
+                inHandle1 = GCHandle.Alloc(inArray1, GCHandleType.Pinned);
+                inHandle2 = GCHandle.Alloc(inArray2, GCHandleType.Pinned);
                 outHandle = GCHandle.Alloc(outArray, GCHandleType.Pinned);
             }
-            public bool CheckResult(Func<T[], T[], bool> check)
+            public bool CheckResult(Func<T[], T[], T[], bool> check)
             {
-                return check(inArray, outArray);
+                return check(inArray1, inArray2, outArray);
             }
 
             public void Dispose()
             {
-                inHandle.Free();
+                inHandle1.Free();
+                inHandle2.Free();
                 outHandle.Free();
             }
         }
-
     }
 }
index b553070..8852b84 100644 (file)
@@ -24,16 +24,17 @@ namespace IntelHardwareIntrinsicTest
             {
                 using (TestTable<float> floatTable = new TestTable<float>(new float[4] { 1, -5, 100, 0 }, new float[4]))
                 {
-
-                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArrayPtr);
+                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArray1Ptr);
                     var vf2 = Sse.SqrtScalar(vf1);
                     Unsafe.Write(floatTable.outArrayPtr, vf2);
 
-                    if (!floatTable.CheckResult((x, y) => {
-                        var expected = MathF.Sqrt(x[0]);
-                        return ((expected == y[0])
-                             || (float.IsNaN(expected) && float.IsNaN(y[0])))
-                            && (y[1] == x[1]) && (y[2] == x[2]) && (y[3] == x[3]);
+                    if (!floatTable.CheckResult((x, y, z) => {
+                        var expected = MathF.Sqrt(y[0]);
+                        return ((Math.Abs(expected - z[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
+                             || (float.IsNaN(expected) && float.IsNaN(z[0]))
+                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(z[0]))
+                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(z[0])))
+                            && (z[1] == x[1]) && (z[2] == x[2]) && (z[3] == x[3]);
                     }))
                     {
                         Console.WriteLine("SSE SqrtScalar failed on float:");
@@ -45,41 +46,74 @@ namespace IntelHardwareIntrinsicTest
                         testResult = Fail;
                     }
                 }
-            }
 
+                using (TestTable<float> floatTable = new TestTable<float>(new float[4] { 1, -5, 100, 0 }, new float[4] { 22, -1, -50, 0 }, new float[4]))
+                {
+                    var vf1 = Unsafe.Read<Vector128<float>>(floatTable.inArray1Ptr);
+                    var vf2 = Unsafe.Read<Vector128<float>>(floatTable.inArray2Ptr);
+                    var vf3 = Sse.SqrtScalar(vf1, vf2);
+                    Unsafe.Write(floatTable.outArrayPtr, vf3);
+
+                    if (!floatTable.CheckResult((x, y, z) => {
+                        var expected = MathF.Sqrt(y[0]);
+                        return ((Math.Abs(expected - z[0]) <= 0.0003662109375f) // |Relative Error| <= 1.5 * 2^-12
+                             || (float.IsNaN(expected) && float.IsNaN(z[0]))
+                             || (float.IsNegativeInfinity(expected) && float.IsNegativeInfinity(z[0]))
+                             || (float.IsPositiveInfinity(expected) && float.IsPositiveInfinity(z[0])))
+                            && (z[1] == x[1]) && (z[2] == x[2]) && (z[3] == x[3]);
+                    }))
+                    {
+                        Console.WriteLine("SSE SqrtScalar failed on float:");
+                        foreach (var item in floatTable.outArray)
+                        {
+                            Console.Write(item + ", ");
+                        }
+                        Console.WriteLine();
+                        testResult = Fail;
+                    }
+                }
+            }
 
             return testResult;
         }
 
         public unsafe struct TestTable<T> : IDisposable where T : struct
         {
-            public T[] inArray;
+            public T[] inArray1;
+            public T[] inArray2;
             public T[] outArray;
 
-            public void* inArrayPtr => inHandle.AddrOfPinnedObject().ToPointer();
+            public void* inArray1Ptr => inHandle1.AddrOfPinnedObject().ToPointer();
+            public void* inArray2Ptr => inHandle2.AddrOfPinnedObject().ToPointer();
             public void* outArrayPtr => outHandle.AddrOfPinnedObject().ToPointer();
 
-            GCHandle inHandle;
+            GCHandle inHandle1;
+            GCHandle inHandle2;
             GCHandle outHandle;
-            public TestTable(T[] a, T[] b)
+            public TestTable(T[] a, T[] b) : this(a, a, b)
+            {
+            }
+            public TestTable(T[] a, T[] b, T[] c)
             {
-                this.inArray = a;
-                this.outArray = b;
+                this.inArray1 = a;
+                this.inArray2 = b;
+                this.outArray = c;
 
-                inHandle = GCHandle.Alloc(inArray, GCHandleType.Pinned);
+                inHandle1 = GCHandle.Alloc(inArray1, GCHandleType.Pinned);
+                inHandle2 = GCHandle.Alloc(inArray2, GCHandleType.Pinned);
                 outHandle = GCHandle.Alloc(outArray, GCHandleType.Pinned);
             }
-            public bool CheckResult(Func<T[], T[], bool> check)
+            public bool CheckResult(Func<T[], T[], T[], bool> check)
             {
-                return check(inArray, outArray);
+                return check(inArray1, inArray2, outArray);
             }
 
             public void Dispose()
             {
-                inHandle.Free();
+                inHandle1.Free();
+                inHandle2.Free();
                 outHandle.Free();
             }
         }
-
     }
 }
diff --git a/tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence.cs b/tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence.cs
new file mode 100644 (file)
index 0000000..b8ba181
--- /dev/null
@@ -0,0 +1,38 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT license.
+// See the LICENSE file in the project root for more information.
+//
+
+using System;
+using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
+using System.Runtime.Intrinsics.X86;
+using System.Runtime.Intrinsics;
+
+namespace IntelHardwareIntrinsicTest
+{
+    class Program
+    {
+        const int Pass = 100;
+        const int Fail = 0;
+
+        static unsafe int Main(string[] args)
+        {
+            int testResult = Pass;
+
+            if (Sse.IsSupported)
+            {
+                try
+                {
+                    Sse.StoreFence();
+                }
+                catch
+                {
+                    testResult = Fail;
+                }
+            }
+
+            return testResult;
+        }
+    }
+}
diff --git a/tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence_r.csproj b/tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence_r.csproj
new file mode 100644 (file)
index 0000000..a3ec7a2
--- /dev/null
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.props))\dir.props" />
+  <PropertyGroup>
+    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
+    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
+    <SchemaVersion>2.0</SchemaVersion>
+    <ProjectGuid>{95DFC527-4DC1-495E-97D7-E94EE1F7140D}</ProjectGuid>
+    <OutputType>Exe</OutputType>
+    <ProjectTypeGuids>{786C830F-07A1-408B-BD7F-6EE04809D6DB};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
+    <SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\..\</SolutionDir>
+    <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
+  </PropertyGroup>
+  <!-- Default configurations to help VS understand the configurations -->
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "></PropertyGroup>
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' " />
+  <ItemGroup>
+    <CodeAnalysisDependentAssemblyPaths Condition=" '$(VS100COMNTOOLS)' != '' " Include="$(VS100COMNTOOLS)..\IDE\PrivateAssemblies">
+      <Visible>False</Visible>
+    </CodeAnalysisDependentAssemblyPaths>
+  </ItemGroup>
+  <PropertyGroup>
+    <DebugType>None</DebugType>
+    <Optimize></Optimize>
+  </PropertyGroup>
+  <ItemGroup>
+    <Service Include="{82A7F48D-3B50-4B1E-B82E-3ADA8210C358}" />
+  </ItemGroup>
+  <ItemGroup>
+    <Compile Include="StoreFence.cs" />
+  </ItemGroup>
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.targets))\dir.targets" />
+  <PropertyGroup Condition=" '$(MsBuildProjectDirOverride)' != '' "></PropertyGroup>
+</Project>
diff --git a/tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence_ro.csproj b/tests/src/JIT/HardwareIntrinsics/X86/Sse/StoreFence_ro.csproj
new file mode 100644 (file)
index 0000000..44afc66
--- /dev/null
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.props))\dir.props" />
+  <PropertyGroup>
+    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
+    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
+    <SchemaVersion>2.0</SchemaVersion>
+    <ProjectGuid>{95DFC527-4DC1-495E-97D7-E94EE1F7140D}</ProjectGuid>
+    <OutputType>Exe</OutputType>
+    <ProjectTypeGuids>{786C830F-07A1-408B-BD7F-6EE04809D6DB};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
+    <SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\..\</SolutionDir>
+    <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
+  </PropertyGroup>
+  <!-- Default configurations to help VS understand the configurations -->
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "></PropertyGroup>
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' " />
+  <ItemGroup>
+    <CodeAnalysisDependentAssemblyPaths Condition=" '$(VS100COMNTOOLS)' != '' " Include="$(VS100COMNTOOLS)..\IDE\PrivateAssemblies">
+      <Visible>False</Visible>
+    </CodeAnalysisDependentAssemblyPaths>
+  </ItemGroup>
+  <PropertyGroup>
+    <DebugType>None</DebugType>
+    <Optimize>True</Optimize>
+  </PropertyGroup>
+  <ItemGroup>
+    <Service Include="{82A7F48D-3B50-4B1E-B82E-3ADA8210C358}" />
+  </ItemGroup>
+  <ItemGroup>
+    <Compile Include="StoreFence.cs" />
+  </ItemGroup>
+  <Import Project="$([MSBuild]::GetDirectoryNameOfFileAbove($(MSBuildThisFileDirectory), dir.targets))\dir.targets" />
+  <PropertyGroup Condition=" '$(MsBuildProjectDirOverride)' != '' "></PropertyGroup>
+</Project>