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

Side by Side Diff: test/cctest/test-api.cc

Issue 371923006: Add mips64 port. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Rebase Created 6 years, 5 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « test/cctest/cctest.status ('k') | test/cctest/test-assembler-mips64.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 the V8 project authors. All rights reserved. 1 // Copyright 2012 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without 2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are 3 // modification, are permitted provided that the following conditions are
4 // met: 4 // met:
5 // 5 //
6 // * Redistributions of source code must retain the above copyright 6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer. 7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above 8 // * Redistributions in binary form must reproduce the above
9 // copyright notice, this list of conditions and the following 9 // copyright notice, this list of conditions and the following
10 // disclaimer in the documentation and/or other materials provided 10 // disclaimer in the documentation and/or other materials provided
(...skipping 18107 matching lines...) Expand 10 before | Expand all | Expand 10 after
18118 double test_value = test_values[i]; 18118 double test_value = test_values[i];
18119 18119
18120 // Check that Number::New preserves non-NaNs and quiets SNaNs. 18120 // Check that Number::New preserves non-NaNs and quiets SNaNs.
18121 v8::Handle<v8::Value> number = v8::Number::New(isolate, test_value); 18121 v8::Handle<v8::Value> number = v8::Number::New(isolate, test_value);
18122 double stored_number = number->NumberValue(); 18122 double stored_number = number->NumberValue();
18123 if (!std::isnan(test_value)) { 18123 if (!std::isnan(test_value)) {
18124 CHECK_EQ(test_value, stored_number); 18124 CHECK_EQ(test_value, stored_number);
18125 } else { 18125 } else {
18126 uint64_t stored_bits = DoubleToBits(stored_number); 18126 uint64_t stored_bits = DoubleToBits(stored_number);
18127 // Check if quiet nan (bits 51..62 all set). 18127 // Check if quiet nan (bits 51..62 all set).
18128 #if defined(V8_TARGET_ARCH_MIPS) && !defined(USE_SIMULATOR) 18128 #if (defined(V8_TARGET_ARCH_MIPS) || defined(V8_TARGET_ARCH_MIPS64)) && \
18129 !defined(USE_SIMULATOR)
18129 // Most significant fraction bit for quiet nan is set to 0 18130 // Most significant fraction bit for quiet nan is set to 0
18130 // on MIPS architecture. Allowed by IEEE-754. 18131 // on MIPS architecture. Allowed by IEEE-754.
18131 CHECK_EQ(0xffe, static_cast<int>((stored_bits >> 51) & 0xfff)); 18132 CHECK_EQ(0xffe, static_cast<int>((stored_bits >> 51) & 0xfff));
18132 #else 18133 #else
18133 CHECK_EQ(0xfff, static_cast<int>((stored_bits >> 51) & 0xfff)); 18134 CHECK_EQ(0xfff, static_cast<int>((stored_bits >> 51) & 0xfff));
18134 #endif 18135 #endif
18135 } 18136 }
18136 18137
18137 // Check that Date::New preserves non-NaNs in the date range and 18138 // Check that Date::New preserves non-NaNs in the date range and
18138 // quiets SNaNs. 18139 // quiets SNaNs.
18139 v8::Handle<v8::Value> date = 18140 v8::Handle<v8::Value> date =
18140 v8::Date::New(isolate, test_value); 18141 v8::Date::New(isolate, test_value);
18141 double expected_stored_date = DoubleToDateTime(test_value); 18142 double expected_stored_date = DoubleToDateTime(test_value);
18142 double stored_date = date->NumberValue(); 18143 double stored_date = date->NumberValue();
18143 if (!std::isnan(expected_stored_date)) { 18144 if (!std::isnan(expected_stored_date)) {
18144 CHECK_EQ(expected_stored_date, stored_date); 18145 CHECK_EQ(expected_stored_date, stored_date);
18145 } else { 18146 } else {
18146 uint64_t stored_bits = DoubleToBits(stored_date); 18147 uint64_t stored_bits = DoubleToBits(stored_date);
18147 // Check if quiet nan (bits 51..62 all set). 18148 // Check if quiet nan (bits 51..62 all set).
18148 #if defined(V8_TARGET_ARCH_MIPS) && !defined(USE_SIMULATOR) 18149 #if (defined(V8_TARGET_ARCH_MIPS) || defined(V8_TARGET_ARCH_MIPS64)) && \
18150 !defined(USE_SIMULATOR)
18149 // Most significant fraction bit for quiet nan is set to 0 18151 // Most significant fraction bit for quiet nan is set to 0
18150 // on MIPS architecture. Allowed by IEEE-754. 18152 // on MIPS architecture. Allowed by IEEE-754.
18151 CHECK_EQ(0xffe, static_cast<int>((stored_bits >> 51) & 0xfff)); 18153 CHECK_EQ(0xffe, static_cast<int>((stored_bits >> 51) & 0xfff));
18152 #else 18154 #else
18153 CHECK_EQ(0xfff, static_cast<int>((stored_bits >> 51) & 0xfff)); 18155 CHECK_EQ(0xfff, static_cast<int>((stored_bits >> 51) & 0xfff));
18154 #endif 18156 #endif
18155 } 18157 }
18156 } 18158 }
18157 } 18159 }
18158 18160
(...skipping 4730 matching lines...) Expand 10 before | Expand all | Expand 10 after
22889 desc = x->GetOwnPropertyDescriptor(v8_str("p1")); 22891 desc = x->GetOwnPropertyDescriptor(v8_str("p1"));
22890 Local<Function> set = 22892 Local<Function> set =
22891 Local<Function>::Cast(Local<Object>::Cast(desc)->Get(v8_str("set"))); 22893 Local<Function>::Cast(Local<Object>::Cast(desc)->Get(v8_str("set")));
22892 Local<Function> get = 22894 Local<Function> get =
22893 Local<Function>::Cast(Local<Object>::Cast(desc)->Get(v8_str("get"))); 22895 Local<Function>::Cast(Local<Object>::Cast(desc)->Get(v8_str("get")));
22894 CHECK_EQ(v8_num(13), get->Call(x, 0, NULL)); 22896 CHECK_EQ(v8_num(13), get->Call(x, 0, NULL));
22895 Handle<Value> args[] = { v8_num(14) }; 22897 Handle<Value> args[] = { v8_num(14) };
22896 set->Call(x, 1, args); 22898 set->Call(x, 1, args);
22897 CHECK_EQ(v8_num(14), get->Call(x, 0, NULL)); 22899 CHECK_EQ(v8_num(14), get->Call(x, 0, NULL));
22898 } 22900 }
OLDNEW
« no previous file with comments | « test/cctest/cctest.status ('k') | test/cctest/test-assembler-mips64.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698