summaryrefslogtreecommitdiff
path: root/compiler/optimizing/common_arm64.h
diff options
context:
space:
mode:
author Nicolas Geoffray <ngeoffray@google.com> 2015-07-07 10:48:12 +0000
committer Gerrit Code Review <noreply-gerritcodereview@google.com> 2015-07-07 10:48:13 +0000
commitee35ff809616324cbada38cbc0610eb09da09b35 (patch)
tree5271ee1feba1a86905fede5b9d9c1cba444ba01c /compiler/optimizing/common_arm64.h
parent00dec6a9506364806227f21f6a053176a6723fe9 (diff)
parent82000b0cf9bb32fc55cdb125bf37c884d44a8671 (diff)
Merge "Improve code generation for ARM64 VisitArrayGet/Set."
Diffstat (limited to 'compiler/optimizing/common_arm64.h')
-rw-r--r--compiler/optimizing/common_arm64.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/compiler/optimizing/common_arm64.h b/compiler/optimizing/common_arm64.h
index 246fff99ac..f54547534f 100644
--- a/compiler/optimizing/common_arm64.h
+++ b/compiler/optimizing/common_arm64.h
@@ -151,6 +151,15 @@ static inline vixl::MemOperand HeapOperand(const vixl::Register& base, size_t of
return vixl::MemOperand(base.X(), offset);
}
+static inline vixl::MemOperand HeapOperand(const vixl::Register& base,
+ const vixl::Register& regoffset,
+ vixl::Shift shift = vixl::LSL,
+ unsigned shift_amount = 0) {
+ // A heap reference must be 32bit, so fit in a W register.
+ DCHECK(base.IsW());
+ return vixl::MemOperand(base.X(), regoffset, shift, shift_amount);
+}
+
static inline vixl::MemOperand HeapOperand(const vixl::Register& base, Offset offset) {
return HeapOperand(base, offset.SizeValue());
}