How do I start a CUDA app in Visual Studio 2010?
CUDA TOOLKIT 4.0 and later
The build customisations file (installed into the Program Files\MSBuild\Microsoft.Cpp\v4.0\BuildCustomizations
directory) "teaches" Visual Studio how to compile and link any .cu files in your project into your application. If you chose to skip installing the customisations, or if you installed VS2010 after CUDA, you can add them later by following the instructions in Program Files\NVIDIA GPU Computing Toolkit\CUDA\v4.0\extras\visual_studio_integration
.
- Create a new project using the standard MS wizards (e.g. an empty console project)
- Implement your host (serial) code in .c or .cpp files
- Add the NVIDIA build customisation (right click on the project, Build customizations, tick the relevant CUDA box)
- See note 1 if using CUDA 4.0
- Implement your wrappers and kernels in .cu files
- If you added
.cu
files before the build customisations, then you'll need to set the type of the.cu
files toCUDA C/C++
(right-click on the file, Properties, set Item Type) - Add the CUDA runtime library (right click on the project and choose Properties, then in Linker -> Input add
cudart.lib
to the Additional Dependencies) - Then just build your project and the .cu files will be compiled to .obj and added to the link automatically
Incidentally I would advocate avoiding cutil if possible, instead roll your own checking. Cutil is not supported by NVIDIA, it's just used to try to keep the examples in the SDK focussed on the actual program and algorithm design and avoid repeating the same things in every example (e.g. command line parsing). If you write your own then you will have much better control and will know what is happening. For example, the cutilSafeCall
wrapper calls exit()
if the function fails - a real application (as opposed to a sample) should probably handle the failure more elegantly!
NOTE
- For CUDA 4.0 only you may need to apply this fix to the build customisations. This patch fixes the following message:
The result "" of evaluating the value "$(CudaBuildTasksPath)" of the "AssemblyFile" attribute in the element is not valid
This answer applies to CUDA 3.2, from 4.0 onwards CUDA supports the VC 10 compiler directly, see other answers for more information
You need either VS 2008 or the 6.1 Windows SDK installed. That's because NSight 1.5 RC or the CUDA 3.2 SDK use the VC 9 compiler under the hood. I've got this working successfully with 2008 installed and am told it should work with the SDK but haven't tried.
With NSight 1.5 and/or the CUDA 3.2 SDK you shouldn't need to muck with any custom build rules. I've been there and it's painful. With the latest builds all that goes away:
- Create your VC++ project.
- Add a .CU file to it.
- Select the project file in the Solution Explorer.
- Open Project | Build Customizations...
- Check the "CUDA 3.2 (.targets, .props)" customization.
- Select a .CU file in your project and hit Alt-Enter to show it's properties.
- Make sure it's Item Type is set to "CUDA C/C++"
It should just build. Let me know if this helps and if you run into problems as this is from memory.
The good news it getting CUDA working with VS 2010 just got much easier.
Ade
BTW: I'll update my blog post.