LLVM 23.0.0git
AMDGPULaneMaskUtils.h
Go to the documentation of this file.
1//===- AMDGPULaneMaskUtils.h - Exec/lane mask helper functions -*- 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#ifndef LLVM_LIB_TARGET_AMDGPU_UTILS_AMDGPULANEMASKUTILS_H
10#define LLVM_LIB_TARGET_AMDGPU_UTILS_AMDGPULANEMASKUTILS_H
11
12#include "GCNSubtarget.h"
14
15namespace llvm {
16
17class GCNSubtarget;
18
19namespace AMDGPU {
20
22public:
25 const unsigned AndOpc;
26 const unsigned AndTermOpc;
27 const unsigned AndN2Opc;
28 const unsigned AndN2SaveExecOpc;
29 const unsigned AndN2TermOpc;
30 const unsigned AndN2WrExecOpc; // GFX10+ (HasNoSdstCMPX) only
31 const unsigned AndSaveExecOpc;
32 const unsigned AndSaveExecTermOpc;
33 const unsigned BfmOpc;
34 const unsigned CMovOpc;
35 const unsigned CSelectOpc;
36 const unsigned MovOpc;
37 const unsigned MovTermOpc;
38 const unsigned OrOpc;
39 const unsigned OrN2Opc;
40 const unsigned OrTermOpc;
41 const unsigned OrSaveExecOpc;
42 const unsigned XorOpc;
43 const unsigned XorTermOpc;
44 const unsigned WQMOpc;
45
46 constexpr LaneMaskConstants(bool IsWave32)
47 : ExecReg(IsWave32 ? AMDGPU::EXEC_LO : AMDGPU::EXEC),
48 VccReg(IsWave32 ? AMDGPU::VCC_LO : AMDGPU::VCC),
49 AndOpc(IsWave32 ? AMDGPU::S_AND_B32 : AMDGPU::S_AND_B64),
50 AndTermOpc(IsWave32 ? AMDGPU::S_AND_B32_term : AMDGPU::S_AND_B64_term),
51 AndN2Opc(IsWave32 ? AMDGPU::S_ANDN2_B32 : AMDGPU::S_ANDN2_B64),
52 AndN2SaveExecOpc(IsWave32 ? AMDGPU::S_ANDN2_SAVEEXEC_B32
53 : AMDGPU::S_ANDN2_SAVEEXEC_B64),
54 AndN2TermOpc(IsWave32 ? AMDGPU::S_ANDN2_B32_term
55 : AMDGPU::S_ANDN2_B64_term),
56 AndN2WrExecOpc(IsWave32 ? AMDGPU::S_ANDN2_WREXEC_B32
57 : AMDGPU::S_ANDN2_WREXEC_B64),
58 AndSaveExecOpc(IsWave32 ? AMDGPU::S_AND_SAVEEXEC_B32
59 : AMDGPU::S_AND_SAVEEXEC_B64),
60 AndSaveExecTermOpc(IsWave32 ? AMDGPU::S_AND_SAVEEXEC_B32_term
61 : AMDGPU::S_AND_SAVEEXEC_B64_term),
62 BfmOpc(IsWave32 ? AMDGPU::S_BFM_B32 : AMDGPU::S_BFM_B64),
63 CMovOpc(IsWave32 ? AMDGPU::S_CMOV_B32 : AMDGPU::S_CMOV_B64),
64 CSelectOpc(IsWave32 ? AMDGPU::S_CSELECT_B32 : AMDGPU::S_CSELECT_B64),
65 MovOpc(IsWave32 ? AMDGPU::S_MOV_B32 : AMDGPU::S_MOV_B64),
66 MovTermOpc(IsWave32 ? AMDGPU::S_MOV_B32_term : AMDGPU::S_MOV_B64_term),
67 OrOpc(IsWave32 ? AMDGPU::S_OR_B32 : AMDGPU::S_OR_B64),
68 OrN2Opc(IsWave32 ? AMDGPU::S_ORN2_B32 : AMDGPU::S_ORN2_B64),
69 OrTermOpc(IsWave32 ? AMDGPU::S_OR_B32_term : AMDGPU::S_OR_B64_term),
70 OrSaveExecOpc(IsWave32 ? AMDGPU::S_OR_SAVEEXEC_B32
71 : AMDGPU::S_OR_SAVEEXEC_B64),
72 XorOpc(IsWave32 ? AMDGPU::S_XOR_B32 : AMDGPU::S_XOR_B64),
73 XorTermOpc(IsWave32 ? AMDGPU::S_XOR_B32_term : AMDGPU::S_XOR_B64_term),
74 WQMOpc(IsWave32 ? AMDGPU::S_WQM_B32 : AMDGPU::S_WQM_B64) {}
75
76 static inline const LaneMaskConstants &get(const GCNSubtarget &ST);
77};
78
80 LaneMaskConstants(/*IsWave32=*/true);
82 LaneMaskConstants(/*IsWave32=*/false);
83
85 unsigned WavefrontSize = ST.getWavefrontSize();
86 assert(WavefrontSize == 32 || WavefrontSize == 64);
87 return WavefrontSize == 32 ? LaneMaskConstants32 : LaneMaskConstants64;
88}
89
90} // end namespace AMDGPU
91
92} // end namespace llvm
93
94#endif // LLVM_LIB_TARGET_AMDGPU_UTILS_AMDGPULANEMASKUTILS_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMD GCN specific subclass of TargetSubtarget.
constexpr LaneMaskConstants(bool IsWave32)
static const LaneMaskConstants & get(const GCNSubtarget &ST)
Wrapper class representing virtual and physical registers.
Definition Register.h:20
static constexpr LaneMaskConstants LaneMaskConstants32
static constexpr LaneMaskConstants LaneMaskConstants64
This is an optimization pass for GlobalISel generic memory operations.