Skip to content

Latest commit

 

History

History
76 lines (59 loc) · 3.94 KB

dependent_kernel_launch.md

File metadata and controls

76 lines (59 loc) · 3.94 KB

README > Dependent kernel launch

Dependent kernel launches

The Hopper and Blackwell architectures supports a new feature through which two kernels in the same stream can overlap their execution, named Programmatic Dependent Launch (PDL). This allows kernels with conflict in global memory to programmatically and safely overlap portions of their execution. Primary kernel can signal it is about to finish execution, and the next kernel is expected to programatically wait on the previous kernel to finish flushing its memory.

We enable PDL by setting a flag through the extended CUDA launch APIs. All CUTLASS kernels with PDL support will wait on the prior kernel to flush its output to memory and signal the next kernel to start. This means they can safely be dropped in with any other set of kernels using PDL as long as they also adhear to waiting on the prior to flush its memory as well.

For more information, we refer you to the PDL section in the CUDA Programming Guide.

Using dependent launch in CUTLASS

When building CUTLASS, you can use the CUTLASS_ENABLE_GDC_FOR_SM90 and CUTLASS_ENABLE_GDC_FOR_SM100 macro respectively to enable PDL-related instructions:

cmake . -DCUTLASS_ENABLE_GDC_FOR_SM90=1

Note that this only adds PDL-related instructions to the kernels, but to actually allow a dependent launch, you must also run your GEMM kernel with PDL:

gemm.run(
  /* stream = */ stream,
  /* cuda_adapter = */ nullptr,
  /* launch_with_pdl = */ true
);_

Model-Aware Optimizations with PDL

In example 63, we use PDL to explicitly optimize for performance of kernels where we know that one of the input matricies (our weights) will not be produced by a prior kernel. In that case, we only need to wait on the prior kernels memory flush in order to load the other input matrix (our activations). During our prologue, we can prefetch our weights to improve performance for memory bandwidth-bound problem sizes. For more informations we refer the reader to the example.

Copyright

Copyright (c) 2017 - 2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved. SPDX-License-Identifier: BSD-3-Clause

  Redistribution and use in source and binary forms, with or without
  modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this
  list of conditions and the following disclaimer.

  2. Redistributions in binary form must reproduce the above copyright notice,
  this list of conditions and the following disclaimer in the documentation
  and/or other materials provided with the distribution.

  3. Neither the name of the copyright holder nor the names of its
  contributors may be used to endorse or promote products derived from
  this software without specific prior written permission.

  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.