1 //===--- AMDGPUMachineModuleInfo.cpp ----------------------------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
10 /// AMDGPU Machine Module Info.
13 //===----------------------------------------------------------------------===//
15 #include "AMDGPUMachineModuleInfo.h"
16 #include "llvm/IR/Module.h"
20 AMDGPUMachineModuleInfo::AMDGPUMachineModuleInfo(const MachineModuleInfo
&MMI
)
21 : MachineModuleInfoELF(MMI
) {
22 LLVMContext
&CTX
= MMI
.getModule()->getContext();
23 AgentSSID
= CTX
.getOrInsertSyncScopeID("agent");
24 WorkgroupSSID
= CTX
.getOrInsertSyncScopeID("workgroup");
25 WavefrontSSID
= CTX
.getOrInsertSyncScopeID("wavefront");
26 SystemOneAddressSpaceSSID
=
27 CTX
.getOrInsertSyncScopeID("one-as");
28 AgentOneAddressSpaceSSID
=
29 CTX
.getOrInsertSyncScopeID("agent-one-as");
30 WorkgroupOneAddressSpaceSSID
=
31 CTX
.getOrInsertSyncScopeID("workgroup-one-as");
32 WavefrontOneAddressSpaceSSID
=
33 CTX
.getOrInsertSyncScopeID("wavefront-one-as");
34 SingleThreadOneAddressSpaceSSID
=
35 CTX
.getOrInsertSyncScopeID("singlethread-one-as");
38 } // end namespace llvm