| OLD | NEW |
| 1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 179 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 190 | 190 |
| 191 RecordWriteNonSmi(object, offset, value, smi_index); | 191 RecordWriteNonSmi(object, offset, value, smi_index); |
| 192 bind(&done); | 192 bind(&done); |
| 193 | 193 |
| 194 // Clobber all input registers when running with the debug-code flag | 194 // Clobber all input registers when running with the debug-code flag |
| 195 // turned on to provoke errors. This clobbering repeats the | 195 // turned on to provoke errors. This clobbering repeats the |
| 196 // clobbering done inside RecordWriteNonSmi but it's necessary to | 196 // clobbering done inside RecordWriteNonSmi but it's necessary to |
| 197 // avoid having the fast case for smis leave the registers | 197 // avoid having the fast case for smis leave the registers |
| 198 // unchanged. | 198 // unchanged. |
| 199 if (FLAG_debug_code) { | 199 if (FLAG_debug_code) { |
| 200 movq(object, bit_cast<int64_t>(kZapValue), RelocInfo::NONE); | 200 movq(object, BitCast<int64_t>(kZapValue), RelocInfo::NONE); |
| 201 movq(value, bit_cast<int64_t>(kZapValue), RelocInfo::NONE); | 201 movq(value, BitCast<int64_t>(kZapValue), RelocInfo::NONE); |
| 202 movq(smi_index, bit_cast<int64_t>(kZapValue), RelocInfo::NONE); | 202 movq(smi_index, BitCast<int64_t>(kZapValue), RelocInfo::NONE); |
| 203 } | 203 } |
| 204 } | 204 } |
| 205 | 205 |
| 206 | 206 |
| 207 void MacroAssembler::RecordWriteNonSmi(Register object, | 207 void MacroAssembler::RecordWriteNonSmi(Register object, |
| 208 int offset, | 208 int offset, |
| 209 Register scratch, | 209 Register scratch, |
| 210 Register smi_index) { | 210 Register smi_index) { |
| 211 Label done; | 211 Label done; |
| 212 | 212 |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 263 RecordWriteStub stub(object, dst, scratch); | 263 RecordWriteStub stub(object, dst, scratch); |
| 264 CallStub(&stub); | 264 CallStub(&stub); |
| 265 } | 265 } |
| 266 } | 266 } |
| 267 | 267 |
| 268 bind(&done); | 268 bind(&done); |
| 269 | 269 |
| 270 // Clobber all input registers when running with the debug-code flag | 270 // Clobber all input registers when running with the debug-code flag |
| 271 // turned on to provoke errors. | 271 // turned on to provoke errors. |
| 272 if (FLAG_debug_code) { | 272 if (FLAG_debug_code) { |
| 273 movq(object, bit_cast<int64_t>(kZapValue), RelocInfo::NONE); | 273 movq(object, BitCast<int64_t>(kZapValue), RelocInfo::NONE); |
| 274 movq(scratch, bit_cast<int64_t>(kZapValue), RelocInfo::NONE); | 274 movq(scratch, BitCast<int64_t>(kZapValue), RelocInfo::NONE); |
| 275 movq(smi_index, bit_cast<int64_t>(kZapValue), RelocInfo::NONE); | 275 movq(smi_index, BitCast<int64_t>(kZapValue), RelocInfo::NONE); |
| 276 } | 276 } |
| 277 } | 277 } |
| 278 | 278 |
| 279 | 279 |
| 280 void MacroAssembler::Assert(Condition cc, const char* msg) { | 280 void MacroAssembler::Assert(Condition cc, const char* msg) { |
| 281 if (FLAG_debug_code) Check(cc, msg); | 281 if (FLAG_debug_code) Check(cc, msg); |
| 282 } | 282 } |
| 283 | 283 |
| 284 | 284 |
| 285 void MacroAssembler::Check(Condition cc, const char* msg) { | 285 void MacroAssembler::Check(Condition cc, const char* msg) { |
| (...skipping 2342 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2628 CodePatcher::~CodePatcher() { | 2628 CodePatcher::~CodePatcher() { |
| 2629 // Indicate that code has changed. | 2629 // Indicate that code has changed. |
| 2630 CPU::FlushICache(address_, size_); | 2630 CPU::FlushICache(address_, size_); |
| 2631 | 2631 |
| 2632 // Check that the code was patched as expected. | 2632 // Check that the code was patched as expected. |
| 2633 ASSERT(masm_.pc_ == address_ + size_); | 2633 ASSERT(masm_.pc_ == address_ + size_); |
| 2634 ASSERT(masm_.reloc_info_writer.pos() == address_ + size_ + Assembler::kGap); | 2634 ASSERT(masm_.reloc_info_writer.pos() == address_ + size_ + Assembler::kGap); |
| 2635 } | 2635 } |
| 2636 | 2636 |
| 2637 } } // namespace v8::internal | 2637 } } // namespace v8::internal |
| OLD | NEW |