Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(67)

Unified Diff: src/compiler/arm64/code-generator-arm64.cc

Issue 1191513003: [turbofan] Add CalleeSavedFPRegisters to CallDescriptor. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Added ports (except ppc). Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: src/compiler/arm64/code-generator-arm64.cc
diff --git a/src/compiler/arm64/code-generator-arm64.cc b/src/compiler/arm64/code-generator-arm64.cc
index 831627dde5cfed8553a8f036e2b53008a78a3bc1..930411e3b3720c89b87129e2482699ca87995ad8 100644
--- a/src/compiler/arm64/code-generator-arm64.cc
+++ b/src/compiler/arm64/code-generator-arm64.cc
@@ -1077,9 +1077,46 @@ void CodeGenerator::AssemblePrologue() {
__ SetStackPointer(csp);
__ Push(lr, fp);
__ Mov(fp, csp);
- // TODO(dcarney): correct callee saved registers.
- __ PushCalleeSavedRegisters();
- frame()->SetRegisterSaveAreaSize(20 * kPointerSize);
+
+ // Save registers.
paul.l... 2015/06/23 02:15:02 This looks a bit messy to me, but luckily there ar
akos.palfi.imgtec 2015/06/23 19:48:57 Thanks, it's much cleaner now.
+ MemOperand tos(csp, -2 * static_cast<int>(kXRegSize), PreIndex);
+ int saved_count = 0;
+ const RegList saves_fp = descriptor->CalleeSavedFPRegisters();
+ if (saves_fp != 0) {
+ // Save callee-saved FP registers.
+ int prev_reg = -1;
+ for (int i = FPRegister::kMaxNumRegisters - 1; i >= 0; i--) {
+ if (((1 << i) & saves_fp)) {
+ if (prev_reg != -1) {
+ __ stp(FPRegister::from_code(i), FPRegister::from_code(prev_reg),
+ tos);
+ saved_count += 2;
+ prev_reg = -1;
+ } else {
+ prev_reg = i;
+ }
+ }
+ }
+ CHECK(prev_reg == -1);
+ }
+ const RegList saves = descriptor->CalleeSavedRegisters();
+ if (saves != 0) {
+ // Save callee-saved registers.
+ int prev_reg = -1;
+ for (int i = Register::kNumRegisters - 1; i >= 0; i--) {
+ if (((1 << i) & saves)) {
+ if (prev_reg != -1) {
+ __ stp(Register::from_code(i), Register::from_code(prev_reg), tos);
+ saved_count += 2;
+ prev_reg = -1;
+ } else {
+ prev_reg = i;
+ }
+ }
+ }
+ CHECK(prev_reg == -1);
+ }
+ frame()->SetRegisterSaveAreaSize(saved_count * kPointerSize);
} else if (descriptor->IsJSFunctionCall()) {
CompilationInfo* info = this->info();
__ SetStackPointer(jssp);
@@ -1128,10 +1165,45 @@ void CodeGenerator::AssembleReturn() {
if (stack_slots > 0) {
__ Add(csp, csp, AlignedStackSlots(stack_slots) * kPointerSize);
}
+
// Restore registers.
- // TODO(dcarney): correct callee saved registers.
- __ PopCalleeSavedRegisters();
+ MemOperand tos(csp, 2 * kXRegSize, PostIndex);
+ const RegList saves = descriptor->CalleeSavedRegisters();
+ if (saves != 0) {
+ // Restore callee-saved registers.
+ int prev_reg = -1;
+ for (int i = 0; i < Register::kNumRegisters; i++) {
+ if (((1 << i) & saves)) {
+ if (prev_reg != -1) {
+ __ ldp(Register::from_code(prev_reg), Register::from_code(i),
+ tos);
+ prev_reg = -1;
+ } else {
+ prev_reg = i;
+ }
+ }
+ }
+ CHECK(prev_reg == -1);
+ }
+ const RegList saves_fp = descriptor->CalleeSavedFPRegisters();
+ if (saves_fp != 0) {
+ // Restore callee-saved FP registers.
+ int prev_reg = -1;
+ for (int i = 0; i < FPRegister::kMaxNumRegisters; i++) {
+ if (((1 << i) & saves_fp)) {
+ if (prev_reg != -1) {
+ __ ldp(FPRegister::from_code(prev_reg), FPRegister::from_code(i),
+ tos);
+ prev_reg = -1;
+ } else {
+ prev_reg = i;
+ }
+ }
+ }
+ CHECK(prev_reg == -1);
+ }
}
+
__ Mov(csp, fp);
__ Pop(fp, lr);
__ Ret();

Powered by Google App Engine
This is Rietveld 408576698