OLD | NEW |
---|---|
1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 1167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1178 // Current string. | 1178 // Current string. |
1179 bool is_ascii = subject->IsAsciiRepresentationUnderneath(); | 1179 bool is_ascii = subject->IsAsciiRepresentationUnderneath(); |
1180 | 1180 |
1181 ASSERT(re_code->instruction_start() <= *return_address); | 1181 ASSERT(re_code->instruction_start() <= *return_address); |
1182 ASSERT(*return_address <= | 1182 ASSERT(*return_address <= |
1183 re_code->instruction_start() + re_code->instruction_size()); | 1183 re_code->instruction_start() + re_code->instruction_size()); |
1184 | 1184 |
1185 MaybeObject* result = Execution::HandleStackGuardInterrupt(); | 1185 MaybeObject* result = Execution::HandleStackGuardInterrupt(); |
1186 | 1186 |
1187 if (*code_handle != re_code) { // Return address no longer valid | 1187 if (*code_handle != re_code) { // Return address no longer valid |
1188 int delta = *code_handle - re_code; | 1188 intptr_t delta = *code_handle - re_code; |
Sven Panne
2011/08/26 13:36:21
This change looks OK, but...
| |
1189 // Overwrite the return address on the stack. | 1189 // Overwrite the return address on the stack. |
1190 *return_address += delta; | 1190 *return_address += delta; |
Sven Panne
2011/08/26 13:36:21
This (old) code looks wrong: The delta is in units
Vyacheslav Egorov (Chromium)
2011/08/26 13:41:03
Yes. Nice catch.
For type safety we need to do co
| |
1191 } | 1191 } |
1192 | 1192 |
1193 if (result->IsException()) { | 1193 if (result->IsException()) { |
1194 return EXCEPTION; | 1194 return EXCEPTION; |
1195 } | 1195 } |
1196 | 1196 |
1197 Handle<String> subject_tmp = subject; | 1197 Handle<String> subject_tmp = subject; |
1198 int slice_offset = 0; | 1198 int slice_offset = 0; |
1199 | 1199 |
1200 // Extract the underlying string and the slice offset. | 1200 // Extract the underlying string and the slice offset. |
(...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1401 } | 1401 } |
1402 } | 1402 } |
1403 | 1403 |
1404 #undef __ | 1404 #undef __ |
1405 | 1405 |
1406 #endif // V8_INTERPRETED_REGEXP | 1406 #endif // V8_INTERPRETED_REGEXP |
1407 | 1407 |
1408 }} // namespace v8::internal | 1408 }} // namespace v8::internal |
1409 | 1409 |
1410 #endif // V8_TARGET_ARCH_X64 | 1410 #endif // V8_TARGET_ARCH_X64 |
OLD | NEW |