| OLD | NEW | 
|---|
| 1 // Copyright 2014 The Crashpad Authors. All rights reserved. | 1 // Copyright 2014 The Crashpad Authors. All rights reserved. | 
| 2 // | 2 // | 
| 3 // Licensed under the Apache License, Version 2.0 (the "License"); | 3 // Licensed under the Apache License, Version 2.0 (the "License"); | 
| 4 // you may not use this file except in compliance with the License. | 4 // you may not use this file except in compliance with the License. | 
| 5 // You may obtain a copy of the License at | 5 // You may obtain a copy of the License at | 
| 6 // | 6 // | 
| 7 //     http://www.apache.org/licenses/LICENSE-2.0 | 7 //     http://www.apache.org/licenses/LICENSE-2.0 | 
| 8 // | 8 // | 
| 9 // Unless required by applicable law or agreed to in writing, software | 9 // Unless required by applicable law or agreed to in writing, software | 
| 10 // distributed under the License is distributed on an "AS IS" BASIS, | 10 // distributed under the License is distributed on an "AS IS" BASIS, | 
| 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
| 12 // See the License for the specific language governing permissions and | 12 // See the License for the specific language governing permissions and | 
| 13 // limitations under the License. | 13 // limitations under the License. | 
| 14 | 14 | 
| 15 #ifndef CRASHPAD_MINIDUMP_MINIDUMP_CONTEXT_WRITER_H_ | 15 #ifndef CRASHPAD_MINIDUMP_MINIDUMP_CONTEXT_WRITER_H_ | 
| 16 #define CRASHPAD_MINIDUMP_MINIDUMP_CONTEXT_WRITER_H_ | 16 #define CRASHPAD_MINIDUMP_MINIDUMP_CONTEXT_WRITER_H_ | 
| 17 | 17 | 
| 18 #include <sys/types.h> | 18 #include <sys/types.h> | 
| 19 | 19 | 
| 20 #include "base/basictypes.h" | 20 #include "base/basictypes.h" | 
|  | 21 #include "base/memory/scoped_ptr.h" | 
| 21 #include "minidump/minidump_context.h" | 22 #include "minidump/minidump_context.h" | 
| 22 #include "minidump/minidump_writable.h" | 23 #include "minidump/minidump_writable.h" | 
| 23 | 24 | 
| 24 namespace crashpad { | 25 namespace crashpad { | 
| 25 | 26 | 
|  | 27 struct CPUContext; | 
|  | 28 struct CPUContextX86; | 
|  | 29 struct CPUContextX86_64; | 
|  | 30 | 
| 26 //! \brief The base class for writers of CPU context structures in minidump | 31 //! \brief The base class for writers of CPU context structures in minidump | 
| 27 //!     files. | 32 //!     files. | 
| 28 class MinidumpContextWriter : public internal::MinidumpWritable { | 33 class MinidumpContextWriter : public internal::MinidumpWritable { | 
| 29  public: | 34  public: | 
| 30   ~MinidumpContextWriter() override; | 35   ~MinidumpContextWriter() override; | 
| 31 | 36 | 
|  | 37   //! \brief Creates a MinidumpContextWriter based on \a context_snapshot. | 
|  | 38   //! | 
|  | 39   //! \param[in] context_snapshot The context snapshot to use as source data. | 
|  | 40   //! | 
|  | 41   //! \return A MinidumpContextWriter subclass, such as MinidumpContextWriterX86 | 
|  | 42   //!     or MinidumpContextWriterAMD64, appropriate to the CPU type of \a | 
|  | 43   //!     context_snapshot. The returned object is initialized using the source | 
|  | 44   //!     data in \a context_snapshot. If \a context_snapshot is an unknown CPU | 
|  | 45   //!     type’s context, logs a message and returns `nullptr`. | 
|  | 46   static scoped_ptr<MinidumpContextWriter> CreateFromSnapshot( | 
|  | 47       const CPUContext* context_snapshot); | 
|  | 48 | 
| 32  protected: | 49  protected: | 
| 33   MinidumpContextWriter() : MinidumpWritable() {} | 50   MinidumpContextWriter() : MinidumpWritable() {} | 
| 34 | 51 | 
| 35   //! \brief Returns the size of the context structure that this object will | 52   //! \brief Returns the size of the context structure that this object will | 
| 36   //!     write. | 53   //!     write. | 
| 37   //! | 54   //! | 
| 38   //! \note This method will only be called in #kStateFrozen or a subsequent | 55   //! \note This method will only be called in #kStateFrozen or a subsequent | 
| 39   //!     state. | 56   //!     state. | 
| 40   virtual size_t ContextSize() const = 0; | 57   virtual size_t ContextSize() const = 0; | 
| 41 | 58 | 
| 42   // MinidumpWritable: | 59   // MinidumpWritable: | 
| 43   size_t SizeOfObject() final; | 60   size_t SizeOfObject() final; | 
| 44 | 61 | 
| 45  private: | 62  private: | 
| 46   DISALLOW_COPY_AND_ASSIGN(MinidumpContextWriter); | 63   DISALLOW_COPY_AND_ASSIGN(MinidumpContextWriter); | 
| 47 }; | 64 }; | 
| 48 | 65 | 
| 49 //! \brief The writer for a MinidumpContextX86 structure in a minidump file. | 66 //! \brief The writer for a MinidumpContextX86 structure in a minidump file. | 
| 50 class MinidumpContextX86Writer final : public MinidumpContextWriter { | 67 class MinidumpContextX86Writer final : public MinidumpContextWriter { | 
| 51  public: | 68  public: | 
| 52   MinidumpContextX86Writer(); | 69   MinidumpContextX86Writer(); | 
| 53   ~MinidumpContextX86Writer() override; | 70   ~MinidumpContextX86Writer() override; | 
| 54 | 71 | 
|  | 72   //! \brief Initializes the MinidumpContextX86 based on \a context_snapshot. | 
|  | 73   //! | 
|  | 74   //! \param[in] context_snapshot The context snapshot to use as source data. | 
|  | 75   //! | 
|  | 76   //! \note Valid in #kStateMutable. No mutation of context() may be done before | 
|  | 77   //!     calling this method, and it is not normally necessary to alter | 
|  | 78   //!     context() after calling this method. | 
|  | 79   void InitializeFromSnapshot(const CPUContextX86* context_snapshot); | 
|  | 80 | 
| 55   //! \brief Returns a pointer to the context structure that this object will | 81   //! \brief Returns a pointer to the context structure that this object will | 
| 56   //!     write. | 82   //!     write. | 
| 57   //! | 83   //! | 
| 58   //! \attention This returns a non-`const` pointer to this object’s private | 84   //! \attention This returns a non-`const` pointer to this object’s private | 
| 59   //!     data so that a caller can populate the context structure directly. | 85   //!     data so that a caller can populate the context structure directly. | 
| 60   //!     This is done because providing setter interfaces to each field in the | 86   //!     This is done because providing setter interfaces to each field in the | 
| 61   //!     context structure would be unwieldy and cumbersome. Care must be taken | 87   //!     context structure would be unwieldy and cumbersome. Care must be taken | 
| 62   //!     to populate the context structure correctly. The context structure | 88   //!     to populate the context structure correctly. The context structure | 
| 63   //!     must only be modified while this object is in the #kStateMutable | 89   //!     must only be modified while this object is in the #kStateMutable | 
| 64   //!     state. | 90   //!     state. | 
| (...skipping 11 matching lines...) Expand all  Loading... | 
| 76 | 102 | 
| 77   DISALLOW_COPY_AND_ASSIGN(MinidumpContextX86Writer); | 103   DISALLOW_COPY_AND_ASSIGN(MinidumpContextX86Writer); | 
| 78 }; | 104 }; | 
| 79 | 105 | 
| 80 //! \brief The writer for a MinidumpContextAMD64 structure in a minidump file. | 106 //! \brief The writer for a MinidumpContextAMD64 structure in a minidump file. | 
| 81 class MinidumpContextAMD64Writer final : public MinidumpContextWriter { | 107 class MinidumpContextAMD64Writer final : public MinidumpContextWriter { | 
| 82  public: | 108  public: | 
| 83   MinidumpContextAMD64Writer(); | 109   MinidumpContextAMD64Writer(); | 
| 84   ~MinidumpContextAMD64Writer() override; | 110   ~MinidumpContextAMD64Writer() override; | 
| 85 | 111 | 
|  | 112   //! \brief Initializes the MinidumpContextAMD64 based on \a context_snapshot. | 
|  | 113   //! | 
|  | 114   //! \param[in] context_snapshot The context snapshot to use as source data. | 
|  | 115   //! | 
|  | 116   //! \note Valid in #kStateMutable. No mutation of context() may be done before | 
|  | 117   //!     calling this method, and it is not normally necessary to alter | 
|  | 118   //!     context() after calling this method. | 
|  | 119   void InitializeFromSnapshot(const CPUContextX86_64* context_snapshot); | 
|  | 120 | 
| 86   //! \brief Returns a pointer to the context structure that this object will | 121   //! \brief Returns a pointer to the context structure that this object will | 
| 87   //!     write. | 122   //!     write. | 
| 88   //! | 123   //! | 
| 89   //! \attention This returns a non-`const` pointer to this object’s private | 124   //! \attention This returns a non-`const` pointer to this object’s private | 
| 90   //!     data so that a caller can populate the context structure directly. | 125   //!     data so that a caller can populate the context structure directly. | 
| 91   //!     This is done because providing setter interfaces to each field in the | 126   //!     This is done because providing setter interfaces to each field in the | 
| 92   //!     context structure would be unwieldy and cumbersome. Care must be taken | 127   //!     context structure would be unwieldy and cumbersome. Care must be taken | 
| 93   //!     to populate the context structure correctly. The context structure | 128   //!     to populate the context structure correctly. The context structure | 
| 94   //!     must only be modified while this object is in the #kStateMutable | 129   //!     must only be modified while this object is in the #kStateMutable | 
| 95   //!     state. | 130   //!     state. | 
| 96   MinidumpContextAMD64* context() { return &context_; } | 131   MinidumpContextAMD64* context() { return &context_; } | 
| 97 | 132 | 
| 98  protected: | 133  protected: | 
| 99   // MinidumpWritable: | 134   // MinidumpWritable: | 
| 100   size_t Alignment() override; | 135   size_t Alignment() override; | 
| 101   bool WriteObject(FileWriterInterface* file_writer) override; | 136   bool WriteObject(FileWriterInterface* file_writer) override; | 
| 102 | 137 | 
| 103   // MinidumpContextWriter: | 138   // MinidumpContextWriter: | 
| 104   size_t ContextSize() const override; | 139   size_t ContextSize() const override; | 
| 105 | 140 | 
| 106  private: | 141  private: | 
| 107   MinidumpContextAMD64 context_; | 142   MinidumpContextAMD64 context_; | 
| 108 | 143 | 
| 109   DISALLOW_COPY_AND_ASSIGN(MinidumpContextAMD64Writer); | 144   DISALLOW_COPY_AND_ASSIGN(MinidumpContextAMD64Writer); | 
| 110 }; | 145 }; | 
| 111 | 146 | 
| 112 }  // namespace crashpad | 147 }  // namespace crashpad | 
| 113 | 148 | 
| 114 #endif  // CRASHPAD_MINIDUMP_MINIDUMP_CONTEXT_WRITER_H_ | 149 #endif  // CRASHPAD_MINIDUMP_MINIDUMP_CONTEXT_WRITER_H_ | 
| OLD | NEW | 
|---|