1 //===--- AMDGPUMachineModuleInfo.cpp ----------------------------*- 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 /// \file
10 /// AMDGPU Machine Module Info.
11 ///
12 //
13 //===----------------------------------------------------------------------===//
14 
15 #include "AMDGPUMachineModuleInfo.h"
16 #include "llvm/IR/Module.h"
17 
18 namespace llvm {
19 
AMDGPUMachineModuleInfo(const MachineModuleInfo & MMI)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");
36 }
37 
38 } // end namespace llvm
39