LLVM 20.0.0git
LowerAtomic.h
Go to the documentation of this file.
1//===- LowerAtomic.h - Lower atomic intrinsics ------------------*- 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/// \file
9// This pass lowers atomic intrinsics to non-atomic form for use in a known
10// non-preemptible environment.
11///
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_TRANSFORMS_UTILS_LOWERATOMIC_H
15#define LLVM_TRANSFORMS_UTILS_LOWERATOMIC_H
16
18
19namespace llvm {
20
21class IRBuilderBase;
22
23/// Convert the given Cmpxchg into primitive load and compare.
24bool lowerAtomicCmpXchgInst(AtomicCmpXchgInst *CXI);
25
26/// Emit IR to implement the given cmpxchg operation on values in registers,
27/// returning the new value.
28std::pair<Value *, Value *> buildCmpXchgValue(IRBuilderBase &Builder,
29 Value *Ptr, Value *Cmp,
30 Value *Val, Align Alignment);
31
32/// Convert the given RMWI into primitive load and stores,
33/// assuming that doing so is legal. Return true if the lowering
34/// succeeds.
35bool lowerAtomicRMWInst(AtomicRMWInst *RMWI);
36
37/// Emit IR to implement the given atomicrmw operation on values in registers,
38/// returning the new value.
39Value *buildAtomicRMWValue(AtomicRMWInst::BinOp Op, IRBuilderBase &Builder,
40 Value *Loaded, Value *Val);
41}
42
43#endif // LLVM_TRANSFORMS_UTILS_LOWERATOMIC_H
uint64_t Align
BinOp
This enumeration lists the possible modifications atomicrmw can make.
Definition: Instructions.h:716
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
std::pair< Value *, Value * > buildCmpXchgValue(IRBuilderBase &Builder, Value *Ptr, Value *Cmp, Value *Val, Align Alignment)
Emit IR to implement the given cmpxchg operation on values in registers, returning the new value.
Definition: LowerAtomic.cpp:40
Value * buildAtomicRMWValue(AtomicRMWInst::BinOp Op, IRBuilderBase &Builder, Value *Loaded, Value *Val)
Emit IR to implement the given atomicrmw operation on values in registers, returning the new value.
Definition: LowerAtomic.cpp:52
DWARFExpression::Operation Op
bool lowerAtomicCmpXchgInst(AtomicCmpXchgInst *CXI)
Convert the given Cmpxchg into primitive load and compare.
Definition: LowerAtomic.cpp:22
bool lowerAtomicRMWInst(AtomicRMWInst *RMWI)
Convert the given RMWI into primitive load and stores, assuming that doing so is legal.