| OLD | NEW |
| 1 // Copyright 2010 the V8 project authors. All rights reserved. | 1 // Copyright 2010 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 7018 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 7029 Register right_arg = eax; | 7029 Register right_arg = eax; |
| 7030 if (!(left.is(left_arg) && right.is(right_arg))) { | 7030 if (!(left.is(left_arg) && right.is(right_arg))) { |
| 7031 if (left.is(right_arg) && right.is(left_arg)) { | 7031 if (left.is(right_arg) && right.is(left_arg)) { |
| 7032 if (IsOperationCommutative()) { | 7032 if (IsOperationCommutative()) { |
| 7033 SetArgsReversed(); | 7033 SetArgsReversed(); |
| 7034 } else { | 7034 } else { |
| 7035 __ xchg(left, right); | 7035 __ xchg(left, right); |
| 7036 } | 7036 } |
| 7037 } else if (left.is(left_arg)) { | 7037 } else if (left.is(left_arg)) { |
| 7038 __ mov(right_arg, right); | 7038 __ mov(right_arg, right); |
| 7039 } else if (right.is(right_arg)) { |
| 7040 __ mov(left_arg, left); |
| 7039 } else if (left.is(right_arg)) { | 7041 } else if (left.is(right_arg)) { |
| 7040 if (IsOperationCommutative()) { | 7042 if (IsOperationCommutative()) { |
| 7041 __ mov(left_arg, right); | 7043 __ mov(left_arg, right); |
| 7042 SetArgsReversed(); | 7044 SetArgsReversed(); |
| 7043 } else { | 7045 } else { |
| 7044 // Order of moves important to avoid destroying left argument. | 7046 // Order of moves important to avoid destroying left argument. |
| 7045 __ mov(left_arg, left); | 7047 __ mov(left_arg, left); |
| 7046 __ mov(right_arg, right); | 7048 __ mov(right_arg, right); |
| 7047 } | 7049 } |
| 7048 } else if (right.is(left_arg)) { | 7050 } else if (right.is(left_arg)) { |
| 7049 if (IsOperationCommutative()) { | 7051 if (IsOperationCommutative()) { |
| 7050 __ mov(right_arg, left); | 7052 __ mov(right_arg, left); |
| 7051 SetArgsReversed(); | 7053 SetArgsReversed(); |
| 7052 } else { | 7054 } else { |
| 7053 // Order of moves important to avoid destroying right argument. | 7055 // Order of moves important to avoid destroying right argument. |
| 7054 __ mov(right_arg, right); | 7056 __ mov(right_arg, right); |
| 7055 __ mov(left_arg, left); | 7057 __ mov(left_arg, left); |
| 7056 } | 7058 } |
| 7057 } else if (right.is(right_arg)) { | |
| 7058 __ mov(left_arg, left); | |
| 7059 } else { | 7059 } else { |
| 7060 // Order of moves is not important. | 7060 // Order of moves is not important. |
| 7061 __ mov(left_arg, left); | 7061 __ mov(left_arg, left); |
| 7062 __ mov(right_arg, right); | 7062 __ mov(right_arg, right); |
| 7063 } | 7063 } |
| 7064 } | 7064 } |
| 7065 | 7065 |
| 7066 // Update flags to indicate that arguments are in registers. | 7066 // Update flags to indicate that arguments are in registers. |
| 7067 SetArgsInRegisters(); | 7067 SetArgsInRegisters(); |
| 7068 __ IncrementCounter(&Counters::generic_binary_stub_calls_regs, 1); | 7068 __ IncrementCounter(&Counters::generic_binary_stub_calls_regs, 1); |
| (...skipping 15 matching lines...) Expand all Loading... |
| 7084 } else { | 7084 } else { |
| 7085 // The calling convention with registers is left in edx and right in eax. | 7085 // The calling convention with registers is left in edx and right in eax. |
| 7086 Register left_arg = edx; | 7086 Register left_arg = edx; |
| 7087 Register right_arg = eax; | 7087 Register right_arg = eax; |
| 7088 if (left.is(left_arg)) { | 7088 if (left.is(left_arg)) { |
| 7089 __ mov(right_arg, Immediate(right)); | 7089 __ mov(right_arg, Immediate(right)); |
| 7090 } else if (left.is(right_arg) && IsOperationCommutative()) { | 7090 } else if (left.is(right_arg) && IsOperationCommutative()) { |
| 7091 __ mov(left_arg, Immediate(right)); | 7091 __ mov(left_arg, Immediate(right)); |
| 7092 SetArgsReversed(); | 7092 SetArgsReversed(); |
| 7093 } else { | 7093 } else { |
| 7094 // For non-commutative operations, left and right_arg might be |
| 7095 // the same register. Therefore, the order of the moves is |
| 7096 // important here in order to not overwrite left before moving |
| 7097 // it to left_arg. |
| 7094 __ mov(left_arg, left); | 7098 __ mov(left_arg, left); |
| 7095 __ mov(right_arg, Immediate(right)); | 7099 __ mov(right_arg, Immediate(right)); |
| 7096 } | 7100 } |
| 7097 | 7101 |
| 7098 // Update flags to indicate that arguments are in registers. | 7102 // Update flags to indicate that arguments are in registers. |
| 7099 SetArgsInRegisters(); | 7103 SetArgsInRegisters(); |
| 7100 __ IncrementCounter(&Counters::generic_binary_stub_calls_regs, 1); | 7104 __ IncrementCounter(&Counters::generic_binary_stub_calls_regs, 1); |
| 7101 } | 7105 } |
| 7102 | 7106 |
| 7103 // Call the stub. | 7107 // Call the stub. |
| (...skipping 12 matching lines...) Expand all Loading... |
| 7116 } else { | 7120 } else { |
| 7117 // The calling convention with registers is left in edx and right in eax. | 7121 // The calling convention with registers is left in edx and right in eax. |
| 7118 Register left_arg = edx; | 7122 Register left_arg = edx; |
| 7119 Register right_arg = eax; | 7123 Register right_arg = eax; |
| 7120 if (right.is(right_arg)) { | 7124 if (right.is(right_arg)) { |
| 7121 __ mov(left_arg, Immediate(left)); | 7125 __ mov(left_arg, Immediate(left)); |
| 7122 } else if (right.is(left_arg) && IsOperationCommutative()) { | 7126 } else if (right.is(left_arg) && IsOperationCommutative()) { |
| 7123 __ mov(right_arg, Immediate(left)); | 7127 __ mov(right_arg, Immediate(left)); |
| 7124 SetArgsReversed(); | 7128 SetArgsReversed(); |
| 7125 } else { | 7129 } else { |
| 7130 // For non-commutative operations, right and left_arg might be |
| 7131 // the same register. Therefore, the order of the moves is |
| 7132 // important here in order to not overwrite right before moving |
| 7133 // it to right_arg. |
| 7134 __ mov(right_arg, right); |
| 7126 __ mov(left_arg, Immediate(left)); | 7135 __ mov(left_arg, Immediate(left)); |
| 7127 __ mov(right_arg, right); | |
| 7128 } | 7136 } |
| 7129 // Update flags to indicate that arguments are in registers. | 7137 // Update flags to indicate that arguments are in registers. |
| 7130 SetArgsInRegisters(); | 7138 SetArgsInRegisters(); |
| 7131 __ IncrementCounter(&Counters::generic_binary_stub_calls_regs, 1); | 7139 __ IncrementCounter(&Counters::generic_binary_stub_calls_regs, 1); |
| 7132 } | 7140 } |
| 7133 | 7141 |
| 7134 // Call the stub. | 7142 // Call the stub. |
| 7135 __ CallStub(this); | 7143 __ CallStub(this); |
| 7136 } | 7144 } |
| 7137 | 7145 |
| (...skipping 2956 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 10094 | 10102 |
| 10095 // Call the runtime; it returns -1 (less), 0 (equal), or 1 (greater) | 10103 // Call the runtime; it returns -1 (less), 0 (equal), or 1 (greater) |
| 10096 // tagged as a small integer. | 10104 // tagged as a small integer. |
| 10097 __ bind(&runtime); | 10105 __ bind(&runtime); |
| 10098 __ TailCallRuntime(ExternalReference(Runtime::kStringCompare), 2, 1); | 10106 __ TailCallRuntime(ExternalReference(Runtime::kStringCompare), 2, 1); |
| 10099 } | 10107 } |
| 10100 | 10108 |
| 10101 #undef __ | 10109 #undef __ |
| 10102 | 10110 |
| 10103 } } // namespace v8::internal | 10111 } } // namespace v8::internal |
| OLD | NEW |