Skip to content

Latest commit

Β 

History

History
485 lines (354 loc) Β· 16.7 KB

File metadata and controls

485 lines (354 loc) Β· 16.7 KB

How to Use This Book

Each puzzle maintains a consistent structure to support systematic skill development:

  • Overview: Problem definition and key concepts for each challenge
  • Configuration: Technical setup and memory organization details
  • Code to Complete: Implementation framework in problems/pXX/ with clearly marked sections to fill in
  • Tips: Strategic hints available when needed, without revealing complete solutions
  • Solution: Comprehensive implementation analysis, including performance considerations and conceptual explanations

The puzzles increase in complexity systematically, building new concepts on established foundations. Working through them sequentially is recommended, as advanced puzzles assume familiarity with concepts from earlier challenges.

Running the code

All puzzles integrate with a testing framework that validates implementations against expected results. Each puzzle provides specific execution instructions and solution verification procedures.

Prerequisites

System requirements

Make sure your system meets our system requirements.

Compatible GPU

You'll need a compatible GPU to run the puzzles. After setup, you can verify your GPU compatibility using the gpu-specs command (see Quick Start section below).

Operating System

Note

Here is some documentation how to setup GPU support in your OS for

Windows WSL2 for Linux with NVIDIA

To setup NVIVIA GPU support on Windows Subsystem for Linux (WSL2) e.g. Unbuntu please follow the NVIDIA CUDA on WLS Guide.

The important information is to install the NVIDIA Windows CUDA Driver for Windows because they fully support WSL2. Once a Windows NVIDIA GPU driver is installed on the system, CUDA becomes available within WSL 2. The CUDA driver installed on Windows host will be stubbed inside the WSL 2 as libcuda.so, therefore users must not install any NVIDIA GPU Linux driver within WSL 2.

Once you have installed the drivers please test the installation

Verify from Windows: Open PowerShell (not WSL)

nvidia-smi

Verify from inside WSL: (first start WLS e.g. via wsl -d Ubuntu)

ls -l /usr/lib/wsl/lib/nvidia-smi
/usr/lib/wsl/lib/nvidia-smi

Check setup from Pixi optionally install missing requirements e.g. for cuda-gdb debugging

pixi run nvidia-smi
pixi run setup-cuda-gdb
pixi run mojo debug --help
pixi run cuda-gdb --version

For WSL you can install VSCode as your Editor

Note

All puzzles 1-15 are working on WSL and Linux.

Linux native with NVIDIA

Check GPU + Ubuntu version (Supported Ubuntu LTS: 20.04, 22.04, 24.04)

lspci | grep -i nvidia
lsb_release -a

Install NVIDIA driver (mandatory)

sudo ubuntu-drivers devices
sudo ubuntu-drivers autoinstall
sudo reboot

For Linux you can install VSCode as your Editor

  • Install VS Code in Linux via VS Code APT repository

Import Microsoft GPG key

wget -qO- https://packages.microsoft.com/keys/microsoft.asc \
  | gpg --dearmor \
  | sudo tee /usr/share/keyrings/packages.microsoft.gpg > /dev/null

Add VS Code APT repository

echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] \
https://packages.microsoft.com/repos/code stable main" \
| sudo tee /etc/apt/sources.list.d/vscode.list

Install VS Code and verify installation

sudo apt update
sudo apt install code
code --version

Note

All puzzles 1-15 are working on Linux.

macOS Apple Silicon

For osx-arm64 users, you'll need:

  • macOS 15.0 or later for optimal compatibility. Run pixi run check-macos and if it fails you'd need to upgrade.
  • Xcode 16 or later (minimum required). Use xcodebuild -version to check.

If xcrun -sdk macosx metal outputs cannot execute tool 'metal' due to missing Metal toolchain proceed by running

xcodebuild -downloadComponent MetalToolchain

and then xcrun -sdk macosx metal, should give you the no input files error.

Note

Currently the puzzles 1-8 and 11-15 are working on macOS. We're working to enable more. Please stay tuned!

Programming knowledge

Basic knowledge of:

  • Programming fundamentals (variables, loops, conditionals, functions)
  • Parallel computing concepts (threads, synchronization, race conditions)
  • Basic familiarity with Mojo (language basics parts and intro to pointers section)
  • GPU programming fundamentals is helpful!

No prior GPU programming experience is necessary! We'll build that knowledge through the puzzles.

Let's begin our journey into the exciting world of GPU computing with MojoπŸ”₯!

