| OLD | NEW | 
|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 #include "src/v8.h" | 9 #include "src/v8.h" | 
| 10 | 10 | 
| (...skipping 2692 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 2703                 UNIMPLEMENTED(); | 2703                 UNIMPLEMENTED(); | 
| 2704               } | 2704               } | 
| 2705               break; | 2705               break; | 
| 2706           } | 2706           } | 
| 2707         } | 2707         } | 
| 2708         return; | 2708         return; | 
| 2709       } | 2709       } | 
| 2710       break; | 2710       break; | 
| 2711     } | 2711     } | 
| 2712     case db_x: { | 2712     case db_x: { | 
|  | 2713       if (instr->Bits(22, 20) == 0x5) { | 
|  | 2714         if (instr->Bits(7, 4) == 0xd) { | 
|  | 2715           // SMMLS (in V8 notation matching ARM ISA format) | 
|  | 2716           // Format(instr, "smmls'cond 'rn, 'rm, 'rs, 'rd"); | 
|  | 2717           int rm = instr->RmValue(); | 
|  | 2718           int32_t rm_val = get_register(rm); | 
|  | 2719           int rs = instr->RsValue(); | 
|  | 2720           int32_t rs_val = get_register(rs); | 
|  | 2721           int rd = instr->RdValue(); | 
|  | 2722           int32_t rd_val = get_register(rd); | 
|  | 2723           rn_val = base::bits::SignedMulHighAndSub32(rm_val, rs_val, rd_val); | 
|  | 2724           set_register(rn, rn_val); | 
|  | 2725           return; | 
|  | 2726         } | 
|  | 2727         if (instr->Bits(7, 4) == 0x1) { | 
|  | 2728           int rm = instr->RmValue(); | 
|  | 2729           int32_t rm_val = get_register(rm); | 
|  | 2730           int rs = instr->RsValue(); | 
|  | 2731           int32_t rs_val = get_register(rs); | 
|  | 2732           if (instr->Bits(15, 12) == 0xF) { | 
|  | 2733             // SMMUL (in V8 notation matching ARM ISA format) | 
|  | 2734             // Format(instr, "smmul'cond 'rn, 'rm, 'rs"); | 
|  | 2735             rn_val = base::bits::SignedMulHigh32(rm_val, rs_val); | 
|  | 2736           } else { | 
|  | 2737             // SMMLA (in V8 notation matching ARM ISA format) | 
|  | 2738             // Format(instr, "smmla'cond 'rn, 'rm, 'rs, 'rd"); | 
|  | 2739             int rd = instr->RdValue(); | 
|  | 2740             int32_t rd_val = get_register(rd); | 
|  | 2741             rn_val = base::bits::SignedMulHighAndAdd32(rm_val, rs_val, rd_val); | 
|  | 2742           } | 
|  | 2743           set_register(rn, rn_val); | 
|  | 2744           return; | 
|  | 2745         } | 
|  | 2746       } | 
| 2713       if (FLAG_enable_sudiv) { | 2747       if (FLAG_enable_sudiv) { | 
| 2714         if (instr->Bits(5, 4) == 0x1) { | 2748         if (instr->Bits(5, 4) == 0x1) { | 
| 2715           if ((instr->Bit(22) == 0x0) && (instr->Bit(20) == 0x1)) { | 2749           if ((instr->Bit(22) == 0x0) && (instr->Bit(20) == 0x1)) { | 
| 2716             // (s/u)div (in V8 notation matching ARM ISA format) rn = rm/rs | 2750             // (s/u)div (in V8 notation matching ARM ISA format) rn = rm/rs | 
| 2717             // Format(instr, "'(s/u)div'cond'b 'rn, 'rm, 'rs); | 2751             // Format(instr, "'(s/u)div'cond'b 'rn, 'rm, 'rs); | 
| 2718             int rm = instr->RmValue(); | 2752             int rm = instr->RmValue(); | 
| 2719             int32_t rm_val = get_register(rm); | 2753             int32_t rm_val = get_register(rm); | 
| 2720             int rs = instr->RsValue(); | 2754             int rs = instr->RsValue(); | 
| 2721             int32_t rs_val = get_register(rs); | 2755             int32_t rs_val = get_register(rs); | 
| 2722             int32_t ret_val = 0; | 2756             int32_t ret_val = 0; | 
| (...skipping 1109 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 3832   uintptr_t address = *stack_slot; | 3866   uintptr_t address = *stack_slot; | 
| 3833   set_register(sp, current_sp + sizeof(uintptr_t)); | 3867   set_register(sp, current_sp + sizeof(uintptr_t)); | 
| 3834   return address; | 3868   return address; | 
| 3835 } | 3869 } | 
| 3836 | 3870 | 
| 3837 } }  // namespace v8::internal | 3871 } }  // namespace v8::internal | 
| 3838 | 3872 | 
| 3839 #endif  // USE_SIMULATOR | 3873 #endif  // USE_SIMULATOR | 
| 3840 | 3874 | 
| 3841 #endif  // V8_TARGET_ARCH_ARM | 3875 #endif  // V8_TARGET_ARCH_ARM | 
| OLD | NEW | 
|---|