| Ian Rogers | 3a5c1ce | 2012-02-29 10:06:46 -0800 | [diff] [blame] | 1 | /* | 
 | 2 |  * Copyright (C) 2012 The Android Open Source Project | 
 | 3 |  * | 
 | 4 |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
 | 5 |  * you may not use this file except in compliance with the License. | 
 | 6 |  * You may obtain a copy of the License at | 
 | 7 |  * | 
 | 8 |  *      http://www.apache.org/licenses/LICENSE-2.0 | 
 | 9 |  * | 
 | 10 |  * Unless required by applicable law or agreed to in writing, software | 
 | 11 |  * distributed under the License is distributed on an "AS IS" BASIS, | 
 | 12 |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
 | 13 |  * See the License for the specific language governing permissions and | 
 | 14 |  * limitations under the License. | 
 | 15 |  */ | 
 | 16 |  | 
| Ian Rogers | 02ed4c0 | 2013-09-06 13:10:04 -0700 | [diff] [blame] | 17 | #ifndef ART_DISASSEMBLER_DISASSEMBLER_ARM_H_ | 
 | 18 | #define ART_DISASSEMBLER_DISASSEMBLER_ARM_H_ | 
| Ian Rogers | 3a5c1ce | 2012-02-29 10:06:46 -0800 | [diff] [blame] | 19 |  | 
| Elliott Hughes | 105afd2 | 2012-04-10 15:04:25 -0700 | [diff] [blame] | 20 | #include <vector> | 
 | 21 |  | 
| Ian Rogers | 3a5c1ce | 2012-02-29 10:06:46 -0800 | [diff] [blame] | 22 | #include "disassembler.h" | 
 | 23 |  | 
 | 24 | namespace art { | 
 | 25 | namespace arm { | 
 | 26 |  | 
| Ian Rogers | 38e1203 | 2014-03-14 14:06:14 -0700 | [diff] [blame] | 27 | class DisassemblerArm FINAL : public Disassembler { | 
| Ian Rogers | 3a5c1ce | 2012-02-29 10:06:46 -0800 | [diff] [blame] | 28 |  public: | 
| Ian Rogers | 38e1203 | 2014-03-14 14:06:14 -0700 | [diff] [blame] | 29 |   DisassemblerArm() { | 
 | 30 |   } | 
| Ian Rogers | 3a5c1ce | 2012-02-29 10:06:46 -0800 | [diff] [blame] | 31 |  | 
| Ian Rogers | 38e1203 | 2014-03-14 14:06:14 -0700 | [diff] [blame] | 32 |   size_t Dump(std::ostream& os, const uint8_t* begin) OVERRIDE; | 
 | 33 |   void Dump(std::ostream& os, const uint8_t* begin, const uint8_t* end) OVERRIDE; | 
| Ian Rogers | b122a4b | 2013-11-19 18:00:50 -0800 | [diff] [blame] | 34 |  | 
| Ian Rogers | 3a5c1ce | 2012-02-29 10:06:46 -0800 | [diff] [blame] | 35 |  private: | 
 | 36 |   void DumpArm(std::ostream& os, const uint8_t* instr); | 
 | 37 |  | 
 | 38 |   // Returns the size of the instruction just decoded | 
 | 39 |   size_t DumpThumb16(std::ostream& os, const uint8_t* instr); | 
 | 40 |   size_t DumpThumb32(std::ostream& os, const uint8_t* instr_ptr); | 
 | 41 |  | 
| Ian Rogers | 40627db | 2012-03-04 17:31:09 -0800 | [diff] [blame] | 42 |   void DumpBranchTarget(std::ostream& os, const uint8_t* instr_ptr, int32_t imm32); | 
 | 43 |   void DumpCond(std::ostream& os, uint32_t cond); | 
| Ian Rogers | b122a4b | 2013-11-19 18:00:50 -0800 | [diff] [blame] | 44 |   void DumpMemoryDomain(std::ostream& os, uint32_t domain); | 
| Elliott Hughes | 105afd2 | 2012-04-10 15:04:25 -0700 | [diff] [blame] | 45 |  | 
 | 46 |   std::vector<const char*> it_conditions_; | 
 | 47 |  | 
 | 48 |   DISALLOW_COPY_AND_ASSIGN(DisassemblerArm); | 
| Ian Rogers | 3a5c1ce | 2012-02-29 10:06:46 -0800 | [diff] [blame] | 49 | }; | 
 | 50 |  | 
 | 51 | }  // namespace arm | 
 | 52 | }  // namespace art | 
 | 53 |  | 
| Ian Rogers | 02ed4c0 | 2013-09-06 13:10:04 -0700 | [diff] [blame] | 54 | #endif  // ART_DISASSEMBLER_DISASSEMBLER_ARM_H_ |