| 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 5983 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5994 | 5994 |
| 5995 SafepointEntry Code::GetSafepointEntry(Address pc) { | 5995 SafepointEntry Code::GetSafepointEntry(Address pc) { |
| 5996 SafepointTable table(this); | 5996 SafepointTable table(this); |
| 5997 return table.FindEntry(pc); | 5997 return table.FindEntry(pc); |
| 5998 } | 5998 } |
| 5999 | 5999 |
| 6000 | 6000 |
| 6001 void Code::SetNoStackCheckTable() { | 6001 void Code::SetNoStackCheckTable() { |
| 6002 // Indicate the absence of a stack-check table by a table start after the | 6002 // Indicate the absence of a stack-check table by a table start after the |
| 6003 // end of the instructions. Table start must be aligned, so round up. | 6003 // end of the instructions. Table start must be aligned, so round up. |
| 6004 set_stack_check_table_start(RoundUp(instruction_size(), kIntSize)); | 6004 set_stack_check_table_offset(RoundUp(instruction_size(), kIntSize)); |
| 6005 } | 6005 } |
| 6006 | 6006 |
| 6007 | 6007 |
| 6008 Map* Code::FindFirstMap() { | 6008 Map* Code::FindFirstMap() { |
| 6009 ASSERT(is_inline_cache_stub()); | 6009 ASSERT(is_inline_cache_stub()); |
| 6010 AssertNoAllocation no_allocation; | 6010 AssertNoAllocation no_allocation; |
| 6011 int mask = RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT); | 6011 int mask = RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT); |
| 6012 for (RelocIterator it(this, mask); !it.done(); it.next()) { | 6012 for (RelocIterator it(this, mask); !it.done(); it.next()) { |
| 6013 RelocInfo* info = it.rinfo(); | 6013 RelocInfo* info = it.rinfo(); |
| 6014 Object* object = info->target_object(); | 6014 Object* object = info->target_object(); |
| (...skipping 256 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 6271 } else { | 6271 } else { |
| 6272 PrintF(out, " <none>"); | 6272 PrintF(out, " <none>"); |
| 6273 } | 6273 } |
| 6274 if (entry.argument_count() > 0) { | 6274 if (entry.argument_count() > 0) { |
| 6275 PrintF(out, " argc: %d", entry.argument_count()); | 6275 PrintF(out, " argc: %d", entry.argument_count()); |
| 6276 } | 6276 } |
| 6277 PrintF(out, "\n"); | 6277 PrintF(out, "\n"); |
| 6278 } | 6278 } |
| 6279 PrintF(out, "\n"); | 6279 PrintF(out, "\n"); |
| 6280 } else if (kind() == FUNCTION) { | 6280 } else if (kind() == FUNCTION) { |
| 6281 unsigned offset = stack_check_table_start(); | 6281 unsigned offset = stack_check_table_offset(); |
| 6282 // If there is no stack check table, the "table start" will at or after | 6282 // If there is no stack check table, the "table start" will at or after |
| 6283 // (due to alignment) the end of the instruction stream. | 6283 // (due to alignment) the end of the instruction stream. |
| 6284 if (static_cast<int>(offset) < instruction_size()) { | 6284 if (static_cast<int>(offset) < instruction_size()) { |
| 6285 unsigned* address = | 6285 unsigned* address = |
| 6286 reinterpret_cast<unsigned*>(instruction_start() + offset); | 6286 reinterpret_cast<unsigned*>(instruction_start() + offset); |
| 6287 unsigned length = address[0]; | 6287 unsigned length = address[0]; |
| 6288 PrintF(out, "Stack checks (size = %u)\n", length); | 6288 PrintF(out, "Stack checks (size = %u)\n", length); |
| 6289 PrintF(out, "ast_id pc_offset\n"); | 6289 PrintF(out, "ast_id pc_offset\n"); |
| 6290 for (unsigned i = 0; i < length; ++i) { | 6290 for (unsigned i = 0; i < length; ++i) { |
| 6291 unsigned index = (2 * i) + 1; | 6291 unsigned index = (2 * i) + 1; |
| (...skipping 3579 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 9871 if (break_point_objects()->IsUndefined()) return 0; | 9871 if (break_point_objects()->IsUndefined()) return 0; |
| 9872 // Single beak point. | 9872 // Single beak point. |
| 9873 if (!break_point_objects()->IsFixedArray()) return 1; | 9873 if (!break_point_objects()->IsFixedArray()) return 1; |
| 9874 // Multiple break points. | 9874 // Multiple break points. |
| 9875 return FixedArray::cast(break_point_objects())->length(); | 9875 return FixedArray::cast(break_point_objects())->length(); |
| 9876 } | 9876 } |
| 9877 #endif | 9877 #endif |
| 9878 | 9878 |
| 9879 | 9879 |
| 9880 } } // namespace v8::internal | 9880 } } // namespace v8::internal |
| OLD | NEW |