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

Side by Side Diff: src/ia32/register-allocator-ia32.cc

Issue 668151: Make more use of the NumberInfo data.... (Closed) Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/
Patch Set: '' Created 10 years, 9 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
OLDNEW
1 // Copyright 2008 the V8 project authors. All rights reserved. 1 // Copyright 2008 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 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
42 if (is_constant()) { 42 if (is_constant()) {
43 Result fresh = CodeGeneratorScope::Current()->allocator()->Allocate(); 43 Result fresh = CodeGeneratorScope::Current()->allocator()->Allocate();
44 ASSERT(fresh.is_valid()); 44 ASSERT(fresh.is_valid());
45 if (CodeGeneratorScope::Current()->IsUnsafeSmi(handle())) { 45 if (CodeGeneratorScope::Current()->IsUnsafeSmi(handle())) {
46 CodeGeneratorScope::Current()->MoveUnsafeSmi(fresh.reg(), handle()); 46 CodeGeneratorScope::Current()->MoveUnsafeSmi(fresh.reg(), handle());
47 } else { 47 } else {
48 CodeGeneratorScope::Current()->masm()->Set(fresh.reg(), 48 CodeGeneratorScope::Current()->masm()->Set(fresh.reg(),
49 Immediate(handle())); 49 Immediate(handle()));
50 } 50 }
51 // This result becomes a copy of the fresh one. 51 // This result becomes a copy of the fresh one.
52 fresh.set_number_info(number_info());
52 *this = fresh; 53 *this = fresh;
53 } 54 }
54 ASSERT(is_register()); 55 ASSERT(is_register());
55 } 56 }
56 57
57 58
58 void Result::ToRegister(Register target) { 59 void Result::ToRegister(Register target) {
59 ASSERT(is_valid()); 60 ASSERT(is_valid());
60 if (!is_register() || !reg().is(target)) { 61 if (!is_register() || !reg().is(target)) {
61 Result fresh = CodeGeneratorScope::Current()->allocator()->Allocate(target); 62 Result fresh = CodeGeneratorScope::Current()->allocator()->Allocate(target);
(...skipping 29 matching lines...) Expand all
91 // register if valid and return an invalid result. 92 // register if valid and return an invalid result.
92 if (result.is_valid() && !result.reg().is_byte_register()) { 93 if (result.is_valid() && !result.reg().is_byte_register()) {
93 result.Unuse(); 94 result.Unuse();
94 return Result(); 95 return Result();
95 } 96 }
96 return result; 97 return result;
97 } 98 }
98 99
99 100
100 } } // namespace v8::internal 101 } } // namespace v8::internal
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698