OLD | NEW |
1 // Copyright 2006-2008 the V8 project authors. All rights reserved. | 1 // Copyright 2006-2008 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 14 matching lines...) Expand all Loading... |
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
27 | 27 |
28 // CPU specific code for ia32 independent of OS goes here. | 28 // CPU specific code for ia32 independent of OS goes here. |
29 | 29 |
30 #include "v8.h" | 30 #include "v8.h" |
31 | 31 |
32 #include "cpu.h" | 32 #include "cpu.h" |
33 #include "macro-assembler.h" | 33 #include "macro-assembler.h" |
34 | 34 |
35 namespace v8 { namespace internal { | 35 namespace v8 { |
| 36 namespace internal { |
36 | 37 |
37 void CPU::Setup() { | 38 void CPU::Setup() { |
38 CpuFeatures::Probe(); | 39 CpuFeatures::Probe(); |
39 } | 40 } |
40 | 41 |
41 | 42 |
42 void CPU::FlushICache(void* start, size_t size) { | 43 void CPU::FlushICache(void* start, size_t size) { |
43 // No need to flush the instruction cache on Intel. On Intel instruction | 44 // No need to flush the instruction cache on Intel. On Intel instruction |
44 // cache flushing is only necessary when multiple cores running the same | 45 // cache flushing is only necessary when multiple cores running the same |
45 // code simultaneously. V8 (and JavaScript) is single threaded and when code | 46 // code simultaneously. V8 (and JavaScript) is single threaded and when code |
(...skipping 10 matching lines...) Expand all Loading... |
56 // To avoid Visual Studio runtime support the following code can be used | 57 // To avoid Visual Studio runtime support the following code can be used |
57 // instead | 58 // instead |
58 // __asm { int 3 } | 59 // __asm { int 3 } |
59 __debugbreak(); | 60 __debugbreak(); |
60 #else | 61 #else |
61 asm("int $3"); | 62 asm("int $3"); |
62 #endif | 63 #endif |
63 } | 64 } |
64 | 65 |
65 } } // namespace v8::internal | 66 } } // namespace v8::internal |
OLD | NEW |