Setting up your environment

  1. Clone the GitHub repository and navigate to the repository:

    # Clone the repository
    git clone https://github.com/modular/mojo-gpu-puzzles
    cd mojo-gpu-puzzles
  2. Install a package manager to run the MojoπŸ”₯ programs:

    Option 1 (Highly recommended): pixi

    pixi is the recommended option for this project because:

    • Easy access to Modular's MAX/Mojo packages
    • Handles GPU dependencies
    • Full conda + PyPI ecosystem support

    Note: Some puzzles only work with pixi

    Install:

    curl -fsSL https://pixi.sh/install.sh | sh

    Update:

    pixi self-update

    Option 2: uv

    Install:

    curl -fsSL https://astral.sh/uv/install.sh | sh

    Update:

    uv self update

    Create a virtual environment:

    uv venv && source .venv/bin/activate
  3. Verify setup and run your first puzzle:

pixi NVIDIA (default) pixi AMD pixi Apple uv
# Check your GPU specifications
pixi run gpu-specs

# Run your first puzzle
# This fails waiting for your implementation! follow the content
pixi run p01
# Check your GPU specifications
pixi run gpu-specs

# Run your first puzzle
# This fails waiting for your implementation! follow the content
pixi run -e amd p01
# Check your GPU specifications
pixi run gpu-specs

# Run your first puzzle
# This fails waiting for your implementation! follow the content
pixi run -e apple p01
# Install GPU-specific dependencies
uv pip install -e ".[nvidia]"  # For NVIDIA GPUs
# OR
uv pip install -e ".[amd]"     # For AMD GPUs

# Check your GPU specifications
uv run poe gpu-specs

# Run your first puzzle
# This fails waiting for your implementation! follow the content
uv run poe p01

Working with puzzles

Project structure

  • problems/: Where you implement your solutions (this is where you work!)
  • solutions/: Reference solutions for comparison and learning that we use throughout the book

Workflow

  1. Navigate to problems/pXX/ to find the puzzle template
  2. Implement your solution in the provided framework
  3. Test your implementation: pixi run pXX or uv run poe pXX (remember to include your platform with -e platform such as -e amd)
  4. Compare with solutions/pXX/ to learn different approaches

Essential commands

pixi uv
# Run puzzles (remember to include your platform with -e if needed)
pixi run pXX             # NVIDIA (default) same as `pixi run -e nvidia pXX`
pixi run -e amd pXX      # AMD GPU
pixi run -e apple pXX    # Apple GPU

# Test solutions
pixi run tests           # Test all solutions
pixi run tests pXX       # Test specific puzzle

# Run manually
pixi run mojo problems/pXX/pXX.mojo     # Your implementation
pixi run mojo solutions/pXX/pXX.mojo    # Reference solution

# Interactive shell
pixi shell               # Enter environment
mojo problems/p01/p01.mojo              # Direct execution
exit                     # Leave shell

# Development
pixi run format         # Format code
pixi task list          # Available commands
# Note: uv is limited and some chapters require pixi
# Install GPU-specific dependencies:
uv pip install -e ".[nvidia]"  # For NVIDIA GPUs
uv pip install -e ".[amd]"     # For AMD GPUs

# Test solutions
uv run poe tests        # Test all solutions
uv run poe tests pXX    # Test specific puzzle

# Run manually
uv run mojo problems/pXX/pXX.mojo      # Your implementation
uv run mojo solutions/pXX/pXX.mojo     # Reference solution

GPU support matrix

The following table shows GPU platform compatibility for each puzzle. Different puzzles require different GPU features and vendor-specific tools.

Puzzle NVIDIA GPU AMD GPU Apple GPU Notes
Part I: GPU Fundamentals
1 - Map βœ… βœ… βœ… Basic GPU kernels
2 - Zip βœ… βœ… βœ… Basic GPU kernels
3 - Guard βœ… βœ… βœ… Basic GPU kernels
4 - Map 2D βœ… βœ… βœ… Basic GPU kernels
5 - Broadcast βœ… βœ… βœ… Basic GPU kernels
6 - Blocks βœ… βœ… βœ… Basic GPU kernels
7 - Shared Memory βœ… βœ… βœ… Basic GPU kernels
8 - Stencil βœ… βœ… βœ… Basic GPU kernels
Part II: Debugging
9 - GPU Debugger βœ… ❌ ❌ NVIDIA-specific debugging tools
10 - Sanitizer βœ… ❌ ❌ NVIDIA-specific debugging tools
Part III: GPU Algorithms
11 - Reduction βœ… βœ… βœ… Basic GPU kernels
12 - Scan βœ… βœ… βœ… Basic GPU kernels
13 - Pool βœ… βœ… βœ… Basic GPU kernels
14 - Conv βœ… βœ… βœ… Basic GPU kernels
15 - Matmul βœ… βœ… βœ… Basic GPU kernels
16 - Flashdot βœ… βœ… βœ… Advanced memory patterns
Part IV: MAX Graph
17 - Custom Op βœ… βœ… βœ… MAX Graph integration
18 - Softmax βœ… βœ… βœ… MAX Graph integration
19 - Attention βœ… βœ… βœ… MAX Graph integration
Part V: PyTorch Integration
20 - Torch Bridge βœ… βœ… ❌ PyTorch integration
21 - Autograd βœ… βœ… ❌ PyTorch integration
22 - Fusion βœ… βœ… ❌ PyTorch integration
Part VI: Functional Patterns
23 - Functional βœ… βœ… βœ… Advanced Mojo patterns
Part VII: Warp Programming
24 - Warp Sum βœ… βœ… βœ… Warp-level operations
25 - Warp Communication βœ… βœ… βœ… Warp-level operations
26 - Advanced Warp βœ… βœ… βœ… Warp-level operations
Part VIII: Block Programming
27 - Block Operations βœ… βœ… βœ… Block-level patterns
Part IX: Memory Systems
28 - Async Memory βœ… βœ… βœ… Advanced memory operations
29 - Barriers βœ… ❌ ❌ Advanced NVIDIA-only synchronization
Part X: Performance Analysis
30 - Profiling βœ… ❌ ❌ NVIDIA profiling tools (NSight)
31 - Occupancy βœ… ❌ ❌ NVIDIA profiling tools
32 - Bank Conflicts βœ… ❌ ❌ NVIDIA profiling tools
Part XI: Modern GPU Features
33 - Tensor Cores βœ… ❌ ❌ NVIDIA Tensor Core specific
34 - Cluster βœ… ❌ ❌ NVIDIA cluster programming

