| OLD | NEW |
| 1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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 <stdint.h> | 5 #include <stdint.h> |
| 6 #include "src/base/build_config.h" | 6 #include "src/base/build_config.h" |
| 7 #include "src/base/platform/platform.h" | 7 #include "src/base/platform/platform.h" |
| 8 #include "test/cctest/cctest.h" | 8 #include "test/cctest/cctest.h" |
| 9 | 9 |
| 10 #ifdef V8_CC_GNU | 10 #ifdef V8_CC_GNU |
| 11 | 11 |
| 12 static uintptr_t sp_addr = 0; | 12 static uintptr_t sp_addr = 0; |
| 13 | 13 |
| 14 void GetStackPointer(const v8::FunctionCallbackInfo<v8::Value>& args) { | 14 void GetStackPointer(const v8::FunctionCallbackInfo<v8::Value>& args) { |
| 15 #if V8_HOST_ARCH_X64 | 15 #if V8_HOST_ARCH_X64 |
| 16 __asm__ __volatile__("mov %%rsp, %0" : "=g"(sp_addr)); | 16 __asm__ __volatile__("mov %%rsp, %0" : "=g"(sp_addr)); |
| 17 #elif V8_HOST_ARCH_IA32 | 17 #elif V8_HOST_ARCH_IA32 |
| 18 __asm__ __volatile__("mov %%esp, %0" : "=g"(sp_addr)); | 18 __asm__ __volatile__("mov %%esp, %0" : "=g"(sp_addr)); |
| 19 #elif V8_HOST_ARCH_ARM | 19 #elif V8_HOST_ARCH_ARM |
| 20 __asm__ __volatile__("str %%sp, %0" : "=g"(sp_addr)); | 20 __asm__ __volatile__("str sp, %0" : "=g"(sp_addr)); |
| 21 #elif V8_HOST_ARCH_ARM64 | 21 #elif V8_HOST_ARCH_ARM64 |
| 22 __asm__ __volatile__("mov x16, sp; str x16, %0" : "=g"(sp_addr)); | 22 __asm__ __volatile__("mov x16, sp; str x16, %0" : "=g"(sp_addr)); |
| 23 #elif V8_HOST_ARCH_MIPS | 23 #elif V8_HOST_ARCH_MIPS |
| 24 __asm__ __volatile__("sw $sp, %0" : "=g"(sp_addr)); | 24 __asm__ __volatile__("sw $sp, %0" : "=g"(sp_addr)); |
| 25 #elif V8_HOST_ARCH_MIPS64 | 25 #elif V8_HOST_ARCH_MIPS64 |
| 26 __asm__ __volatile__("sd $sp, %0" : "=g"(sp_addr)); | 26 __asm__ __volatile__("sd $sp, %0" : "=g"(sp_addr)); |
| 27 #elif defined(__s390x__) || defined(_ARCH_S390X) | 27 #elif defined(__s390x__) || defined(_ARCH_S390X) |
| 28 __asm__ __volatile__("stg 15, %0" : "=g"(sp_addr)); | 28 __asm__ __volatile__("stg 15, %0" : "=g"(sp_addr)); |
| 29 #elif defined(__s390__) || defined(_ARCH_S390) | 29 #elif defined(__s390__) || defined(_ARCH_S390) |
| 30 __asm__ __volatile__("st 15, %0" : "=g"(sp_addr)); | 30 __asm__ __volatile__("st 15, %0" : "=g"(sp_addr)); |
| (...skipping 30 matching lines...) Expand all Loading... |
| 61 .ToLocalChecked()); | 61 .ToLocalChecked()); |
| 62 | 62 |
| 63 v8::Local<v8::Value> result = | 63 v8::Local<v8::Value> result = |
| 64 foo->Call(isolate->GetCurrentContext(), global_object, 0, NULL) | 64 foo->Call(isolate->GetCurrentContext(), global_object, 0, NULL) |
| 65 .ToLocalChecked(); | 65 .ToLocalChecked(); |
| 66 CHECK_EQ(0u, result->Uint32Value(isolate->GetCurrentContext()).FromJust() % | 66 CHECK_EQ(0u, result->Uint32Value(isolate->GetCurrentContext()).FromJust() % |
| 67 v8::base::OS::ActivationFrameAlignment()); | 67 v8::base::OS::ActivationFrameAlignment()); |
| 68 } | 68 } |
| 69 | 69 |
| 70 #endif // V8_CC_GNU | 70 #endif // V8_CC_GNU |
| OLD | NEW |