| Index: runtime/vm/assembler_arm64_test.cc
|
| diff --git a/runtime/vm/assembler_arm64_test.cc b/runtime/vm/assembler_arm64_test.cc
|
| index 624a950e717bddb4bfab28bd343bdac7f041024c..566a9a323ae669fb12df34e2814cc79462fd1359 100644
|
| --- a/runtime/vm/assembler_arm64_test.cc
|
| +++ b/runtime/vm/assembler_arm64_test.cc
|
| @@ -580,7 +580,7 @@ ASSEMBLER_TEST_GENERATE(Semaphore, assembler) {
|
|
|
| ASSEMBLER_TEST_RUN(Semaphore, test) {
|
| EXPECT(test != NULL);
|
| - typedef intptr_t (*Semaphore)() DART_UNUSED;
|
| + typedef int (*Semaphore)() DART_UNUSED;
|
| EXPECT_EQ(42, EXECUTE_TEST_CODE_INT64(Semaphore, test->entry()));
|
| }
|
|
|
| @@ -602,73 +602,11 @@ ASSEMBLER_TEST_GENERATE(FailedSemaphore, assembler) {
|
|
|
| ASSEMBLER_TEST_RUN(FailedSemaphore, test) {
|
| EXPECT(test != NULL);
|
| - typedef intptr_t (*FailedSemaphore)() DART_UNUSED;
|
| + typedef int (*FailedSemaphore)() DART_UNUSED;
|
| EXPECT_EQ(41, EXECUTE_TEST_CODE_INT64(FailedSemaphore, test->entry()));
|
| }
|
|
|
|
|
| -ASSEMBLER_TEST_GENERATE(Semaphore32, assembler) {
|
| - __ SetupDartSP();
|
| - __ movz(R0, Immediate(40), 0);
|
| - __ add(R0, R0, Operand(R0, LSL, 32));
|
| - __ Push(R0);
|
| -
|
| - __ movz(R0, Immediate(40), 0);
|
| - __ movz(R1, Immediate(42), 0);
|
| -
|
| - Label retry;
|
| - __ Bind(&retry);
|
| - __ ldxr(R0, SP, kWord);
|
| - // 32 bit operation should ignore the high word of R0 that was pushed on the
|
| - // stack.
|
| - __ stxr(TMP, R1, SP, kWord); // IP == 0, success
|
| - __ cmp(TMP, Operand(0));
|
| - __ b(&retry, NE); // NE if context switch occurred between ldrex and strex.
|
| - __ Pop(R0); // 42 + 42 * 2**32
|
| - __ RestoreCSP();
|
| - __ ret();
|
| -}
|
| -
|
| -
|
| -ASSEMBLER_TEST_RUN(Semaphore32, test) {
|
| - EXPECT(test != NULL);
|
| - typedef intptr_t (*Semaphore32)() DART_UNUSED;
|
| - // Lower word has been atomically switched from 40 to 42k, whereas upper word
|
| - // is unchanged at 40.
|
| - EXPECT_EQ(42 + (40l << 32),
|
| - EXECUTE_TEST_CODE_INT64(Semaphore32, test->entry()));
|
| -}
|
| -
|
| -
|
| -ASSEMBLER_TEST_GENERATE(FailedSemaphore32, assembler) {
|
| - __ SetupDartSP();
|
| - __ movz(R0, Immediate(40), 0);
|
| - __ add(R0, R0, Operand(R0, LSL, 32));
|
| - __ Push(R0);
|
| -
|
| - __ movz(R0, Immediate(40), 0);
|
| - __ movz(R1, Immediate(42), 0);
|
| -
|
| - __ ldxr(R0, SP, kWord);
|
| - __ clrex(); // Simulate a context switch.
|
| - __ stxr(TMP, R1, SP, kWord); // IP == 1, failure
|
| - __ Pop(R0); // 40
|
| - __ add(R0, R0, Operand(TMP));
|
| - __ RestoreCSP();
|
| - __ ret();
|
| -}
|
| -
|
| -
|
| -ASSEMBLER_TEST_RUN(FailedSemaphore32, test) {
|
| - EXPECT(test != NULL);
|
| - typedef intptr_t (*FailedSemaphore32)() DART_UNUSED;
|
| - // Lower word has had the failure code (1) added to it. Upper word is
|
| - // unchanged at 40.
|
| - EXPECT_EQ(41 + (40l << 32),
|
| - EXECUTE_TEST_CODE_INT64(FailedSemaphore32, test->entry()));
|
| -}
|
| -
|
| -
|
| // Logical register operations.
|
| ASSEMBLER_TEST_GENERATE(AndRegs, assembler) {
|
| __ movz(R1, Immediate(43), 0);
|
|
|