This is due Friday, September 1 2017. (See late policy at the bottom)
Summary: In this project, you will set up your CUDA development tools and verify that you can build, run, and do performance analysis.
This project is a simple program that demonstrates CUDA and OpenGL functionality and interoperability, testing that CUDA has been properly installed. If the machine you are working on has CUDA and OpenGL 4.0 support, then when you run the program, you should see either one or two colors depending on your graphics card.
This project (and all other CUDA projects in this course) requires an NVIDIA
graphics card with CUDA capability. Any card with Compute Capability 2.0
(sm_20
) or greater will work. Gheck your GPU in this compatibility
table. If you do not have a personal
machine with these specs, you may use computers in the Moore or SIG Labs.
If you need to use the lab computer for your development:
CUDA 8.0, Visual Studio 2015, CMake and Git are already installed on all of the CETS Lab PCs including the machines in Moore 100B and Moore 100C.
Skip this part if you are developing on a lab computer.
- Make sure you are running Windows 7/8/10 and that your NVIDIA drivers are up-to-date. You will need support for OpenGL 4.0 or better in this course.
- Install Visual Studio 2015.
- 2012/2013 will also work, if you already have one installed.
- 2010 doesn't work because glfw only supports 32-bit binaries for vc2010. We don't provide libraries for Win32
- http://www.seas.upenn.edu/cets/software/msdn/
- You need C++ support. None of the optional components are necessary.
- Install CUDA 8.
-
CUDA 8 is enforced for consistency because VS2015 doesn't support CUDA 7.5. However, if you have any reason that you have to use CUDA 7.5, please clarify you're using CUDA 7.5 in your report. Also you need to change
find_package(CUDA 8.0 REQUIRED)
inCMakeLists.txt
tofind_package(CUDA REQUIRED)
before you build your project. -
Use the Express installation. If using Custom, make sure you select Nsight for Visual Studio.
-
- Install CMake. (Windows binaries are under "Binary distributions.")
- Install Git.
- Make sure you are running OS X 10.9 or newer.
- Install XCode (available for free from the App Store).
- On 10.10, this may not actually be necessary. Try running
gcc
in a terminal first.
- On 10.10, this may not actually be necessary. Try running
- Install OS X Unix Command Line Development Tools (if necessary).
- Install CUDA 8
(don't use cask; the CUDA cask is outdated).
- CUDA 8 is recommended.
However, if you have any reason that you have to use CUDA 7.5, please clarify
you're using CUDA 7.5 in your report. Also you need to change
find_package(CUDA 8.0 REQUIRED)
inCMakeLists.txt
tofind_package(CUDA REQUIRED)
before you build your project. - Make sure you select Nsight.
- CUDA 8 is recommended.
However, if you have any reason that you have to use CUDA 7.5, please clarify
you're using CUDA 7.5 in your report. Also you need to change
- Install Git
(or:
brew install git
). - Install CMake
(or:
brew cask install cmake
).
Note: to debug CUDA on Linux, you will need an NVIDIA GPU with Compute Capability 5.0.
- Install CUDA 8.
- CUDA 8 is recommended.
However, if you have any reason that you have to use CUDA 7.5, please clarify
you're using CUDA 7.5 in your report. Also you need to change
find_package(CUDA 8.0 REQUIRED)
inCMakeLists.txt
tofind_package(CUDA REQUIRED)
before you build your project. For more Linux installation info, check out CUDA_Linux Installation Guide. - Make sure you select Nsight.
- CUDA 8 is recommended.
However, if you have any reason that you have to use CUDA 7.5, please clarify
you're using CUDA 7.5 in your report. Also you need to change
- Install Git (
apt-get install git
on Debian/Ubuntu). - Install CMake (
apt-get install cmake
on Debian/Ubuntu).
- Use GitHub to fork this repository into your own GitHub account.
- If you haven't used Git, you'll need to set up a few things.
- On Windows: In order to use Git commands, you can use Git Bash. You can right-click in a folder and open Git Bash there.
- On OS X/Linux: Open a terminal.
- Configure git with some basic options by running these commands:
git config --global push.default simple
git config --global user.name "YOUR NAME"
git config --global user.email "[email protected]"
- (Or, you can use your own address, but remember that it will be public!)
- Clone from GitHub onto your machine:
- Navigate to the directory where you want to keep your 565 projects, then
clone your fork.
git clone
the clone URL from your GitHub fork homepage.
- Navigate to the directory where you want to keep your 565 projects, then
clone your fork.
src/
contains the source code.external/
contains the binaries and headers for GLEW and GLFW.
CMake note: Do not change any build settings or add any files to your
project directly (in Visual Studio, Nsight, etc.) Instead, edit the
src/CMakeLists.txt
file. Any files you add must be added here. If you edit it,
just rebuild your VS/Nsight project to make it update itself.
- In Git Bash, navigate to your cloned project directory.
- Create a
build
directory:mkdir build
- (This "out-of-source" build makes it easy to delete the
build
directory and try again if something goes wrong with the configuration.)
- (This "out-of-source" build makes it easy to delete the
- Navigate into that directory:
cd build
- Open the CMake GUI to configure the project:
cmake-gui ..
or"C:\Program Files (x86)\cmake\bin\cmake-gui.exe" ..
- Don't forget the
..
part!
- Don't forget the
- Make sure that the "Source" directory is like
.../Project0-CUDA-Getting-Started
. - Click Configure. Select your version of Visual Studio, Win64. (NOTE: you must use Win64, as we don't provide libraries for Win32.)
- If you see an error like
CUDA_SDK_ROOT_DIR-NOTFOUND
, setCUDA_SDK_ROOT_DIR
to your CUDA install path. This will be something like:C:/Program Files/NVIDIA GPU Computing Toolkit/CUDA/v7.5
- Click Generate.
- If generation was successful, there should now be a Visual Studio solution
(
.sln
) file in thebuild
directory that you just created. Open this. (from the command line:explorer *.sln
) - Build. (Note that there are Debug and Release configuration options.)
- Run. Make sure you run the
cis565_
target (notALL_BUILD
) by right-clicking it and selecting "Set as StartUp Project".- If you have switchable graphics (NVIDIA Optimus), you may need to force your program to run with only the NVIDIA card. In NVIDIA Control Panel, under "Manage 3D Settings," set "Multi-display/Mixed GPU acceleration" to "Single display performance mode".
It is recommended that you use Nsight. Nsight is shipped with CUDA. If you set up the environment path correctly export PATH=/usr/local/cuda-8.0/bin${PATH:+:${PATH}}
(Note that simply typing the export
command is a temporary change. The PATH
variable won't be updated permanently. For permanent change, add it to your shell configuration file, e.g. ~/.profile
on Ubuntu), you can run Nsight by typing nsight
in your terminal.
- Open Nsight. Set the workspace to the one containing your cloned repo.
- File->Import...->General->Existing Projects Into Workspace.
- Select the Project 0 repository as the root directory.
- Select the cis565- project in the Project Explorer. Right click the project. Select Build Project.
- For later use, note that you can select various Debug and Release build configurations under Project->Build Configurations->Set Active....
- If you see an error like
CUDA_SDK_ROOT_DIR-NOTFOUND
:- In a terminal, navigate to the build directory, then run:
cmake-gui ..
- Set
CUDA_SDK_ROOT_DIR
to your CUDA install path. This will be something like:/usr/local/cuda
- Click Configure, then Generate.
- In a terminal, navigate to the build directory, then run:
- Right click and Refresh the project.
- From the Run menu, Run. Select "Local C/C++ Application" and the
cis565_
binary.
- Search the code for
TODO
: you'll find one insrc/main.cpp
on line 13. Change the string to your name, rebuild, and run. (m_yourName = "TODO: YOUR NAME HERE";
) - Take a screenshot of the window (including title bar) and save it to the
images
directory for Part 7. - You're done with some code changes now; make a commit!
- Make sure to
git add
themain.cpp
file. - Use
git status
to make sure you didn't miss anything. - Use
git commit
to save a version of your code including your changes. Write a short message describing your changes. - Use
git push
to sync your code history to the GitHub server.
- Make sure to
NOTE: This part cannot be done on the lab computers, as it requires administrative access. If you do not have a CUDA-capable computer of your own, you may need to borrow one for this part. However, you can still do the rest of your development on the lab computer.
- Go to the Nsight menu in Visual Studio.
- Select Start Performance Analysis....
- Select Trace Application. Under Trace Settings, enable tracing for CUDA and OpenGL.
- Under Application Control, click Launch.
- If you have switchable graphics (NVIDIA Optimus), see the note in Part 3.
- Run the program for a few seconds, then close it.
- At the top of the report page, select Timeline from the drop-down menu.
- Take a screenshot of this tab and save it to
images
, for Part 7.
- Open your project in Nsight.
- Run->Profile.
- Run the program for a few seconds, then close it.
- Take a screenshot of the timeline and save it to
images
, for Part 7.
NOTE: This part cannot be done on the lab computers, as it requires administrative access. If you do not have a CUDA-capable computer of your own, you may need to borrow one for this part. However, you can still do the rest of your development on the lab computer.
- Switch your build configuration to "Debug" and
Rebuild
the solution. - Select the Nsight menu in Visual Studio and select Start CUDA Debugging.
- When prompted, select the Connect Unsecurely option to start Nsight.
- Exit the app.
- Now place a breakpoint at Line 30 of
kernel.cu
=>if (x <= width && y <= height) {
- Restart the CUDA Debugging. This time, the breakpoint should be hit.
- The Autos and Locals debugging tabs should appear at the bottom. (You can also open this from Debug -> Windows -> Autos/Locals)
- Notice the values that are in the autos.
- The following steps should be done with Nsight CUDA Debugging running.
- Go to Nsight menu and select Next Active Warp. Now notice the values that have changed (hightlighted in red).
- Now, let's try to go to a particular index (pick your own number - anything greater than 1000).
- Right click the breakpoint and select conditions.
- The window that pops up should have defaults Conditional Expression and is true.
- In the third box, put it
index == <your number>
. - Click close.
- Now click Continue in the Visual Studio toolbar.
- The breakpoint should be hit one more time. This time, the Autos window will should
index
as your number. - Goto
Nsight
->Windows
->CUDA Info
->CUDA Info 1
.- This window shows information about the kernel, threads, blocks, warps, memory allocations etc. Choose from the drop downs to view each. Finally, select Warp and keep it that way.
- Take a screenshot of this Autos window and the CUDA Info -> Warp as a image and save it under
images
. - Play around with Nsight debugger as much as you want.
Unluckily, from CUDA GDB documentation, debugger doesn't work when your CUDA application and X11 GUI both run on the same GPU. Even if you have multiple GPUs, it doesn't make any sense since we run both glfw (requiring X11) and CUDA kernel code in our application, which means there's no way to isolate them to different GPUs.
However, there's a BETA feature available on Linux and supports devices with SM3.5 compute capability. If the compute capability of your graphics card is beyond SM3.5, you might be able to debug CUDA code by following the instruction.
- Update ALL of the TODOs at the top of this README:
- Finish your
README.md
- Add your name, computer, and whether it's a personal or lab computer.
- Embed the screenshots you took:
![](images/example.png)
- Syntax help: https://help.github.com/articles/writing-on-github/
- Finish your
- Add, commit, and push your screenshots and README.
- Make sure your README looks good on GitHub!
- If you have modified either of the
CMakeLists.txt
at all (aside from the list ofSOURCE_FILES
), mention it explicitly.
If you are using a private fork and do not want to make a public pull request, contact a TA to submit. You still must submit before the due date.
Open a GitHub pull request so that we can see that you have finished. The title should be "Project 0: YOUR NAME". The template of the comment section of your pull request is attached below, you can do some copy and paste:
- Repo Link
Your PENNKEY
- (Briefly) Mentions features that you've completed. Especially those bells and whistles you want to highlight
- Feature 0
- Feature 1
- ...
- Feedback on the project itself, if any.
And you're done!
- Due at midnight on the due date
- Submitted using GitHub
- Late Policy
- Up to 1 week late: 50% deduction
- Use up to 4 bonus days over the semester to extend the due date without penalty
- Examples
- Extend 4 projects by 1 day each
- OR: Extend 1 project by 4 days
- OR: Extend 2 projects by 2 days each
- Can't be used for the final project