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

Side by Side Diff: src/x64/code-stubs-x64.cc

Issue 18076002: Use macros instead of using number directly for x64 (Closed) Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/
Patch Set: Created 7 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 | « no previous file | src/x64/codegen-x64.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 1540 matching lines...) Expand 10 before | Expand all | Expand 10 after
1551 #ifdef DEBUG 1551 #ifdef DEBUG
1552 // Check that the layout of cache elements match expectations. 1552 // Check that the layout of cache elements match expectations.
1553 { // NOLINT - doesn't like a single brace on a line. 1553 { // NOLINT - doesn't like a single brace on a line.
1554 TranscendentalCache::SubCache::Element test_elem[2]; 1554 TranscendentalCache::SubCache::Element test_elem[2];
1555 char* elem_start = reinterpret_cast<char*>(&test_elem[0]); 1555 char* elem_start = reinterpret_cast<char*>(&test_elem[0]);
1556 char* elem2_start = reinterpret_cast<char*>(&test_elem[1]); 1556 char* elem2_start = reinterpret_cast<char*>(&test_elem[1]);
1557 char* elem_in0 = reinterpret_cast<char*>(&(test_elem[0].in[0])); 1557 char* elem_in0 = reinterpret_cast<char*>(&(test_elem[0].in[0]));
1558 char* elem_in1 = reinterpret_cast<char*>(&(test_elem[0].in[1])); 1558 char* elem_in1 = reinterpret_cast<char*>(&(test_elem[0].in[1]));
1559 char* elem_out = reinterpret_cast<char*>(&(test_elem[0].output)); 1559 char* elem_out = reinterpret_cast<char*>(&(test_elem[0].output));
1560 // Two uint_32's and a pointer per element. 1560 // Two uint_32's and a pointer per element.
1561 CHECK_EQ(16, static_cast<int>(elem2_start - elem_start)); 1561 CHECK_EQ(2 * kIntSize + 1 * kPointerSize,
1562 static_cast<int>(elem2_start - elem_start));
1562 CHECK_EQ(0, static_cast<int>(elem_in0 - elem_start)); 1563 CHECK_EQ(0, static_cast<int>(elem_in0 - elem_start));
1563 CHECK_EQ(kIntSize, static_cast<int>(elem_in1 - elem_start)); 1564 CHECK_EQ(kIntSize, static_cast<int>(elem_in1 - elem_start));
1564 CHECK_EQ(2 * kIntSize, static_cast<int>(elem_out - elem_start)); 1565 CHECK_EQ(2 * kIntSize, static_cast<int>(elem_out - elem_start));
1565 } 1566 }
1566 #endif 1567 #endif
1567 // Find the address of the rcx'th entry in the cache, i.e., &rax[rcx*16]. 1568 // Find the address of the rcx'th entry in the cache, i.e., &rax[rcx*16].
1568 __ addl(rcx, rcx); 1569 __ addl(rcx, rcx);
1569 __ lea(rcx, Operand(rax, rcx, times_8, 0)); 1570 __ lea(rcx, Operand(rax, rcx, times_8, 0));
1570 // Check if cache matches: Double value is stored in uint32_t[2] array. 1571 // Check if cache matches: Double value is stored in uint32_t[2] array.
1571 Label cache_miss; 1572 Label cache_miss;
(...skipping 3526 matching lines...) Expand 10 before | Expand all | Expand 10 after
5098 __ j(zero, &done, Label::kNear); 5099 __ j(zero, &done, Label::kNear);
5099 5100
5100 // Make count the number of bytes to copy. 5101 // Make count the number of bytes to copy.
5101 if (!ascii) { 5102 if (!ascii) {
5102 STATIC_ASSERT(2 == sizeof(uc16)); 5103 STATIC_ASSERT(2 == sizeof(uc16));
5103 __ addl(count, count); 5104 __ addl(count, count);
5104 } 5105 }
5105 5106
5106 // Don't enter the rep movs if there are less than 4 bytes to copy. 5107 // Don't enter the rep movs if there are less than 4 bytes to copy.
5107 Label last_bytes; 5108 Label last_bytes;
5108 __ testl(count, Immediate(~7)); 5109 __ testl(count, Immediate(~(kPointerSize - 1)));
5109 __ j(zero, &last_bytes, Label::kNear); 5110 __ j(zero, &last_bytes, Label::kNear);
5110 5111
5111 // Copy from edi to esi using rep movs instruction. 5112 // Copy from edi to esi using rep movs instruction.
5112 __ movl(kScratchRegister, count); 5113 __ movl(kScratchRegister, count);
5113 __ shr(count, Immediate(3)); // Number of doublewords to copy. 5114 __ shr(count, Immediate(kPointerSizeLog2)); // Number of doublewords to copy.
5114 __ repmovsq(); 5115 __ repmovsq();
5115 5116
5116 // Find number of bytes left. 5117 // Find number of bytes left.
5117 __ movl(count, kScratchRegister); 5118 __ movl(count, kScratchRegister);
5118 __ and_(count, Immediate(7)); 5119 __ and_(count, Immediate(kPointerSize - 1));
5119 5120
5120 // Check if there are more bytes to copy. 5121 // Check if there are more bytes to copy.
5121 __ bind(&last_bytes); 5122 __ bind(&last_bytes);
5122 __ testl(count, count); 5123 __ testl(count, count);
5123 __ j(zero, &done, Label::kNear); 5124 __ j(zero, &done, Label::kNear);
5124 5125
5125 // Copy remaining characters. 5126 // Copy remaining characters.
5126 Label loop; 5127 Label loop;
5127 __ bind(&loop); 5128 __ bind(&loop);
5128 __ movb(kScratchRegister, Operand(src, 0)); 5129 __ movb(kScratchRegister, Operand(src, 0));
(...skipping 1895 matching lines...) Expand 10 before | Expand all | Expand 10 after
7024 __ bind(&fast_elements_case); 7025 __ bind(&fast_elements_case);
7025 GenerateCase(masm, FAST_ELEMENTS); 7026 GenerateCase(masm, FAST_ELEMENTS);
7026 } 7027 }
7027 7028
7028 7029
7029 #undef __ 7030 #undef __
7030 7031
7031 } } // namespace v8::internal 7032 } } // namespace v8::internal
7032 7033
7033 #endif // V8_TARGET_ARCH_X64 7034 #endif // V8_TARGET_ARCH_X64
OLDNEW
« no previous file with comments | « no previous file | src/x64/codegen-x64.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698