Commit 5428e036 authored by whesse@chromium.org's avatar whesse@chromium.org

Make ARM assembler VFP3 test pass on machines without VFP3 floating point hardware.

Review URL: http://codereview.chromium.org/543187

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@3691 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent bfcbc10c
...@@ -242,7 +242,6 @@ TEST(4) { ...@@ -242,7 +242,6 @@ TEST(4) {
Label L, C; Label L, C;
ASSERT(CpuFeatures::IsSupported(VFP3));
if (CpuFeatures::IsSupported(VFP3)) { if (CpuFeatures::IsSupported(VFP3)) {
CpuFeatures::Scope scope(VFP3); CpuFeatures::Scope scope(VFP3);
...@@ -261,26 +260,27 @@ TEST(4) { ...@@ -261,26 +260,27 @@ TEST(4) {
__ vstr(d4, r4, OFFSET_OF(T, b)); __ vstr(d4, r4, OFFSET_OF(T, b));
__ ldm(ia_w, sp, r4.bit() | fp.bit() | pc.bit()); __ ldm(ia_w, sp, r4.bit() | fp.bit() | pc.bit());
}
CodeDesc desc; CodeDesc desc;
assm.GetCode(&desc); assm.GetCode(&desc);
Object* code = Heap::CreateCode(desc, Object* code = Heap::CreateCode(desc,
NULL, NULL,
Code::ComputeFlags(Code::STUB), Code::ComputeFlags(Code::STUB),
Handle<Object>(Heap::undefined_value())); Handle<Object>(Heap::undefined_value()));
CHECK(code->IsCode()); CHECK(code->IsCode());
#ifdef DEBUG #ifdef DEBUG
Code::cast(code)->Print(); Code::cast(code)->Print();
#endif #endif
F3 f = FUNCTION_CAST<F3>(Code::cast(code)->entry()); F3 f = FUNCTION_CAST<F3>(Code::cast(code)->entry());
t.a = 1.5; t.a = 1.5;
t.b = 2.75; t.b = 2.75;
t.c = 17.17; t.c = 17.17;
Object* dummy = CALL_GENERATED_CODE(f, &t, 0, 0, 0, 0); Object* dummy = CALL_GENERATED_CODE(f, &t, 0, 0, 0, 0);
USE(dummy); USE(dummy);
CHECK_EQ(4.25, t.c); CHECK_EQ(4.25, t.c);
CHECK_EQ(4.25, t.b); CHECK_EQ(4.25, t.b);
CHECK_EQ(1.5, t.a); CHECK_EQ(1.5, t.a);
}
} }
#undef __ #undef __
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment