| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 394 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 405 return Immediate(static_cast<int32_t>(literal->Number())); | 405 return Immediate(static_cast<int32_t>(literal->Number())); |
| 406 } else if (r.IsDouble()) { | 406 } else if (r.IsDouble()) { |
| 407 Abort("unsupported double immediate"); | 407 Abort("unsupported double immediate"); |
| 408 } | 408 } |
| 409 ASSERT(r.IsTagged()); | 409 ASSERT(r.IsTagged()); |
| 410 return Immediate(literal); | 410 return Immediate(literal); |
| 411 } | 411 } |
| 412 | 412 |
| 413 | 413 |
| 414 Operand LCodeGen::ToOperand(LOperand* op) const { | 414 Operand LCodeGen::ToOperand(LOperand* op) const { |
| 415 ASSERT(!op->IsRegister()); | 415 if (op->IsRegister()) return Operand(ToRegister(op)); |
| 416 ASSERT(!op->IsDoubleRegister()); | 416 if (op->IsDoubleRegister()) return Operand(ToDoubleRegister(op)); |
| 417 ASSERT(op->IsStackSlot() || op->IsDoubleStackSlot()); | 417 ASSERT(op->IsStackSlot() || op->IsDoubleStackSlot()); |
| 418 int index = op->index(); | 418 int index = op->index(); |
| 419 if (index >= 0) { | 419 if (index >= 0) { |
| 420 // Local or spill slot. Skip the frame pointer, function, and | 420 // Local or spill slot. Skip the frame pointer, function, and |
| 421 // context in the fixed part of the frame. | 421 // context in the fixed part of the frame. |
| 422 return Operand(ebp, -(index + 3) * kPointerSize); | 422 return Operand(ebp, -(index + 3) * kPointerSize); |
| 423 } else { | 423 } else { |
| 424 // Incoming parameter. Skip the return address. | 424 // Incoming parameter. Skip the return address. |
| 425 return Operand(ebp, -(index - 1) * kPointerSize); | 425 return Operand(ebp, -(index - 1) * kPointerSize); |
| 426 } | 426 } |
| (...skipping 3216 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3643 ASSERT(osr_pc_offset_ == -1); | 3643 ASSERT(osr_pc_offset_ == -1); |
| 3644 osr_pc_offset_ = masm()->pc_offset(); | 3644 osr_pc_offset_ = masm()->pc_offset(); |
| 3645 } | 3645 } |
| 3646 | 3646 |
| 3647 | 3647 |
| 3648 #undef __ | 3648 #undef __ |
| 3649 | 3649 |
| 3650 } } // namespace v8::internal | 3650 } } // namespace v8::internal |
| 3651 | 3651 |
| 3652 #endif // V8_TARGET_ARCH_IA32 | 3652 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |