mirror of
https://github.com/electron/electron.git
synced 2026-02-17 10:31:38 -05:00
76 lines
2.7 KiB
Diff
76 lines
2.7 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Richard Townsend <richard.townsend@arm.com>
|
|
Date: Wed, 24 Apr 2019 13:57:36 +0100
|
|
Subject: Workaround an undefined symbol error
|
|
|
|
Previously, builds configured with dcheck_always_on=true would error
|
|
with messages like this in the log:
|
|
lld-link: error: undefined symbol: public: bool __cdecl
|
|
v8::internal::CPURegister::IsZero(void) const
|
|
|
|
By moving some functions out of the the arm64-assembler header file,
|
|
this error no longer seems to happen.
|
|
|
|
diff --git a/src/codegen/arm64/assembler-arm64.cc b/src/codegen/arm64/assembler-arm64.cc
|
|
index 159e763ba2602639b4499af7b7869ead58b267d4..ac529e78a8a6ae8cffb0fef26e4bce9f258517ee 100644
|
|
--- a/src/codegen/arm64/assembler-arm64.cc
|
|
+++ b/src/codegen/arm64/assembler-arm64.cc
|
|
@@ -3564,6 +3564,22 @@ void Assembler::MoveWide(const Register& rd, uint64_t imm, int shift,
|
|
ImmMoveWide(static_cast<int>(imm)) | ShiftMoveWide(shift));
|
|
}
|
|
|
|
+Instr Assembler::RmNot31(CPURegister rm) {
|
|
+ DCHECK_NE(rm.code(), kSPRegInternalCode);
|
|
+ DCHECK(!rm.IsZero());
|
|
+ return Rm(rm);
|
|
+}
|
|
+
|
|
+Instr Assembler::RdSP(Register rd) {
|
|
+ DCHECK(!rd.IsZero());
|
|
+ return (rd.code() & kRegCodeMask) << Rd_offset;
|
|
+}
|
|
+
|
|
+Instr Assembler::RnSP(Register rn) {
|
|
+ DCHECK(!rn.IsZero());
|
|
+ return (rn.code() & kRegCodeMask) << Rn_offset;
|
|
+}
|
|
+
|
|
void Assembler::AddSub(const Register& rd, const Register& rn,
|
|
const Operand& operand, FlagsUpdate S, AddSubOp op) {
|
|
DCHECK_EQ(rd.SizeInBits(), rn.SizeInBits());
|
|
diff --git a/src/codegen/arm64/assembler-arm64.h b/src/codegen/arm64/assembler-arm64.h
|
|
index 6a6bf633c13ec6d94bbc145eae6daa9ce0d9b2ce..42a77d305b17ffaac6fd3f07c5290c1d61f31065 100644
|
|
--- a/src/codegen/arm64/assembler-arm64.h
|
|
+++ b/src/codegen/arm64/assembler-arm64.h
|
|
@@ -2079,11 +2079,7 @@ class V8_EXPORT_PRIVATE Assembler : public AssemblerBase {
|
|
return rm.code() << Rm_offset;
|
|
}
|
|
|
|
- static Instr RmNot31(CPURegister rm) {
|
|
- DCHECK_NE(rm.code(), kSPRegInternalCode);
|
|
- DCHECK(!rm.IsZero());
|
|
- return Rm(rm);
|
|
- }
|
|
+ static Instr RmNot31(CPURegister rm);
|
|
|
|
static Instr Ra(CPURegister ra) {
|
|
DCHECK_NE(ra.code(), kSPRegInternalCode);
|
|
@@ -2107,15 +2103,8 @@ class V8_EXPORT_PRIVATE Assembler : public AssemblerBase {
|
|
|
|
// These encoding functions allow the stack pointer to be encoded, and
|
|
// disallow the zero register.
|
|
- static Instr RdSP(Register rd) {
|
|
- DCHECK(!rd.IsZero());
|
|
- return (rd.code() & kRegCodeMask) << Rd_offset;
|
|
- }
|
|
-
|
|
- static Instr RnSP(Register rn) {
|
|
- DCHECK(!rn.IsZero());
|
|
- return (rn.code() & kRegCodeMask) << Rn_offset;
|
|
- }
|
|
+ static Instr RdSP(Register rd);
|
|
+ static Instr RnSP(Register rn);
|
|
|
|
// Flags encoding.
|
|
inline static Instr Flags(FlagsUpdate S);
|