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 20 matching lines...) Expand all Loading... | |
31 | 31 |
32 #include "arguments.h" | 32 #include "arguments.h" |
33 #include "bootstrapper.h" | 33 #include "bootstrapper.h" |
34 #include "compiler.h" | 34 #include "compiler.h" |
35 #include "debug.h" | 35 #include "debug.h" |
36 #include "deoptimizer.h" | 36 #include "deoptimizer.h" |
37 #include "execution.h" | 37 #include "execution.h" |
38 #include "global-handles.h" | 38 #include "global-handles.h" |
39 #include "heap-profiler.h" | 39 #include "heap-profiler.h" |
40 #include "messages.h" | 40 #include "messages.h" |
41 #include "natives.h" | |
41 #include "parser.h" | 42 #include "parser.h" |
42 #include "platform.h" | 43 #include "platform.h" |
43 #include "profile-generator-inl.h" | 44 #include "profile-generator-inl.h" |
44 #include "runtime-profiler.h" | 45 #include "runtime-profiler.h" |
45 #include "serialize.h" | 46 #include "serialize.h" |
46 #include "snapshot.h" | 47 #include "snapshot.h" |
47 #include "v8threads.h" | 48 #include "v8threads.h" |
48 #include "version.h" | 49 #include "version.h" |
49 #include "vm-state-inl.h" | 50 #include "vm-state-inl.h" |
50 | 51 |
(...skipping 265 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
316 return StartupData::kBZip2; | 317 return StartupData::kBZip2; |
317 #else | 318 #else |
318 return StartupData::kUncompressed; | 319 return StartupData::kUncompressed; |
319 #endif | 320 #endif |
320 } | 321 } |
321 | 322 |
322 | 323 |
323 enum CompressedStartupDataItems { | 324 enum CompressedStartupDataItems { |
324 kSnapshot = 0, | 325 kSnapshot = 0, |
325 kSnapshotContext, | 326 kSnapshotContext, |
326 kCompressedStartupDataCount | 327 kSnapshotDataCount |
327 }; | 328 }; |
328 | 329 |
329 int V8::GetCompressedStartupDataCount() { | 330 int V8::GetCompressedStartupDataCount() { |
330 #ifdef COMPRESS_STARTUP_DATA_BZ2 | 331 #ifdef COMPRESS_STARTUP_DATA_BZ2 |
331 return kCompressedStartupDataCount; | 332 return kSnapshotDataCount + |
333 i::Natives::GetBuiltinsCount() + | |
334 i::ExperimentalNatives::GetBuiltinsCount(); | |
332 #else | 335 #else |
333 return 0; | 336 return 0; |
334 #endif | 337 #endif |
335 } | 338 } |
336 | 339 |
337 | 340 |
338 void V8::GetCompressedStartupData(StartupData* compressed_data) { | 341 void V8::GetCompressedStartupData(StartupData* compressed_data) { |
339 #ifdef COMPRESS_STARTUP_DATA_BZ2 | 342 #ifdef COMPRESS_STARTUP_DATA_BZ2 |
340 compressed_data[kSnapshot].data = | 343 compressed_data[kSnapshot].data = |
341 reinterpret_cast<const char*>(i::Snapshot::data()); | 344 reinterpret_cast<const char*>(i::Snapshot::data()); |
342 compressed_data[kSnapshot].compressed_size = i::Snapshot::size(); | 345 compressed_data[kSnapshot].compressed_size = i::Snapshot::size(); |
343 compressed_data[kSnapshot].raw_size = i::Snapshot::raw_size(); | 346 compressed_data[kSnapshot].raw_size = i::Snapshot::raw_size(); |
344 | 347 |
345 compressed_data[kSnapshotContext].data = | 348 compressed_data[kSnapshotContext].data = |
346 reinterpret_cast<const char*>(i::Snapshot::context_data()); | 349 reinterpret_cast<const char*>(i::Snapshot::context_data()); |
347 compressed_data[kSnapshotContext].compressed_size = | 350 compressed_data[kSnapshotContext].compressed_size = |
348 i::Snapshot::context_size(); | 351 i::Snapshot::context_size(); |
349 compressed_data[kSnapshotContext].raw_size = i::Snapshot::context_raw_size(); | 352 compressed_data[kSnapshotContext].raw_size = i::Snapshot::context_raw_size(); |
353 | |
354 for (int i = 0, idx = kSnapshotDataCount; | |
Vitaly Repeshko
2011/06/06 10:08:23
It may be easier to read to maintain a separate of
mnaganov (inactive)
2011/06/06 13:40:18
Done.
| |
355 i < i::Natives::GetBuiltinsCount(); | |
Vitaly Repeshko
2011/06/06 10:08:23
I hope no compiler will have trouble with 'i' both
mnaganov (inactive)
2011/06/06 13:40:18
Bots will tell ;)
| |
356 ++i, ++idx) { | |
357 i::Vector<const i::byte> source = i::Natives::GetScriptSource(i); | |
358 compressed_data[idx].data = | |
359 reinterpret_cast<const char*>(source.start()); | |
360 compressed_data[idx].compressed_size = source.length(); | |
361 compressed_data[idx].raw_size = i::Natives::GetRawScriptSize(i); | |
362 } | |
363 | |
364 for (int i = 0, idx = kSnapshotDataCount + i::Natives::GetBuiltinsCount(); | |
365 i < i::ExperimentalNatives::GetBuiltinsCount(); | |
366 ++i, ++idx) { | |
367 i::Vector<const i::byte> source = | |
368 i::ExperimentalNatives::GetScriptSource(i); | |
369 compressed_data[idx].data = | |
370 reinterpret_cast<const char*>(source.start()); | |
371 compressed_data[idx].compressed_size = source.length(); | |
372 compressed_data[idx].raw_size = | |
373 i::ExperimentalNatives::GetRawScriptSize(i); | |
374 } | |
350 #endif | 375 #endif |
351 } | 376 } |
352 | 377 |
353 | 378 |
354 void V8::SetDecompressedStartupData(StartupData* decompressed_data) { | 379 void V8::SetDecompressedStartupData(StartupData* decompressed_data) { |
355 #ifdef COMPRESS_STARTUP_DATA_BZ2 | 380 #ifdef COMPRESS_STARTUP_DATA_BZ2 |
356 ASSERT_EQ(i::Snapshot::raw_size(), decompressed_data[kSnapshot].raw_size); | 381 ASSERT_EQ(i::Snapshot::raw_size(), decompressed_data[kSnapshot].raw_size); |
357 i::Snapshot::set_raw_data( | 382 i::Snapshot::set_raw_data( |
358 reinterpret_cast<const i::byte*>(decompressed_data[kSnapshot].data)); | 383 reinterpret_cast<const i::byte*>(decompressed_data[kSnapshot].data)); |
359 | 384 |
360 ASSERT_EQ(i::Snapshot::context_raw_size(), | 385 ASSERT_EQ(i::Snapshot::context_raw_size(), |
361 decompressed_data[kSnapshotContext].raw_size); | 386 decompressed_data[kSnapshotContext].raw_size); |
362 i::Snapshot::set_context_raw_data( | 387 i::Snapshot::set_context_raw_data( |
363 reinterpret_cast<const i::byte*>( | 388 reinterpret_cast<const i::byte*>( |
364 decompressed_data[kSnapshotContext].data)); | 389 decompressed_data[kSnapshotContext].data)); |
390 | |
391 for (int i = 0, idx = kSnapshotDataCount; | |
Vitaly Repeshko
2011/06/06 10:08:23
Same here.
| |
392 i < i::Natives::GetBuiltinsCount(); | |
393 ++i, ++idx) { | |
394 ASSERT_EQ(i::Natives::GetRawScriptSize(i), | |
395 decompressed_data[idx].raw_size); | |
396 i::Vector<const char> source(decompressed_data[idx].data, | |
397 decompressed_data[idx].raw_size); | |
398 i::Natives::SetRawScriptSource(i, source); | |
399 } | |
400 | |
401 for (int i = 0, idx = kSnapshotDataCount + i::Natives::GetBuiltinsCount(); | |
402 i < i::ExperimentalNatives::GetBuiltinsCount(); | |
403 ++i, ++idx) { | |
404 ASSERT_EQ(i::ExperimentalNatives::GetRawScriptSize(i), | |
405 decompressed_data[idx].raw_size); | |
406 i::Vector<const char> source(decompressed_data[idx].data, | |
407 decompressed_data[idx].raw_size); | |
408 i::ExperimentalNatives::SetRawScriptSource(i, source); | |
409 } | |
365 #endif | 410 #endif |
366 } | 411 } |
367 | 412 |
368 | 413 |
369 void V8::SetFatalErrorHandler(FatalErrorCallback that) { | 414 void V8::SetFatalErrorHandler(FatalErrorCallback that) { |
370 i::Isolate* isolate = EnterIsolateIfNeeded(); | 415 i::Isolate* isolate = EnterIsolateIfNeeded(); |
371 isolate->set_exception_behavior(that); | 416 isolate->set_exception_behavior(that); |
372 } | 417 } |
373 | 418 |
374 | 419 |
(...skipping 5469 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
5844 | 5889 |
5845 | 5890 |
5846 char* HandleScopeImplementer::Iterate(ObjectVisitor* v, char* storage) { | 5891 char* HandleScopeImplementer::Iterate(ObjectVisitor* v, char* storage) { |
5847 HandleScopeImplementer* scope_implementer = | 5892 HandleScopeImplementer* scope_implementer = |
5848 reinterpret_cast<HandleScopeImplementer*>(storage); | 5893 reinterpret_cast<HandleScopeImplementer*>(storage); |
5849 scope_implementer->IterateThis(v); | 5894 scope_implementer->IterateThis(v); |
5850 return storage + ArchiveSpacePerThread(); | 5895 return storage + ArchiveSpacePerThread(); |
5851 } | 5896 } |
5852 | 5897 |
5853 } } // namespace v8::internal | 5898 } } // namespace v8::internal |
OLD | NEW |