Nearly CC
An educational compiler skeleton
peephole_ll.h
1 // Copyright (c) 2021-2023, David H. Hovemeyer <david.hovemeyer@gmail.com>
2 //
3 // Permission is hereby granted, free of charge, to any person obtaining a
4 // copy of this software and associated documentation files (the "Software"),
5 // to deal in the Software without restriction, including without limitation
6 // the rights to use, copy, modify, merge, publish, distribute, sublicense,
7 // and/or sell copies of the Software, and to permit persons to whom the
8 // Software is furnished to do so, subject to the following conditions:
9 //
10 // The above copyright notice and this permission notice shall be included
11 // in all copies or substantial portions of the Software.
12 //
13 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
16 // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
17 // OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
18 // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
19 // OTHER DEALINGS IN THE SOFTWARE.
20 
21 #ifndef PEEPHOLE_LL_H
22 #define PEEPHOLE_LL_H
23 
24 #include <deque>
25 #include <vector>
26 #include "live_mregs.h"
27 #include "cfg_transform.h"
28 
30 private:
31  // liveness info about machine registers
32  LiveMregs m_live_mregs;
33 
34  // window of instructions from the original InstructionSequence
35  std::deque<Instruction *> m_window;
36 
37  // number of patterns matched/transformations applied
38  int m_num_matched;
39 
40 public:
41  PeepholeLowLevel(const std::shared_ptr<ControlFlowGraph> &cfg);
42  virtual ~PeepholeLowLevel();
43 
44  virtual std::shared_ptr<InstructionSequence> transform_basic_block(std::shared_ptr<InstructionSequence> orig_bb);
45 
46  int get_num_matched() const { return m_num_matched; }
47 
48 private:
49  void emit_earliest_in_window(InstructionSequence *result_iseq);
50 };
51 
52 #endif // PEEPHOLE_LL_H
Base class for ControlFlowGraphTransform transformations.
Definition: cfg_transform.h:32
InstructionSequence class, which represents a linear sequence of Instruction objects.
Definition: instruction_seq.h:50
Definition: peephole_ll.h:29
virtual std::shared_ptr< InstructionSequence > transform_basic_block(std::shared_ptr< InstructionSequence > orig_bb)
Create a transformed version of the instructions in a basic block.
Definition: peephole_ll.cpp:1373
Dataflow analysis to determine which machine registers contain live values.