Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 1 | // $G $D/$F.go && $L $F.$A && ./$A.out |
| 2 | |
| 3 | // Copyright 2009 The Go Authors. All rights reserved. |
| 4 | // Use of this source code is governed by a BSD-style |
| 5 | // license that can be found in the LICENSE file. |
| 6 | |
| 7 | // Repeated malloc test. |
| 8 | |
| 9 | package main |
| 10 | |
| 11 | import ( |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 12 | "flag" |
| 13 | "runtime" |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 14 | ) |
| 15 | |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 16 | var chatty = flag.Bool("v", false, "chatty") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 17 | |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 18 | var oldsys uint64 |
| 19 | |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 20 | func bigger() { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 21 | if st := runtime.MemStats; oldsys < st.Sys { |
| 22 | oldsys = st.Sys |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 23 | if *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 24 | println(st.Sys, " system bytes for ", st.Alloc, " Go bytes") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 25 | } |
Russ Cox | f48cbfd | 2009-01-16 16:12:14 -0800 | [diff] [blame] | 26 | if st.Sys > 1e9 { |
Rob Pike | 325cf8e | 2010-03-24 16:46:53 -0700 | [diff] [blame] | 27 | println("too big") |
| 28 | panic("fail") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 29 | } |
| 30 | } |
| 31 | } |
| 32 | |
| 33 | func main() { |
Ian Lance Taylor | 9d93d57 | 2010-09-10 15:54:16 -0700 | [diff] [blame] | 34 | runtime.GC() // clean up garbage from init |
Russ Cox | 6eb251f | 2010-03-24 09:40:09 -0700 | [diff] [blame] | 35 | runtime.MemProfileRate = 0 // disable profiler |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 36 | runtime.MemStats.Alloc = 0 // ignore stacks |
Russ Cox | 6eb251f | 2010-03-24 09:40:09 -0700 | [diff] [blame] | 37 | flag.Parse() |
Russ Cox | ebd27d6 | 2009-10-09 11:18:32 -0700 | [diff] [blame] | 38 | for i := 0; i < 1<<7; i++ { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 39 | for j := 1; j <= 1<<22; j <<= 1 { |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 40 | if i == 0 && *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 41 | println("First alloc:", j) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 42 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 43 | if a := runtime.MemStats.Alloc; a != 0 { |
Rob Pike | 325cf8e | 2010-03-24 16:46:53 -0700 | [diff] [blame] | 44 | println("no allocations but stats report", a, "bytes allocated") |
| 45 | panic("fail") |
Russ Cox | b014be7 | 2009-06-05 10:59:37 -0700 | [diff] [blame] | 46 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 47 | b := runtime.Alloc(uintptr(j)) |
| 48 | during := runtime.MemStats.Alloc |
| 49 | runtime.Free(b) |
Dmitriy Vyukov | 66d5c9b | 2011-07-18 14:52:57 -0400 | [diff] [blame] | 50 | runtime.GC() |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 51 | if a := runtime.MemStats.Alloc; a != 0 { |
Russ Cox | 00f9f0c | 2010-03-30 10:34:57 -0700 | [diff] [blame] | 52 | println("allocated ", j, ": wrong stats: during=", during, " after=", a, " (want 0)") |
| 53 | panic("fail") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 54 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 55 | bigger() |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 56 | } |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 57 | if i%(1<<10) == 0 && *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 58 | println(i) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 59 | } |
| 60 | if i == 0 { |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 61 | if *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 62 | println("Primed", i) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 63 | } |
Rob Pike | 4f61fc9 | 2010-09-04 10:36:13 +1000 | [diff] [blame] | 64 | // runtime.frozen = true |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 65 | } |
| 66 | } |
| 67 | } |