我目前正在使用 VS2013。我创建了一个非常简单的 C# 解决方案,旨在将 Cloo 与一个简单的类一起使用:
using System;
using System.Collections.Concurrent;
using System.Threading.Tasks;
using System.IO;
using Cloo;
namespace ClooTest
{
class Test
{
public static void main_entry(byte[] args)
{
ComputePlatform platform = ComputePlatform.Platforms[0];
ComputeContext context = new ComputeContext(ComputeDeviceTypes.Gpu,
new ComputeContextPropertyList(platform), null, IntPtr.Zero);
ComputeCommandQueue queue = new ComputeCommandQueue(context,
context.Devices[0], ComputeCommandQueueFlags.None);
// get and build the source code
ComputeProgram program = new ComputeProgram(context, new string[] { kernelCode });
program.Build(null, null, null, IntPtr.Zero);
// pick the fucntion
ComputeKernel kernel = program.CreateKernel("add_data");
// create a ten integer array and its length
byte[] data1 = new byte[] { 1, 2, 3, 4, 5 };
byte[] data2 = new byte[] { 1, 2, 3, 4, 5 };
int size = data1.Length;
/* allocate memory */
ComputeBuffer<byte> data1buffer = new ComputeBuffer<byte>(context,
ComputeMemoryFlags.ReadWrite, data1);
ComputeBuffer<byte> data2buffer = new ComputeBuffer<byte>(context,
ComputeMemoryFlags.ReadWrite, data2);
kernel.SetMemoryArgument(0, data1buffer); // set the byte array
kernel.SetMemoryArgument(1, data2buffer); // set the byte array
kernel.SetValueArgument(2, size); // set third argument as size;
// execute
queue.ExecuteTask(kernel, null);
// wait for completion
queue.Finish();
// output results
for (int i = 0; i < size; i++)
Console.WriteLine(data1[i].ToString());
}
#region Kernels
private static string kernelCode = @"__kernel void add_data(__local char* data1, __local char* data2, __local int n)
{
data1[0]=data1[0]+data2[0];
}";
#endregion
}
}
虽然我在 Visual Studio 中构建解决方案没有任何问题,但我不断收到“检测到 OpenCL 错误代码:BuildProgramFailure ”。尝试使用“ program.Build(null, null, null, IntPtr.Zero) ”构建程序时。内核代码看起来不错,但我已经在这工作了几个晚上,似乎无法弄清楚发生了什么。你可能会说我对 Cloo 很陌生,我从网上的例子中得到了一些想法,但我可能在一个非常简单的层面上做错了。任何建议都会很棒。
我已经为我的显卡下载了所有最新的 OpenCL 驱动程序。
谢谢