[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / lib / Target / WebAssembly / WebAssemblyAsmPrinter.h
blob4e55c81dec38a78375334f3149230beef095dcda
1 // WebAssemblyAsmPrinter.h - WebAssembly implementation of AsmPrinter-*- 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 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_LIB_TARGET_WEBASSEMBLY_WEBASSEMBLYASMPRINTER_H
10 #define LLVM_LIB_TARGET_WEBASSEMBLY_WEBASSEMBLYASMPRINTER_H
12 #include "WebAssemblyMachineFunctionInfo.h"
13 #include "WebAssemblySubtarget.h"
14 #include "llvm/CodeGen/AsmPrinter.h"
15 #include "llvm/MC/MCStreamer.h"
16 #include "llvm/Target/TargetMachine.h"
18 namespace llvm {
19 class MCSymbol;
20 class WebAssemblyTargetStreamer;
21 class WebAssemblyMCInstLower;
23 class LLVM_LIBRARY_VISIBILITY WebAssemblyAsmPrinter final : public AsmPrinter {
24 const WebAssemblySubtarget *Subtarget;
25 const MachineRegisterInfo *MRI;
26 WebAssemblyFunctionInfo *MFI;
27 // TODO: Do the uniquing of Signatures here instead of ObjectFileWriter?
28 std::vector<std::unique_ptr<wasm::WasmSignature>> Signatures;
30 public:
31 explicit WebAssemblyAsmPrinter(TargetMachine &TM,
32 std::unique_ptr<MCStreamer> Streamer)
33 : AsmPrinter(TM, std::move(Streamer)), Subtarget(nullptr), MRI(nullptr),
34 MFI(nullptr) {}
36 StringRef getPassName() const override {
37 return "WebAssembly Assembly Printer";
40 const WebAssemblySubtarget &getSubtarget() const { return *Subtarget; }
41 void addSignature(std::unique_ptr<wasm::WasmSignature> &&Sig) {
42 Signatures.push_back(std::move(Sig));
45 //===------------------------------------------------------------------===//
46 // MachineFunctionPass Implementation.
47 //===------------------------------------------------------------------===//
49 bool runOnMachineFunction(MachineFunction &MF) override {
50 Subtarget = &MF.getSubtarget<WebAssemblySubtarget>();
51 MRI = &MF.getRegInfo();
52 MFI = MF.getInfo<WebAssemblyFunctionInfo>();
53 return AsmPrinter::runOnMachineFunction(MF);
56 //===------------------------------------------------------------------===//
57 // AsmPrinter Implementation.
58 //===------------------------------------------------------------------===//
60 void EmitEndOfAsmFile(Module &M) override;
61 void EmitProducerInfo(Module &M);
62 void EmitTargetFeatures(Module &M);
63 void EmitJumpTableInfo() override;
64 void EmitConstantPool() override;
65 void EmitFunctionBodyStart() override;
66 void EmitInstruction(const MachineInstr *MI) override;
67 bool PrintAsmOperand(const MachineInstr *MI, unsigned OpNo,
68 const char *ExtraCode, raw_ostream &OS) override;
69 bool PrintAsmMemoryOperand(const MachineInstr *MI, unsigned OpNo,
70 const char *ExtraCode, raw_ostream &OS) override;
72 MVT getRegType(unsigned RegNo) const;
73 std::string regToString(const MachineOperand &MO);
74 WebAssemblyTargetStreamer *getTargetStreamer();
77 } // end namespace llvm
79 #endif