mirror of
https://github.com/chromium/crashpad.git
synced 2025-01-14 17:30:09 +08:00
4f5dd67229
Only RV64GC is supported. Bug: fuchsia:127655 Tested: `python build/run_tests.py` on RISC-V emulator Tested: Created minidump via self-induced crash on RISC-V emulator, ran through Breakpad stackwalker Change-Id: I713797cd623b0a758269048e01696cbce502ca6c Reviewed-on: https://chromium-review.googlesource.com/c/crashpad/crashpad/+/4581050 Reviewed-by: Joshua Peraza <jperaza@chromium.org>
62 lines
1.8 KiB
C++
62 lines
1.8 KiB
C++
// Copyright 2017 The Crashpad Authors
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#include "test/linux/get_tls.h"
|
|
|
|
#include "build/build_config.h"
|
|
#include "util/misc/from_pointer_cast.h"
|
|
|
|
namespace crashpad {
|
|
namespace test {
|
|
|
|
LinuxVMAddress GetTLS() {
|
|
LinuxVMAddress tls;
|
|
#if defined(ARCH_CPU_ARMEL)
|
|
// 0xffff0fe0 is the address of the kernel user helper __kuser_get_tls().
|
|
auto kuser_get_tls = reinterpret_cast<void* (*)()>(0xffff0fe0);
|
|
tls = FromPointerCast<LinuxVMAddress>(kuser_get_tls());
|
|
#elif defined(ARCH_CPU_ARM64)
|
|
// Linux/aarch64 places the tls address in system register tpidr_el0.
|
|
asm("mrs %0, tpidr_el0" : "=r"(tls));
|
|
#elif defined(ARCH_CPU_X86)
|
|
uint32_t tls_32;
|
|
asm("movl %%gs:0x0, %0" : "=r"(tls_32));
|
|
tls = tls_32;
|
|
#elif defined(ARCH_CPU_X86_64)
|
|
asm("movq %%fs:0x0, %0" : "=r"(tls));
|
|
#elif defined(ARCH_CPU_MIPSEL)
|
|
uint32_t tls_32;
|
|
asm("rdhwr $3,$29\n\t"
|
|
"move %0,$3\n\t"
|
|
: "=r"(tls_32)
|
|
:
|
|
: "$3");
|
|
tls = tls_32;
|
|
#elif defined(ARCH_CPU_MIPS64EL)
|
|
asm("rdhwr $3,$29\n\t"
|
|
"move %0,$3\n\t"
|
|
: "=r"(tls)
|
|
:
|
|
: "$3");
|
|
#elif defined(ARCH_CPU_RISCV64)
|
|
asm("mv %0, tp" : "=r"(tls));
|
|
#else
|
|
#error Port.
|
|
#endif // ARCH_CPU_ARMEL
|
|
return tls;
|
|
}
|
|
|
|
} // namespace test
|
|
} // namespace crashpad
|