diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:41:05 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:41:05 +0000 | 
| commit | 01095a5d43bbfde13731688ddcf6048ebb8b7721 (patch) | |
| tree | 4def12e759965de927d963ac65840d663ef9d1ea /lib/CodeGen/AsmPrinter/DwarfExpression.h | |
| parent | f0f4822ed4b66e3579e92a89f368f8fb860e218e (diff) | |
Diffstat (limited to 'lib/CodeGen/AsmPrinter/DwarfExpression.h')
| -rw-r--r-- | lib/CodeGen/AsmPrinter/DwarfExpression.h | 46 | 
1 files changed, 31 insertions, 15 deletions
| diff --git a/lib/CodeGen/AsmPrinter/DwarfExpression.h b/lib/CodeGen/AsmPrinter/DwarfExpression.h index 78ec937a6b602..5fff28d8a13c3 100644 --- a/lib/CodeGen/AsmPrinter/DwarfExpression.h +++ b/lib/CodeGen/AsmPrinter/DwarfExpression.h @@ -31,13 +31,10 @@ class DIELoc;  class DwarfExpression {  protected:    // Various convenience accessors that extract things out of AsmPrinter. -  const TargetRegisterInfo &TRI;    unsigned DwarfVersion;  public: -  DwarfExpression(const TargetRegisterInfo &TRI, -                  unsigned DwarfVersion) -    : TRI(TRI), DwarfVersion(DwarfVersion) {} +  DwarfExpression(unsigned DwarfVersion) : DwarfVersion(DwarfVersion) {}    virtual ~DwarfExpression() {}    /// Output a dwarf operand and an optional assembler comment. @@ -48,7 +45,7 @@ public:    virtual void EmitUnsigned(uint64_t Value) = 0;    /// Return whether the given machine register is the frame register in the    /// current function. -  virtual bool isFrameRegister(unsigned MachineReg) = 0; +  virtual bool isFrameRegister(const TargetRegisterInfo &TRI, unsigned MachineReg) = 0;    /// Emit a dwarf register operation.    void AddReg(int DwarfReg, const char *Comment = nullptr); @@ -61,10 +58,24 @@ public:    void AddOpPiece(unsigned SizeInBits, unsigned OffsetInBits = 0);    /// Emit a shift-right dwarf expression.    void AddShr(unsigned ShiftBy); +  /// Emit a DW_OP_stack_value, if supported. +  /// +  /// The proper way to describe a constant value is +  /// DW_OP_constu <const>, DW_OP_stack_value. +  /// Unfortunately, DW_OP_stack_value was not available until DWARF-4, +  /// so we will continue to generate DW_OP_constu <const> for DWARF-2 +  /// and DWARF-3. Technically, this is incorrect since DW_OP_const <const> +  /// actually describes a value at a constant addess, not a constant value. +  /// However, in the past there was no better way  to describe a constant +  /// value, so the producers and consumers started to rely on heuristics +  /// to disambiguate the value vs. location status of the expression. +  /// See PR21176 for more details. +  void AddStackValue();    /// Emit an indirect dwarf register operation for the given machine register.    /// \return false if no DWARF register exists for MachineReg. -  bool AddMachineRegIndirect(unsigned MachineReg, int Offset = 0); +  bool AddMachineRegIndirect(const TargetRegisterInfo &TRI, unsigned MachineReg, +                             int Offset = 0);    /// \brief Emit a partial DWARF register operation.    /// \param MachineReg        the register @@ -80,20 +91,24 @@ public:    /// subregisters that alias the register.    ///    /// \return false if no DWARF register exists for MachineReg. -  bool AddMachineRegPiece(unsigned MachineReg, unsigned PieceSizeInBits = 0, +  bool AddMachineRegPiece(const TargetRegisterInfo &TRI, unsigned MachineReg, +                          unsigned PieceSizeInBits = 0,                            unsigned PieceOffsetInBits = 0);    /// Emit a signed constant. -  void AddSignedConstant(int Value); +  void AddSignedConstant(int64_t Value); +  /// Emit an unsigned constant. +  void AddUnsignedConstant(uint64_t Value);    /// Emit an unsigned constant. -  void AddUnsignedConstant(unsigned Value); +  void AddUnsignedConstant(const APInt &Value);    /// \brief Emit an entire expression on top of a machine register location.    ///    /// \param PieceOffsetInBits If this is one piece out of a fragmented    /// location, this is the offset of the piece inside the entire variable.    /// \return false if no DWARF register exists for MachineReg. -  bool AddMachineRegExpression(const DIExpression *Expr, unsigned MachineReg, +  bool AddMachineRegExpression(const TargetRegisterInfo &TRI, +                               const DIExpression *Expr, unsigned MachineReg,                                 unsigned PieceOffsetInBits = 0);    /// Emit a the operations remaining the DIExpressionIterator I.    /// \param PieceOffsetInBits If this is one piece out of a fragmented @@ -108,14 +123,14 @@ class DebugLocDwarfExpression : public DwarfExpression {    ByteStreamer &BS;  public: -  DebugLocDwarfExpression(const TargetRegisterInfo &TRI, -                          unsigned DwarfVersion, ByteStreamer &BS) -    : DwarfExpression(TRI, DwarfVersion), BS(BS) {} +  DebugLocDwarfExpression(unsigned DwarfVersion, ByteStreamer &BS) +      : DwarfExpression(DwarfVersion), BS(BS) {}    void EmitOp(uint8_t Op, const char *Comment = nullptr) override;    void EmitSigned(int64_t Value) override;    void EmitUnsigned(uint64_t Value) override; -  bool isFrameRegister(unsigned MachineReg) override; +  bool isFrameRegister(const TargetRegisterInfo &TRI, +                       unsigned MachineReg) override;  };  /// DwarfExpression implementation for singular DW_AT_location. @@ -129,7 +144,8 @@ public:    void EmitOp(uint8_t Op, const char *Comment = nullptr) override;    void EmitSigned(int64_t Value) override;    void EmitUnsigned(uint64_t Value) override; -  bool isFrameRegister(unsigned MachineReg) override; +  bool isFrameRegister(const TargetRegisterInfo &TRI, +                       unsigned MachineReg) override;  };  } | 
