MLIR 22.0.0git
MemoryPromotion.h
Go to the documentation of this file.
1//===- MemoryPromotion.h - Utilities for moving data across GPU -*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This header file declares the utility functions that generate IR copying
10// the data between different levels of memory hierarchy.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef MLIR_DIALECT_GPU_TRANSFORMS_MEMORYPROMOTION_H
15#define MLIR_DIALECT_GPU_TRANSFORMS_MEMORYPROMOTION_H
16
17namespace mlir {
18
19namespace gpu {
20class GPUFuncOp;
21} // namespace gpu
22
23/// Promotes a function argument to workgroup memory in the given function. The
24/// copies will be inserted in the beginning and in the end of the function.
25void promoteToWorkgroupMemory(gpu::GPUFuncOp op, unsigned arg);
26
27} // namespace mlir
28
29#endif // MLIR_DIALECT_GPU_TRANSFORMS_MEMORYPROMOTION_H
Include the generated interface declarations.
void promoteToWorkgroupMemory(gpu::GPUFuncOp op, unsigned arg)
Promotes a function argument to workgroup memory in the given function.