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

Side by Side Diff: src/mips64/simulator-mips64.h

Issue 1108583003: MIPS: Add rounding support in simulator and RINT instruction. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Addressed comments Created 5 years, 7 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
« no previous file with comments | « src/mips64/disasm-mips64.cc ('k') | src/mips64/simulator-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 2011 the V8 project authors. All rights reserved. 1 // Copyright 2011 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 5
6 // Declares a Simulator for MIPS instructions if we are not generating a native 6 // Declares a Simulator for MIPS instructions if we are not generating a native
7 // MIPS binary. This Simulator allows us to run and debug MIPS code generation 7 // MIPS binary. This Simulator allows us to run and debug MIPS code generation
8 // on regular desktop machines. 8 // on regular desktop machines.
9 // V8 calls into generated code by "calling" the CALL_GENERATED_CODE macro, 9 // V8 calls into generated code by "calling" the CALL_GENERATED_CODE macro,
10 // which will start execution in the Simulator or forwards to the real entry 10 // which will start execution in the Simulator or forwards to the real entry
(...skipping 189 matching lines...) Expand 10 before | Expand all | Expand 10 after
200 int64_t get_fpu_register(int fpureg) const; 200 int64_t get_fpu_register(int fpureg) const;
201 int32_t get_fpu_register_word(int fpureg) const; 201 int32_t get_fpu_register_word(int fpureg) const;
202 int32_t get_fpu_register_signed_word(int fpureg) const; 202 int32_t get_fpu_register_signed_word(int fpureg) const;
203 int32_t get_fpu_register_hi_word(int fpureg) const; 203 int32_t get_fpu_register_hi_word(int fpureg) const;
204 float get_fpu_register_float(int fpureg) const; 204 float get_fpu_register_float(int fpureg) const;
205 double get_fpu_register_double(int fpureg) const; 205 double get_fpu_register_double(int fpureg) const;
206 void set_fcsr_bit(uint32_t cc, bool value); 206 void set_fcsr_bit(uint32_t cc, bool value);
207 bool test_fcsr_bit(uint32_t cc); 207 bool test_fcsr_bit(uint32_t cc);
208 bool set_fcsr_round_error(double original, double rounded); 208 bool set_fcsr_round_error(double original, double rounded);
209 bool set_fcsr_round64_error(double original, double rounded); 209 bool set_fcsr_round64_error(double original, double rounded);
210 void round_according_to_fcsr(double toRound, double& rounded,
211 int32_t& rounded_int, double fs);
212 void round64_according_to_fcsr(double toRound, double& rounded,
213 int64_t& rounded_int, double fs);
210 214
211 // Special case of set_register and get_register to access the raw PC value. 215 // Special case of set_register and get_register to access the raw PC value.
212 void set_pc(int64_t value); 216 void set_pc(int64_t value);
213 int64_t get_pc() const; 217 int64_t get_pc() const;
214 218
215 Address get_sp() { 219 Address get_sp() {
216 return reinterpret_cast<Address>(static_cast<intptr_t>(get_register(sp))); 220 return reinterpret_cast<Address>(static_cast<intptr_t>(get_register(sp)));
217 } 221 }
218 222
219 // Accessor to the internal simulator stack area. 223 // Accessor to the internal simulator stack area.
(...skipping 292 matching lines...) Expand 10 before | Expand all | Expand 10 after
512 516
513 static inline void UnregisterCTryCatch() { 517 static inline void UnregisterCTryCatch() {
514 Simulator::current(Isolate::Current())->PopAddress(); 518 Simulator::current(Isolate::Current())->PopAddress();
515 } 519 }
516 }; 520 };
517 521
518 } } // namespace v8::internal 522 } } // namespace v8::internal
519 523
520 #endif // !defined(USE_SIMULATOR) 524 #endif // !defined(USE_SIMULATOR)
521 #endif // V8_MIPS_SIMULATOR_MIPS_H_ 525 #endif // V8_MIPS_SIMULATOR_MIPS_H_
OLDNEW
« no previous file with comments | « src/mips64/disasm-mips64.cc ('k') | src/mips64/simulator-mips64.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698