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 | 226fb09 | 2011-07-22 00:55:01 -0400 | [diff] [blame] | 21 | runtime.UpdateMemStats() |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 22 | if st := runtime.MemStats; oldsys < st.Sys { |
| 23 | oldsys = st.Sys |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 24 | if *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 25 | println(st.Sys, " system bytes for ", st.Alloc, " Go bytes") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 26 | } |
Russ Cox | f48cbfd | 2009-01-16 16:12:14 -0800 | [diff] [blame] | 27 | if st.Sys > 1e9 { |
Rob Pike | 325cf8e | 2010-03-24 16:46:53 -0700 | [diff] [blame] | 28 | println("too big") |
| 29 | panic("fail") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 30 | } |
| 31 | } |
| 32 | } |
| 33 | |
| 34 | func main() { |
Russ Cox | 226fb09 | 2011-07-22 00:55:01 -0400 | [diff] [blame] | 35 | runtime.GC() // clean up garbage from init |
Russ Cox | 6eb251f | 2010-03-24 09:40:09 -0700 | [diff] [blame] | 36 | runtime.MemProfileRate = 0 // disable profiler |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 37 | runtime.MemStats.Alloc = 0 // ignore stacks |
Russ Cox | 6eb251f | 2010-03-24 09:40:09 -0700 | [diff] [blame] | 38 | flag.Parse() |
Russ Cox | ebd27d6 | 2009-10-09 11:18:32 -0700 | [diff] [blame] | 39 | for i := 0; i < 1<<7; i++ { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 40 | for j := 1; j <= 1<<22; j <<= 1 { |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 41 | if i == 0 && *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 42 | println("First alloc:", j) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 43 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 44 | if a := runtime.MemStats.Alloc; a != 0 { |
Rob Pike | 325cf8e | 2010-03-24 16:46:53 -0700 | [diff] [blame] | 45 | println("no allocations but stats report", a, "bytes allocated") |
| 46 | panic("fail") |
Russ Cox | b014be7 | 2009-06-05 10:59:37 -0700 | [diff] [blame] | 47 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 48 | b := runtime.Alloc(uintptr(j)) |
Russ Cox | 226fb09 | 2011-07-22 00:55:01 -0400 | [diff] [blame] | 49 | runtime.UpdateMemStats() |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 50 | during := runtime.MemStats.Alloc |
| 51 | runtime.Free(b) |
Russ Cox | 226fb09 | 2011-07-22 00:55:01 -0400 | [diff] [blame] | 52 | runtime.UpdateMemStats() |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 53 | if a := runtime.MemStats.Alloc; a != 0 { |
Russ Cox | 00f9f0c | 2010-03-30 10:34:57 -0700 | [diff] [blame] | 54 | println("allocated ", j, ": wrong stats: during=", during, " after=", a, " (want 0)") |
| 55 | panic("fail") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 56 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 57 | bigger() |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 58 | } |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 59 | if i%(1<<10) == 0 && *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 60 | println(i) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 61 | } |
| 62 | if i == 0 { |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 63 | if *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 64 | println("Primed", i) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 65 | } |
Rob Pike | 4f61fc9 | 2010-09-04 10:36:13 +1000 | [diff] [blame] | 66 | // runtime.frozen = true |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 67 | } |
| 68 | } |
| 69 | } |