mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-26 17:23:54 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| //@ skip if $architecture == "x86"
 | |
| 
 | |
| function sumOfArithSeries(limit) {
 | |
|     return limit * (limit + 1) / 2;
 | |
| }
 | |
| 
 | |
| var n = 10000000;
 | |
| 
 | |
| function bar() { }
 | |
| 
 | |
| function verify(q, i) {
 | |
|     if (q.f == q.g)
 | |
|         throw "Error: q.f == q.g";
 | |
|     if (q.f.f != q.g.f)
 | |
|         throw "Error: q.f.f != q.g.f";
 | |
|     if (q.f.f.f != i)
 | |
|         throw "Error: q.f.f.f != i";
 | |
| }
 | |
| 
 | |
| function foo() {
 | |
|     var result = 0;
 | |
|     for (var i = 0; i < n; ++i) {
 | |
|         var leaf = {f:i};
 | |
|         var o = {f:leaf};
 | |
|         var p = {f:leaf};
 | |
|         var q = {f:o, g:p};
 | |
|         result += q.f.f.f;
 | |
|         if (i >= n - 100) {
 | |
|             // We want the materialization to happen in the exit. So, before calling the thing that
 | |
|             // causes the materialization, we call bar(). We've never profiled this call at the time
 | |
|             // of FTL compilation, so this should be an exit.
 | |
|             bar();
 | |
|             verify(q, i);
 | |
|         }
 | |
|     }
 | |
|     return result;
 | |
| }
 | |
| 
 | |
| noInline(foo);
 | |
| noInline(verify);
 | |
| noInline(bar);
 | |
| 
 | |
| var result = foo();
 | |
| if (result != sumOfArithSeries(n - 1))
 | |
|     throw "Error: bad result: " + result;
 |