1 //===-- llvm/Target/AMDGPU/AMDGPUMIRFormatter.h -----------------*- C++ -*-===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 6 // See https://llvm.org/LICENSE.txt for license information. 7 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 8 // 9 //===----------------------------------------------------------------------===// 10 // 11 /// \file 12 /// AMDGPU specific overrides of MIRFormatter. 13 // 14 //===----------------------------------------------------------------------===// 15 16 #ifndef LLVM_LIB_TARGET_AMDGPUMIRFORMATTER_H 17 #define LLVM_LIB_TARGET_AMDGPUMIRFORMATTER_H 18 19 #include "llvm/CodeGen/MIRFormatter.h" 20 21 namespace llvm { 22 23 class MachineFunction; 24 struct PerFunctionMIParsingState; 25 26 class AMDGPUMIRFormatter final : public MIRFormatter { 27 public: 28 AMDGPUMIRFormatter() {} 29 virtual ~AMDGPUMIRFormatter() = default; 30 31 /// Implement target specific parsing of target custom pseudo source value. 32 virtual bool 33 parseCustomPseudoSourceValue(StringRef Src, MachineFunction &MF, 34 PerFunctionMIParsingState &PFS, 35 const PseudoSourceValue *&PSV, 36 ErrorCallbackType ErrorCallback) const override; 37 }; 38 39 } // end namespace llvm 40 41 #endif 42