| Index: src/mips64/disasm-mips64.cc
|
| diff --git a/src/mips64/disasm-mips64.cc b/src/mips64/disasm-mips64.cc
|
| index 0723190871959b507fff262f81c63f36a93ac270..a723bdc7702bc7f088e4f45c3c393cd2b9ef197e 100644
|
| --- a/src/mips64/disasm-mips64.cc
|
| +++ b/src/mips64/disasm-mips64.cc
|
| @@ -344,8 +344,10 @@ void Decoder::PrintPCImm21(Instruction* instr, int delta_pc, int n_bits) {
|
|
|
| // Print 26-bit hex immediate value.
|
| void Decoder::PrintXImm26(Instruction* instr) {
|
| - uint32_t imm = static_cast<uint32_t>(instr->Imm26Value()) << kImmFieldShift;
|
| - out_buffer_pos_ += SNPrintF(out_buffer_ + out_buffer_pos_, "0x%x", imm);
|
| + uint64_t target = static_cast<uint64_t>(instr->Imm26Value())
|
| + << kImmFieldShift;
|
| + target = (reinterpret_cast<uint64_t>(instr) & ~0xfffffff) | target;
|
| + out_buffer_pos_ += SNPrintF(out_buffer_ + out_buffer_pos_, "0x%lx", target);
|
| }
|
|
|
|
|
|
|