namespace internal {
+static SaveFPRegsMode GetSaveFPRegsMode() {
+ // We don't need to save floating point regs when generating the snapshot
+ return CpuFeatures::IsSafeForSnapshot(VFP32DREGS)
+ ? kSaveFPRegs
+ : kDontSaveFPRegs;
+}
+
+
class SafepointGenerator : public CallWrapper {
public:
SafepointGenerator(LCodeGen* codegen,
__ str(r0, target);
// Update the write barrier. This clobbers r3 and r0.
__ RecordWriteContextSlot(
- cp, target.offset(), r0, r3, GetLinkRegisterState(), kSaveFPRegs);
+ cp,
+ target.offset(),
+ r0,
+ r3,
+ GetLinkRegisterState(),
+ GetSaveFPRegsMode());
}
}
Comment(";;; End allocate local context");
value,
scratch,
GetLinkRegisterState(),
- kSaveFPRegs,
+ GetSaveFPRegsMode(),
EMIT_REMEMBERED_SET,
check_needed);
}
scratch,
temp,
GetLinkRegisterState(),
- kSaveFPRegs,
+ GetSaveFPRegsMode(),
OMIT_REMEMBERED_SET,
OMIT_SMI_CHECK);
}
value,
scratch,
GetLinkRegisterState(),
- kSaveFPRegs,
+ GetSaveFPRegsMode(),
EMIT_REMEMBERED_SET,
check_needed);
}
value,
object,
GetLinkRegisterState(),
- kSaveFPRegs,
+ GetSaveFPRegsMode(),
EMIT_REMEMBERED_SET,
check_needed);
}
key,
value,
GetLinkRegisterState(),
- kSaveFPRegs,
+ GetSaveFPRegsMode(),
EMIT_REMEMBERED_SET,
check_needed);
}