| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | // $G $D/$F.go && $L $F.$A && ./$A.out | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Copyright 2009 The Go Authors. All rights reserved. | 
					
						
							|  |  |  | // Use of this source code is governed by a BSD-style | 
					
						
							|  |  |  | // license that can be found in the LICENSE file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Try to tickle stack splitting bugs by doing | 
					
						
							| 
									
										
										
										
											2009-02-06 13:46:56 -08:00
										 |  |  | // go, defer, and closure calls at different stack depths. | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | package main | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | type T [20]int | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func g(c chan int, t T) { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 	s := 0 | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	for i := 0; i < len(t); i++ { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		s += t[i] | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 	c <- s | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func d(t T) { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 	s := 0 | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	for i := 0; i < len(t); i++ { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		s += t[i] | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if s != len(t) { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		println("bad defer", s) | 
					
						
							|  |  |  | 		panic("fail") | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-01 18:34:41 -05:00
										 |  |  | func f0() { | 
					
						
							|  |  |  | 	// likely to make a new stack for f0, | 
					
						
							|  |  |  | 	// because the call to f1 puts 3000 bytes | 
					
						
							|  |  |  | 	// in our frame. | 
					
						
							|  |  |  | 	f1() | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func f1() [3000]byte { | 
					
						
							|  |  |  | 	// likely to make a new stack for f1, | 
					
						
							|  |  |  | 	// because 3000 bytes were used by f0 | 
					
						
							|  |  |  | 	// and we need 3000 more for the call | 
					
						
							|  |  |  | 	// to f2.  if the call to morestack in f1 | 
					
						
							|  |  |  | 	// does not pass the frame size, the new | 
					
						
							|  |  |  | 	// stack (default size 5k) will not be big | 
					
						
							|  |  |  | 	// enough for the frame, and the morestack | 
					
						
							|  |  |  | 	// check in f2 will die, if we get that far  | 
					
						
							|  |  |  | 	// without faulting. | 
					
						
							|  |  |  | 	f2() | 
					
						
							|  |  |  | 	return [3000]byte{} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func f2() [3000]byte { | 
					
						
							|  |  |  | 	// just take up space | 
					
						
							|  |  |  | 	return [3000]byte{} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | var c = make(chan int) | 
					
						
							|  |  |  | var t T | 
					
						
							|  |  |  | var b = []byte{1, 2, 3, 4, 5, 6, 7, 8, 9, 10} | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func recur(n int) { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 	ss := string(b) | 
					
						
							| 
									
										
										
										
											2009-04-10 06:22:41 -07:00
										 |  |  | 	if len(ss) != len(b) { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		panic("bad []byte -> string") | 
					
						
							| 
									
										
										
										
											2009-04-10 06:22:41 -07:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 	go g(c, t) | 
					
						
							| 
									
										
										
										
											2011-02-01 18:34:41 -05:00
										 |  |  | 	f0() | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 	s := <-c | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	if s != len(t) { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		println("bad go", s) | 
					
						
							|  |  |  | 		panic("fail") | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-02-06 13:46:56 -08:00
										 |  |  | 	f := func(t T) int { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		s := 0 | 
					
						
							| 
									
										
										
										
											2009-02-06 13:46:56 -08:00
										 |  |  | 		for i := 0; i < len(t); i++ { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 			s += t[i] | 
					
						
							| 
									
										
										
										
											2009-02-06 13:46:56 -08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		s += n | 
					
						
							|  |  |  | 		return s | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	s = f(t) | 
					
						
							|  |  |  | 	if s != len(t)+n { | 
					
						
							|  |  |  | 		println("bad func", s, "at level", n) | 
					
						
							|  |  |  | 		panic("fail") | 
					
						
							| 
									
										
										
										
											2009-02-06 13:46:56 -08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	if n > 0 { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		recur(n - 1) | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 	defer d(t) | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func main() { | 
					
						
							|  |  |  | 	for i := 0; i < len(t); i++ { | 
					
						
							| 
									
										
										
										
											2010-03-24 16:46:53 -07:00
										 |  |  | 		t[i] = 1 | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-04-22 17:52:22 -07:00
										 |  |  | 	recur(8000) | 
					
						
							| 
									
										
										
										
											2009-01-28 16:58:48 -08:00
										 |  |  | } |