| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include <stdarg.h> | 5 #include <stdarg.h> |
| 6 #include <stdlib.h> | 6 #include <stdlib.h> |
| 7 #include <cmath> | 7 #include <cmath> |
| 8 | 8 |
| 9 #if V8_TARGET_ARCH_PPC | 9 #if V8_TARGET_ARCH_PPC |
| 10 | 10 |
| (...skipping 2028 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2039 break; | 2039 break; |
| 2040 } | 2040 } |
| 2041 case ADDCX: { | 2041 case ADDCX: { |
| 2042 int rt = instr->RTValue(); | 2042 int rt = instr->RTValue(); |
| 2043 int ra = instr->RAValue(); | 2043 int ra = instr->RAValue(); |
| 2044 int rb = instr->RBValue(); | 2044 int rb = instr->RBValue(); |
| 2045 // int oe = instr->Bit(10); | 2045 // int oe = instr->Bit(10); |
| 2046 uintptr_t ra_val = get_register(ra); | 2046 uintptr_t ra_val = get_register(ra); |
| 2047 uintptr_t rb_val = get_register(rb); | 2047 uintptr_t rb_val = get_register(rb); |
| 2048 uintptr_t alu_out = ra_val + rb_val; | 2048 uintptr_t alu_out = ra_val + rb_val; |
| 2049 // Check overflow | 2049 // Set carry |
| 2050 if (~ra_val < rb_val) { | 2050 if (~ra_val < rb_val) { |
| 2051 special_reg_xer_ = (special_reg_xer_ & ~0xF0000000) | 0x20000000; | 2051 special_reg_xer_ = (special_reg_xer_ & ~0xF0000000) | 0x20000000; |
| 2052 } else { | 2052 } else { |
| 2053 special_reg_xer_ &= ~0xF0000000; | 2053 special_reg_xer_ &= ~0xF0000000; |
| 2054 } | 2054 } |
| 2055 set_register(rt, alu_out); | 2055 set_register(rt, alu_out); |
| 2056 if (instr->Bit(0)) { // RC bit set | 2056 if (instr->Bit(0)) { // RC bit set |
| 2057 SetCR0(static_cast<intptr_t>(alu_out)); | 2057 SetCR0(static_cast<intptr_t>(alu_out)); |
| 2058 } | 2058 } |
| 2059 // todo - handle OE bit | 2059 // todo - handle OE bit |
| 2060 break; | 2060 break; |
| 2061 } | 2061 } |
| 2062 case ADDEX: { |
| 2063 int rt = instr->RTValue(); |
| 2064 int ra = instr->RAValue(); |
| 2065 int rb = instr->RBValue(); |
| 2066 // int oe = instr->Bit(10); |
| 2067 uintptr_t ra_val = get_register(ra); |
| 2068 uintptr_t rb_val = get_register(rb); |
| 2069 uintptr_t alu_out = ra_val + rb_val; |
| 2070 if (special_reg_xer_ & 0x20000000) { |
| 2071 alu_out += 1; |
| 2072 } |
| 2073 set_register(rt, alu_out); |
| 2074 if (instr->Bit(0)) { // RC bit set |
| 2075 SetCR0(static_cast<intptr_t>(alu_out)); |
| 2076 } |
| 2077 // todo - handle OE bit |
| 2078 break; |
| 2079 } |
| 2062 case MULHWX: { | 2080 case MULHWX: { |
| 2063 int rt = instr->RTValue(); | 2081 int rt = instr->RTValue(); |
| 2064 int ra = instr->RAValue(); | 2082 int ra = instr->RAValue(); |
| 2065 int rb = instr->RBValue(); | 2083 int rb = instr->RBValue(); |
| 2066 int32_t ra_val = (get_register(ra) & 0xFFFFFFFF); | 2084 int32_t ra_val = (get_register(ra) & 0xFFFFFFFF); |
| 2067 int32_t rb_val = (get_register(rb) & 0xFFFFFFFF); | 2085 int32_t rb_val = (get_register(rb) & 0xFFFFFFFF); |
| 2068 int64_t alu_out = (int64_t)ra_val * (int64_t)rb_val; | 2086 int64_t alu_out = (int64_t)ra_val * (int64_t)rb_val; |
| 2069 alu_out >>= 32; | 2087 alu_out >>= 32; |
| 2070 set_register(rt, alu_out); | 2088 set_register(rt, alu_out); |
| 2071 if (instr->Bit(0)) { // RC bit set | 2089 if (instr->Bit(0)) { // RC bit set |
| (...skipping 2021 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4093 uintptr_t* stack_slot = reinterpret_cast<uintptr_t*>(current_sp); | 4111 uintptr_t* stack_slot = reinterpret_cast<uintptr_t*>(current_sp); |
| 4094 uintptr_t address = *stack_slot; | 4112 uintptr_t address = *stack_slot; |
| 4095 set_register(sp, current_sp + sizeof(uintptr_t)); | 4113 set_register(sp, current_sp + sizeof(uintptr_t)); |
| 4096 return address; | 4114 return address; |
| 4097 } | 4115 } |
| 4098 } // namespace internal | 4116 } // namespace internal |
| 4099 } // namespace v8 | 4117 } // namespace v8 |
| 4100 | 4118 |
| 4101 #endif // USE_SIMULATOR | 4119 #endif // USE_SIMULATOR |
| 4102 #endif // V8_TARGET_ARCH_PPC | 4120 #endif // V8_TARGET_ARCH_PPC |
| OLD | NEW |