| // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| #include "vm/globals.h" |
| #if defined(TARGET_ARCH_MIPS) |
| |
| #include "vm/assembler.h" |
| #include "vm/os.h" |
| #include "vm/unit_test.h" |
| #include "vm/virtual_memory.h" |
| |
| namespace dart { |
| |
| #define __ assembler-> |
| |
| ASSEMBLER_TEST_GENERATE(Simple, assembler) { |
| __ LoadImmediate(V0, 42); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Simple, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Addiu, assembler) { |
| __ addiu(V0, ZR, Immediate(42)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Addiu, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Addiu_overflow, assembler) { |
| __ LoadImmediate(V0, 0x7fffffff); |
| __ addiu(V0, V0, Immediate(1)); // V0 is modified on overflow. |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Addiu_overflow, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(static_cast<int32_t>(0x80000000), |
| EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Addu, assembler) { |
| __ addiu(R2, ZR, Immediate(21)); |
| __ addiu(R3, ZR, Immediate(21)); |
| __ addu(V0, R2, R3); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Addu, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Addu_overflow, assembler) { |
| __ LoadImmediate(R2, 0x7fffffff); |
| __ addiu(R3, R0, Immediate(1)); |
| __ addu(V0, R2, R3); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Addu_overflow, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(static_cast<int32_t>(0x80000000), |
| EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(And, assembler) { |
| __ addiu(R2, ZR, Immediate(42)); |
| __ addiu(R3, ZR, Immediate(2)); |
| __ and_(V0, R2, R3); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(And, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(2, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Andi, assembler) { |
| __ addiu(R1, ZR, Immediate(42)); |
| __ andi(V0, R1, Immediate(2)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Andi, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(2, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Clo, assembler) { |
| __ addiu(R1, ZR, Immediate(-1)); |
| __ clo(V0, R1); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Clo, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(32, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Clz, assembler) { |
| __ addiu(R1, ZR, Immediate(0x7fff)); |
| __ clz(V0, R1); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Clz, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(17, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Divu, assembler) { |
| __ addiu(R1, ZR, Immediate(27)); |
| __ addiu(R2, ZR, Immediate(9)); |
| __ divu(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Divu, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(3, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Div, assembler) { |
| __ addiu(R1, ZR, Immediate(27)); |
| __ addiu(R2, ZR, Immediate(9)); |
| __ div(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Div, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(3, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Divu_zero, assembler) { |
| __ addiu(R1, ZR, Immediate(27)); |
| __ addiu(R2, ZR, Immediate(0)); |
| __ divu(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Divu_zero, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Div_zero, assembler) { |
| __ addiu(R1, ZR, Immediate(27)); |
| __ addiu(R2, ZR, Immediate(0)); |
| __ div(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Div_zero, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Divu_corner, assembler) { |
| __ LoadImmediate(R1, 0x80000000); |
| __ LoadImmediate(R2, 0xffffffff); |
| __ divu(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Divu_corner, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Div_corner, assembler) { |
| __ LoadImmediate(R1, 0x80000000); |
| __ LoadImmediate(R2, 0xffffffff); |
| __ div(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Div_corner, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(static_cast<int32_t>(0x80000000), |
| EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Lb, assembler) { |
| __ addiu(SP, SP, Immediate(-kWordSize * 30)); |
| __ LoadImmediate(R1, 0xff); |
| __ sb(R1, Address(SP)); |
| __ lb(V0, Address(SP)); |
| __ addiu(SP, SP, Immediate(kWordSize * 30)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Lb, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Lb_offset, assembler) { |
| __ addiu(SP, SP, Immediate(-kWordSize * 30)); |
| __ LoadImmediate(R1, 0xff); |
| __ sb(R1, Address(SP, 1)); |
| __ lb(V0, Address(SP, 1)); |
| __ addiu(SP, SP, Immediate(kWordSize * 30)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Lb_offset, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Lbu, assembler) { |
| __ addiu(SP, SP, Immediate(-kWordSize * 30)); |
| __ LoadImmediate(R1, 0xff); |
| __ sb(R1, Address(SP)); |
| __ lbu(V0, Address(SP)); |
| __ addiu(SP, SP, Immediate(kWordSize * 30)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Lbu, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(255, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Lh, assembler) { |
| __ addiu(SP, SP, Immediate(-kWordSize * 30)); |
| __ LoadImmediate(R1, 0xffff); |
| __ sh(R1, Address(SP)); |
| __ lh(V0, Address(SP)); |
| __ addiu(SP, SP, Immediate(kWordSize * 30)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Lh, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Lhu, assembler) { |
| __ addiu(SP, SP, Immediate(-kWordSize * 30)); |
| __ LoadImmediate(R1, 0xffff); |
| __ sh(R1, Address(SP)); |
| __ lhu(V0, Address(SP)); |
| __ addiu(SP, SP, Immediate(kWordSize * 30)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Lhu, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(65535, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Lw, assembler) { |
| __ addiu(SP, SP, Immediate(-kWordSize * 30)); |
| __ LoadImmediate(R1, -1); |
| __ sw(R1, Address(SP)); |
| __ lw(V0, Address(SP)); |
| __ addiu(SP, SP, Immediate(kWordSize * 30)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Lw, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Lui, assembler) { |
| __ lui(V0, Immediate(42)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Lui, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42 << 16, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Sll, assembler) { |
| __ LoadImmediate(R1, 21); |
| __ sll(V0, R1, 1); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Sll, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Srl, assembler) { |
| __ LoadImmediate(R1, 84); |
| __ srl(V0, R1, 1); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Srl, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(LShifting, assembler) { |
| __ LoadImmediate(R1, 1); |
| __ sll(R1, R1, 31); |
| __ srl(V0, R1, 31); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(LShifting, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(RShifting, assembler) { |
| __ LoadImmediate(R1, 1); |
| __ sll(R1, R1, 31); |
| __ sra(V0, R1, 31); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(RShifting, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Sllv, assembler) { |
| __ LoadImmediate(R1, 21); |
| __ LoadImmediate(R2, 1); |
| __ sllv(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Sllv, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Srlv, assembler) { |
| __ LoadImmediate(R1, 84); |
| __ LoadImmediate(R2, 1); |
| __ srlv(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Srlv, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(LShiftingV, assembler) { |
| __ LoadImmediate(R1, 1); |
| __ LoadImmediate(R2, 31); |
| __ sllv(R1, R1, R2); |
| __ srlv(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(LShiftingV, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(RShiftingV, assembler) { |
| __ LoadImmediate(R1, 1); |
| __ LoadImmediate(R2, 31); |
| __ sllv(R1, R1, R2); |
| __ srav(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(RShiftingV, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Mult_pos, assembler) { |
| __ LoadImmediate(R1, 6); |
| __ LoadImmediate(R2, 7); |
| __ mult(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Mult_pos, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Mult_neg, assembler) { |
| __ LoadImmediate(R1, -6); |
| __ LoadImmediate(R2, 7); |
| __ mult(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Mult_neg, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Mult_neg_hi, assembler) { |
| __ LoadImmediate(R1, -6); |
| __ LoadImmediate(R2, 7); |
| __ mult(R1, R2); |
| __ mfhi(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Mult_neg_hi, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Multu_lo, assembler) { |
| __ LoadImmediate(R1, 6); |
| __ LoadImmediate(R2, 7); |
| __ multu(R1, R2); |
| __ mflo(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Multu_lo, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Multu_hi, assembler) { |
| __ LoadImmediate(R1, 65536); |
| __ LoadImmediate(R2, 65536); |
| __ multu(R1, R2); |
| __ mfhi(V0); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Multu_hi, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Subu, assembler) { |
| __ LoadImmediate(R1, 737); |
| __ LoadImmediate(R2, 695); |
| __ subu(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Subu, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Or, assembler) { |
| __ LoadImmediate(R1, 34); |
| __ LoadImmediate(R2, 8); |
| __ or_(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Or, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Nor, assembler) { |
| __ LoadImmediate(R1, -47); |
| __ LoadImmediate(R2, -60); |
| __ nor(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Nor, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Xor, assembler) { |
| __ LoadImmediate(R1, 51); |
| __ LoadImmediate(R2, 25); |
| __ xor_(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Xor, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Xori, assembler) { |
| __ LoadImmediate(T0, 51); |
| __ xori(V0, T0, Immediate(25)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Xori, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Slt, assembler) { |
| __ LoadImmediate(R1, -1); |
| __ LoadImmediate(R2, 0); |
| __ slt(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Slt, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Sltu, assembler) { |
| __ LoadImmediate(R1, -1); |
| __ LoadImmediate(R2, 0); |
| __ sltu(V0, R1, R2); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Sltu, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Movz, assembler) { |
| __ LoadImmediate(R1, 42); |
| __ LoadImmediate(R2, 23); |
| __ slt(R3, R1, R2); |
| __ movz(V0, R1, R3); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Movz, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Movn, assembler) { |
| __ LoadImmediate(R1, 42); |
| __ LoadImmediate(R2, 23); |
| __ slt(R3, R2, R1); |
| __ movn(V0, R1, R3); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Movn, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Jr_delay, assembler) { |
| __ jr(RA); |
| __ delay_slot()->ori(V0, ZR, Immediate(42)); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Jr_delay, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beq_backward, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R1, 0); |
| __ LoadImmediate(R2, 1); |
| __ Bind(&l); |
| __ addiu(R1, R1, Immediate(1)); |
| __ beq(R1, R2, &l); |
| __ ori(V0, R1, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beq_backward, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(2, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beq_backward_delay, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R1, 0); |
| __ LoadImmediate(R2, 1); |
| __ Bind(&l); |
| __ addiu(R1, R1, Immediate(1)); |
| __ beq(R1, R2, &l); |
| __ delay_slot()->addiu(R1, R1, Immediate(1)); |
| __ ori(V0, R1, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beq_backward_delay, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(4, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beq_forward_taken, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 1); |
| __ LoadImmediate(R6, 1); |
| |
| __ LoadImmediate(V0, 42); |
| __ beq(R5, R6, &l); |
| __ LoadImmediate(V0, 0); |
| __ Bind(&l); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beq_forward_taken, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beq_forward_not_taken, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 0); |
| __ LoadImmediate(R6, 1); |
| |
| __ LoadImmediate(V0, 42); |
| __ beq(R5, R6, &l); |
| __ LoadImmediate(V0, 0); |
| __ Bind(&l); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beq_forward_not_taken, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beq_forward_taken2, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 1); |
| __ LoadImmediate(R6, 1); |
| |
| __ LoadImmediate(V0, 42); |
| __ beq(R5, R6, &l); |
| __ nop(); |
| __ nop(); |
| __ LoadImmediate(V0, 0); |
| __ Bind(&l); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beq_forward_taken2, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beq_forward_taken_delay, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 1); |
| __ LoadImmediate(R6, 1); |
| |
| __ LoadImmediate(V0, 42); |
| __ beq(R5, R6, &l); |
| __ delay_slot()->ori(V0, V0, Immediate(1)); |
| __ LoadImmediate(V0, 0); |
| __ Bind(&l); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beq_forward_taken_delay, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(43, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beq_forward_not_taken_delay, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 0); |
| __ LoadImmediate(R6, 1); |
| |
| __ LoadImmediate(V0, 42); |
| __ beq(R5, R6, &l); |
| __ delay_slot()->ori(V0, V0, Immediate(1)); |
| __ addiu(V0, V0, Immediate(1)); |
| __ Bind(&l); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beq_forward_not_taken_delay, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(44, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Beql_backward_delay, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 0); |
| __ LoadImmediate(R6, 1); |
| __ Bind(&l); |
| __ addiu(R5, R5, Immediate(1)); |
| __ beql(R5, R6, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Beql_backward_delay, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(3, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bgez, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 3); |
| __ Bind(&l); |
| __ bgez(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(-1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bgez, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-2, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bgezl, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 3); |
| __ Bind(&l); |
| __ bgezl(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(-1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bgezl, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Blez, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, -3); |
| __ Bind(&l); |
| __ blez(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Blez, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(2, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Blezl, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, -3); |
| __ Bind(&l); |
| __ blezl(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Blezl, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bgtz, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 3); |
| __ Bind(&l); |
| __ bgtz(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(-1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bgtz, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bgtzl, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 3); |
| __ Bind(&l); |
| __ bgtzl(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(-1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bgtzl, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bltz, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, -3); |
| __ Bind(&l); |
| __ bltz(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bltz, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bltzl, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, -3); |
| __ Bind(&l); |
| __ bltzl(R5, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bltzl, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bne, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 3); |
| __ Bind(&l); |
| __ bne(R5, R0, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(-1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bne, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(-1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Bnel, assembler) { |
| Label l; |
| |
| __ LoadImmediate(R5, 3); |
| __ Bind(&l); |
| __ bnel(R5, R0, &l); |
| __ delay_slot()->addiu(R5, R5, Immediate(-1)); |
| __ ori(V0, R5, Immediate(0)); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Bnel, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Label_link1, assembler) { |
| Label l; |
| |
| __ bgez(ZR, &l); |
| __ bgez(ZR, &l); |
| __ bgez(ZR, &l); |
| |
| __ LoadImmediate(V0, 1); |
| __ Bind(&l); |
| __ mov(V0, ZR); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Label_link1, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Label_link2, assembler) { |
| Label l; |
| |
| __ beq(ZR, ZR, &l); |
| __ beq(ZR, ZR, &l); |
| __ beq(ZR, ZR, &l); |
| |
| __ LoadImmediate(V0, 1); |
| __ Bind(&l); |
| __ mov(V0, ZR); |
| __ jr(RA); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Label_link2, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(0, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Jalr_delay, assembler) { |
| __ mov(R2, RA); |
| __ jalr(R2, RA); |
| __ delay_slot()->ori(V0, ZR, Immediate(42)); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Jalr_delay, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(AddOverflow_detect, assembler) { |
| Register left = T0; |
| Register right = T1; |
| Register result = T2; |
| Register overflow = T3; |
| Label error, done; |
| |
| __ LoadImmediate(V0, 1); // Success value. |
| |
| __ LoadImmediate(left, 0x7fffffff); |
| __ LoadImmediate(right, 1); |
| __ AdduDetectOverflow(result, left, right, overflow); |
| __ bgez(overflow, &error); // INT_MAX + 1 overflows. |
| |
| __ LoadImmediate(left, 0x7fffffff); |
| __ AdduDetectOverflow(result, left, left, overflow); |
| __ bgez(overflow, &error); // INT_MAX + INT_MAX overflows. |
| |
| __ LoadImmediate(left, 0x7fffffff); |
| __ LoadImmediate(right, -1); |
| __ AdduDetectOverflow(result, left, right, overflow); |
| __ bltz(overflow, &error); // INT_MAX - 1 does not overflow. |
| |
| __ LoadImmediate(left, -1); |
| __ LoadImmediate(right, 1); |
| __ AdduDetectOverflow(result, left, right, overflow); |
| __ bltz(overflow, &error); // -1 + 1 does not overflow. |
| |
| __ LoadImmediate(left, 123456); |
| __ LoadImmediate(right, 654321); |
| __ AdduDetectOverflow(result, left, right, overflow); |
| __ bltz(overflow, &error); // 123456 + 654321 does not overflow. |
| |
| __ LoadImmediate(left, 0x80000000); |
| __ LoadImmediate(right, -1); |
| __ AdduDetectOverflow(result, left, right, overflow); |
| __ bgez(overflow, &error); // INT_MIN - 1 overflows. |
| |
| // result has 0x7fffffff. |
| __ AdduDetectOverflow(result, result, result, overflow); |
| __ bgez(overflow, &error); // INT_MAX + INT_MAX overflows. |
| |
| __ LoadImmediate(left, 0x80000000); |
| __ LoadImmediate(right, 0x80000000); |
| __ AdduDetectOverflow(result, left, right, overflow); |
| __ bgez(overflow, &error); // INT_MIN + INT_MIN overflows. |
| |
| __ LoadImmediate(left, -123456); |
| __ LoadImmediate(right, -654321); |
| __ AdduDetectOverflow(result, left, right, overflow); |
| __ bltz(overflow, &error); // -123456 + -654321 does not overflow. |
| |
| __ b(&done); |
| __ Bind(&error); |
| __ mov(V0, ZR); |
| __ Bind(&done); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(AddOverflow_detect, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(SubOverflow_detect, assembler) { |
| Register left = T0; |
| Register right = T1; |
| Register result = T2; |
| Register overflow = T3; |
| Label error, done; |
| |
| __ LoadImmediate(V0, 1); // Success value. |
| |
| __ LoadImmediate(left, 0x80000000); |
| __ LoadImmediate(right, 1); |
| __ SubuDetectOverflow(result, left, right, overflow); |
| __ bgez(overflow, &error); // INT_MIN - 1 overflows. |
| |
| __ LoadImmediate(left, 0x7fffffff); |
| __ LoadImmediate(right, 0x8000000); |
| __ SubuDetectOverflow(result, left, left, overflow); |
| __ bltz(overflow, &error); // INT_MIN - INT_MAX does not overflow. |
| |
| __ LoadImmediate(left, 0x80000000); |
| __ LoadImmediate(right, 0x80000000); |
| __ SubuDetectOverflow(result, left, right, overflow); |
| __ bltz(overflow, &error); // INT_MIN - INT_MIN does not overflow. |
| |
| __ LoadImmediate(left, 0x7fffffff); |
| __ LoadImmediate(right, 0x80000000); |
| __ SubuDetectOverflow(result, left, right, overflow); |
| __ bgez(overflow, &error); // INT_MAX - INT_MIN overflows. |
| |
| __ LoadImmediate(left, 1); |
| __ LoadImmediate(right, -1); |
| __ SubuDetectOverflow(result, left, right, overflow); |
| __ bltz(overflow, &error); // 1 - -1 does not overflow. |
| |
| __ b(&done); |
| __ Bind(&error); |
| __ mov(V0, ZR); |
| __ Bind(&done); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(SubOverflow_detect, test) { |
| typedef int (*SimpleCode)(); |
| EXPECT_EQ(1, EXECUTE_TEST_CODE_INT32(SimpleCode, test->entry())); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Mtc1Mfc1, assembler) { |
| __ mtc1(ZR, F0); |
| __ mfc1(V0, F0); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Mtc1Mfc1, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| double res = EXECUTE_TEST_CODE_FLOAT(SimpleCode, test->entry()); |
| EXPECT_FLOAT_EQ(0.0, res, 0.001); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Addd, assembler) { |
| __ LoadImmediate(F0, 1.0); |
| __ LoadImmediate(F2, 2.0); |
| __ addd(F4, F0, F2); |
| __ mfc1(V0, F4); |
| __ mfc1(V1, F5); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Addd, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| double res = EXECUTE_TEST_CODE_DOUBLE(SimpleCode, test->entry()); |
| EXPECT_FLOAT_EQ(3.0, res, 0.001); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Adds, assembler) { |
| __ LoadImmediate(F0, 1.0f); |
| __ LoadImmediate(F2, 2.0f); |
| __ adds(F4, F0, F2); |
| __ mfc1(V0, F4); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Adds, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| double res = EXECUTE_TEST_CODE_FLOAT(SimpleCode, test->entry()); |
| EXPECT_FLOAT_EQ(3.0, res, 0.001); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Movd, assembler) { |
| __ LoadImmediate(F0, 1.0); |
| __ movd(F2, F0); |
| __ mfc1(V0, F2); |
| __ mfc1(V1, F3); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Movd, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| double res = EXECUTE_TEST_CODE_DOUBLE(SimpleCode, test->entry()); |
| EXPECT_FLOAT_EQ(1.0, res, 0.001); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Movs, assembler) { |
| __ LoadImmediate(F0, 1.0f); |
| __ movd(F2, F0); |
| __ mfc1(V0, F2); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Movs, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| double res = EXECUTE_TEST_CODE_FLOAT(SimpleCode, test->entry()); |
| EXPECT_FLOAT_EQ(1.0, res, 0.001); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Sdc1Ldc1, assembler) { |
| __ AddImmediate(SP, -8 * kWordSize); |
| __ LoadImmediate(T1, ~(8 - 1)); |
| __ and_(T0, SP, T1); // Need 8 byte alignment. |
| __ LoadImmediate(F0, 1.0); |
| __ sdc1(F0, Address(T0)); |
| __ ldc1(F2, Address(T0)); |
| __ mfc1(V0, F2); |
| __ mfc1(V1, F3); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Sdc1Ldc1, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| double res = EXECUTE_TEST_CODE_DOUBLE(SimpleCode, test->entry()); |
| EXPECT_FLOAT_EQ(1.0, res, 0.001); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Swc1Lwc1, assembler) { |
| __ AddImmediate(SP, -1 * kWordSize); |
| __ LoadImmediate(F0, 1.0f); |
| __ swc1(F0, Address(SP)); |
| __ lwc1(F1, Address(SP)); |
| __ mfc1(V0, F1); |
| __ AddImmediate(SP, 1 * kWordSize); |
| __ Ret(); |
| } |
| |
| ASSEMBLER_TEST_RUN(Swc1Lwc1, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| double res = EXECUTE_TEST_CODE_FLOAT(SimpleCode, test->entry()); |
| EXPECT_FLOAT_EQ(1.0, res, 0.001); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Adds_NaN, assembler) { |
| __ LoadImmediate(F0, 1.0f); |
| __ LoadImmediate(T0, 0x7f800001); // NaN |
| __ mtc1(T0, F2); |
| __ adds(F4, F0, F2); |
| __ mfc1(V0, F4); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Adds_NaN, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| float res = EXECUTE_TEST_CODE_FLOAT(SimpleCode, test->entry()); |
| EXPECT_EQ(isnan(res), true); |
| } |
| |
| |
| ASSEMBLER_TEST_GENERATE(Adds_Inf, assembler) { |
| __ LoadImmediate(F0, 1.0f); |
| __ LoadImmediate(T0, 0x7f800000); // +inf |
| __ mtc1(T0, F2); |
| __ adds(F4, F0, F2); |
| __ mfc1(V0, F4); |
| __ Ret(); |
| } |
| |
| |
| ASSEMBLER_TEST_RUN(Adds_Inf, test) { |
| typedef double (*SimpleCode)(); |
| EXPECT(test != NULL); |
| float res = EXECUTE_TEST_CODE_FLOAT(SimpleCode, test->entry()); |
| EXPECT_EQ(isfinite(res), false); |
| } |
| |
| |
| // Called from assembler_test.cc. |
| // RA: return address. |
| // A0: context. |
| // A1: value. |
| // A2: growable array. |
| ASSEMBLER_TEST_GENERATE(StoreIntoObject, assembler) { |
| __ addiu(SP, SP, Immediate(-2 * kWordSize)); |
| __ sw(CTX, Address(SP, 1 * kWordSize)); |
| __ sw(RA, Address(SP, 0 * kWordSize)); |
| |
| __ mov(CTX, A0); |
| __ StoreIntoObject(A2, |
| FieldAddress(A2, GrowableObjectArray::data_offset()), |
| A1); |
| __ lw(RA, Address(SP, 0 * kWordSize)); |
| __ lw(CTX, Address(SP, 1 * kWordSize)); |
| __ addiu(SP, SP, Immediate(2 * kWordSize)); |
| __ Ret(); |
| } |
| |
| } // namespace dart |
| |
| #endif // defined TARGET_ARCH_MIPS |