Legend

  • βœ… Supported: Puzzle works on this platform
  • ❌ Not Supported: Puzzle requires platform-specific features

Platform notes

NVIDIA GPUs (Complete Support)

  • All puzzles (1-34) work on NVIDIA GPUs with CUDA support
  • Requires CUDA toolkit and compatible drivers
  • Best learning experience with access to all features

AMD GPUs (Extensive Support)

  • Most puzzles (1-8, 11-29) work with ROCm support
  • Missing only: Debugging tools (9-10), profiling (30-32), Tensor Cores (33-34)
  • Excellent for learning GPU programming including advanced algorithms and memory patterns

Apple GPUs (Basic Support)

  • A selection of fundamental (1-8, 11-18) and advanced (23-27) puzzles are supported
  • Missing: All advanced features, debugging, profiling tools
  • Suitable for learning basic GPU programming patterns

Future Support: We're actively working to expand tooling and platform support for AMD and Apple GPUs. Missing features like debugging tools, profiling capabilities, and advanced GPU operations are planned for future releases. Check back for updates as we continue to broaden cross-platform compatibility.

GPU Resources

Free cloud GPU platforms

If you don't have local GPU access, several cloud platforms offer free GPU resources for learning and experimentation:

Google Colab

Google Colab provides free GPU access with some limitations for Mojo GPU programming:

Available GPUs:

  • Tesla T4 (older Turing architecture)
  • Tesla V100 (limited availability)

Limitations for Mojo GPU Puzzles:

  • Older GPU architecture: T4 GPUs may have limited compatibility with advanced Mojo GPU features
  • Session limits: 12-hour maximum runtime, then automatic disconnect
  • Limited debugging support: NVIDIA debugging tools (puzzles 9-10) may not be fully available
  • Package installation restrictions: May require workarounds for Mojo/MAX installation
  • Performance limitations: Shared infrastructure affects consistent benchmarking

Recommended for: Basic GPU programming concepts (puzzles 1-8, 11-15) and learning fundamental patterns.

Kaggle Notebooks

Kaggle offers more generous free GPU access:

Available GPUs:

  • Tesla T4 (30 hours per week free)
  • P100 (limited availability)

Advantages over Colab:

  • More generous time limits: 30 hours per week compared to Colab's daily session limits
  • Better persistence: Notebooks save automatically
  • Consistent environment: More reliable package installation

Limitations for Mojo GPU Puzzles:

  • Same GPU architecture constraints: T4 compatibility issues with advanced features
  • Limited debugging tools: NVIDIA profiling and debugging tools (puzzles 9-10, 30-32) unavailable
  • Mojo installation complexity: Requires manual setup of Mojo environment
  • No cluster programming support: Advanced puzzles (33-34) won't work

Recommended for: Extended learning sessions on fundamental GPU programming (puzzles 1-16).

Recommendations

  • Complete Learning Path: Use NVIDIA GPU for full curriculum access (all 34 puzzles)
  • Comprehensive Learning: AMD GPUs work well for most content (27 of 34 puzzles)
  • Basic Understanding: Apple GPUs suitable for fundamental concepts (13 of 34 puzzles)
  • Free Platform Learning: Google Colab/Kaggle suitable for basic to intermediate concepts (puzzles 1-16)
  • Debugging & Profiling: NVIDIA GPU required for debugging tools and performance analysis
  • Modern GPU Features: NVIDIA GPU required for Tensor Cores and cluster programming

Development

Please see details in the README.

Join the community

Subscribe for Updates Modular Forum Discord

Join our vibrant community to discuss GPU programming, share solutions, and get help!