OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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 18 matching lines...) Expand all Loading... |
29 // Flags: --expose-gc --allow-natives-syntax | 29 // Flags: --expose-gc --allow-natives-syntax |
30 // Flags: --concurrent-recompilation --block-concurrent-recompilation | 30 // Flags: --concurrent-recompilation --block-concurrent-recompilation |
31 | 31 |
32 if (!%IsConcurrentRecompilationSupported()) { | 32 if (!%IsConcurrentRecompilationSupported()) { |
33 print("Concurrent recompilation is disabled. Skipping this test."); | 33 print("Concurrent recompilation is disabled. Skipping this test."); |
34 quit(); | 34 quit(); |
35 } | 35 } |
36 | 36 |
37 function test(fun) { | 37 function test(fun) { |
38 fun(); | 38 fun(); |
| 39 %BaselineFunctionOnNextCall(fun); |
39 fun(); | 40 fun(); |
40 // Mark for concurrent optimization. | 41 // Mark for concurrent optimization. |
41 %OptimizeFunctionOnNextCall(fun, "concurrent"); | 42 %OptimizeFunctionOnNextCall(fun, "concurrent"); |
42 // Kick off recompilation. | 43 // Kick off recompilation. |
43 fun(); | 44 fun(); |
44 // Tenure cons string after compile graph has been created. | 45 // Tenure cons string after compile graph has been created. |
45 gc(); | 46 gc(); |
46 // In the mean time, concurrent recompiling is still blocked. | 47 // In the mean time, concurrent recompiling is still blocked. |
47 assertUnoptimized(fun, "no sync"); | 48 assertUnoptimized(fun, "no sync"); |
48 // Let concurrent recompilation proceed. | 49 // Let concurrent recompilation proceed. |
(...skipping 12 matching lines...) Expand all Loading... |
61 return "abcdefghijklmn\u2603" + "123456789"; | 62 return "abcdefghijklmn\u2603" + "123456789"; |
62 } | 63 } |
63 | 64 |
64 function h() { | 65 function h() { |
65 return "abcdefghijklmn\u2603" + "123456789\u2604"; | 66 return "abcdefghijklmn\u2603" + "123456789\u2604"; |
66 } | 67 } |
67 | 68 |
68 test(f); | 69 test(f); |
69 test(g); | 70 test(g); |
70 test(h); | 71 test(h); |
OLD | NEW |