| Index: src/arm64/eh-frame-arm64.cc
|
| diff --git a/src/arm64/eh-frame-arm64.cc b/src/arm64/eh-frame-arm64.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..e207a39c040a9d15cf1d309a51650c8f71fd515c
|
| --- /dev/null
|
| +++ b/src/arm64/eh-frame-arm64.cc
|
| @@ -0,0 +1,64 @@
|
| +// Copyright 2016 the V8 project authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "src/eh-frame.h"
|
| +
|
| +namespace v8 {
|
| +namespace internal {
|
| +
|
| +static const int kX0DwarfCode = 0;
|
| +static const int kFpDwarfCode = 29;
|
| +static const int kLrDwarfCode = 30;
|
| +static const int kSpDwarfCode = 31;
|
| +
|
| +STATIC_CONST_MEMBER_DEFINITION const int EhFrameWriter::kDataAlignmentFactor =
|
| + -8;
|
| +
|
| +void EhFrameWriter::WriteReturnAddressRegisterCode() {
|
| + WriteULEB128(kLrDwarfCode);
|
| +}
|
| +
|
| +void EhFrameWriter::WriteInitialStateInCIE() {
|
| + SetBaseAddressRegisterAndOffset(x29, 0);
|
| + RecordRegisterIsValid(x30);
|
| +}
|
| +
|
| +// static
|
| +int EhFrameWriter::RegisterToDwarfCode(Register name) {
|
| + switch (name.code()) {
|
| + case Register::kCode_x29:
|
| + return kFpDwarfCode;
|
| + case Register::kCode_x30:
|
| + return kLrDwarfCode;
|
| + case Register::kCode_x31:
|
| + return kSpDwarfCode;
|
| + case Register::kCode_x0:
|
| + return kX0DwarfCode;
|
| + default:
|
| + UNIMPLEMENTED();
|
| + return -1;
|
| + }
|
| +}
|
| +
|
| +#ifdef ENABLE_DISASSEMBLER
|
| +
|
| +// static
|
| +const char* EhFrameDisassembler::DwarfRegisterCodeToString(int code) {
|
| + switch (code) {
|
| + case kFpDwarfCode:
|
| + return "fp";
|
| + case kLrDwarfCode:
|
| + return "lr";
|
| + case kSpDwarfCode:
|
| + return "sp"; // This could be zr as well
|
| + default:
|
| + UNIMPLEMENTED();
|
| + return nullptr;
|
| + }
|
| +}
|
| +
|
| +#endif
|
| +
|
| +} // namespace internal
|
| +} // namespace v8
|
|
|