1//===- AMDGPUMIRFormatter.cpp ---------------------------------------------===//
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/// Implementation of AMDGPU overrides of MIRFormatter.
11//
12//===----------------------------------------------------------------------===//
13
14#include "AMDGPUMIRFormatter.h"
15#include "GCNSubtarget.h"
16#include "SIMachineFunctionInfo.h"
17
18using namespace llvm;
19
20bool AMDGPUMIRFormatter::parseCustomPseudoSourceValue(
21 StringRef Src, MachineFunction &MF, PerFunctionMIParsingState &PFS,
22 const PseudoSourceValue *&PSV, ErrorCallbackType ErrorCallback) const {
23 SIMachineFunctionInfo *MFI = MF.getInfo<SIMachineFunctionInfo>();
24 const AMDGPUTargetMachine &TM =
25 static_cast<const AMDGPUTargetMachine &>(MF.getTarget());
26 if (Src == "GWSResource") {
27 PSV = MFI->getGWSPSV(TM);
28 return false;
29 }
30 llvm_unreachable("unknown MIR custom pseudo source value");
31}
32

source code of llvm/lib/Target/AMDGPU/AMDGPUMIRFormatter.cpp