| OLD | NEW |
| 1 // Copyright (c) 1994-2006 Sun Microsystems Inc. | 1 // Copyright (c) 1994-2006 Sun Microsystems Inc. |
| 2 // All Rights Reserved. | 2 // All Rights Reserved. |
| 3 // | 3 // |
| 4 // Redistribution and use in source and binary forms, with or without | 4 // Redistribution and use in source and binary forms, with or without |
| 5 // modification, are permitted provided that the following conditions | 5 // modification, are permitted provided that the following conditions |
| 6 // are met: | 6 // are met: |
| 7 // | 7 // |
| 8 // - Redistributions of source code must retain the above copyright notice, | 8 // - Redistributions of source code must retain the above copyright notice, |
| 9 // this list of conditions and the following disclaimer. | 9 // this list of conditions and the following disclaimer. |
| 10 // | 10 // |
| (...skipping 14 matching lines...) Expand all Loading... |
| 25 // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 25 // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
| 26 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | 26 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
| 27 // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | 27 // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
| 28 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, | 28 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, |
| 29 // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | 29 // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| 30 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | 30 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED |
| 31 // OF THE POSSIBILITY OF SUCH DAMAGE. | 31 // OF THE POSSIBILITY OF SUCH DAMAGE. |
| 32 | 32 |
| 33 // The original source code covered by the above license above has been modified | 33 // The original source code covered by the above license above has been modified |
| 34 // significantly by Google Inc. | 34 // significantly by Google Inc. |
| 35 // Copyright 2006-2008 the V8 project authors. All rights reserved. | 35 // Copyright 2012 the V8 project authors. All rights reserved. |
| 36 | 36 |
| 37 #ifndef V8_ARM_ASSEMBLER_ARM_INL_H_ | 37 #ifndef V8_ARM_ASSEMBLER_ARM_INL_H_ |
| 38 #define V8_ARM_ASSEMBLER_ARM_INL_H_ | 38 #define V8_ARM_ASSEMBLER_ARM_INL_H_ |
| 39 | 39 |
| 40 #include "arm/assembler-arm.h" | 40 #include "arm/assembler-arm.h" |
| 41 #include "cpu.h" | 41 #include "cpu.h" |
| 42 #include "debug.h" | 42 #include "debug.h" |
| 43 | 43 |
| 44 | 44 |
| 45 namespace v8 { | 45 namespace v8 { |
| 46 namespace internal { | 46 namespace internal { |
| 47 | 47 |
| 48 | 48 |
| 49 int DwVfpRegister::ToAllocationIndex(DwVfpRegister reg) { |
| 50 ASSERT(!reg.is(kDoubleRegZero)); |
| 51 ASSERT(!reg.is(kScratchDoubleReg)); |
| 52 return reg.code(); |
| 53 } |
| 54 |
| 55 |
| 49 void RelocInfo::apply(intptr_t delta) { | 56 void RelocInfo::apply(intptr_t delta) { |
| 50 if (RelocInfo::IsInternalReference(rmode_)) { | 57 if (RelocInfo::IsInternalReference(rmode_)) { |
| 51 // absolute code pointer inside code object moves with the code object. | 58 // absolute code pointer inside code object moves with the code object. |
| 52 int32_t* p = reinterpret_cast<int32_t*>(pc_); | 59 int32_t* p = reinterpret_cast<int32_t*>(pc_); |
| 53 *p += delta; // relocate entry | 60 *p += delta; // relocate entry |
| 54 } | 61 } |
| 55 // We do not use pc relative addressing on ARM, so there is | 62 // We do not use pc relative addressing on ARM, so there is |
| 56 // nothing else to do. | 63 // nothing else to do. |
| 57 } | 64 } |
| 58 | 65 |
| (...skipping 285 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 344 // CPU::FlushICache(pc, sizeof(target)); | 351 // CPU::FlushICache(pc, sizeof(target)); |
| 345 // However, on ARM, no instruction was actually patched by the assignment | 352 // However, on ARM, no instruction was actually patched by the assignment |
| 346 // above; the target address is not part of an instruction, it is patched in | 353 // above; the target address is not part of an instruction, it is patched in |
| 347 // the constant pool and is read via a data access; the instruction accessing | 354 // the constant pool and is read via a data access; the instruction accessing |
| 348 // this address in the constant pool remains unchanged. | 355 // this address in the constant pool remains unchanged. |
| 349 } | 356 } |
| 350 | 357 |
| 351 } } // namespace v8::internal | 358 } } // namespace v8::internal |
| 352 | 359 |
| 353 #endif // V8_ARM_ASSEMBLER_ARM_INL_H_ | 360 #endif // V8_ARM_ASSEMBLER_ARM_INL_H_ |
| OLD | NEW |