Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 1 | // Copyright 2009 The Go Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style |
| 3 | // license that can be found in the LICENSE file. |
| 4 | |
| 5 | // Repeated malloc test. |
| 6 | |
Russ Cox | 03f2289 | 2012-02-19 00:11:44 -0500 | [diff] [blame] | 7 | // +build ignore |
| 8 | |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 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 |
Rémy Oudompheng | 842c906 | 2012-02-06 19:16:26 +0100 | [diff] [blame] | 19 | var memstats runtime.MemStats |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 20 | |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 21 | func bigger() { |
Rémy Oudompheng | 842c906 | 2012-02-06 19:16:26 +0100 | [diff] [blame] | 22 | st := &memstats |
| 23 | runtime.ReadMemStats(st) |
| 24 | if oldsys < st.Sys { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 25 | oldsys = st.Sys |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 26 | if *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 27 | println(st.Sys, " system bytes for ", st.Alloc, " Go bytes") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 28 | } |
Russ Cox | f48cbfd | 2009-01-16 16:12:14 -0800 | [diff] [blame] | 29 | if st.Sys > 1e9 { |
Rob Pike | 325cf8e | 2010-03-24 16:46:53 -0700 | [diff] [blame] | 30 | println("too big") |
| 31 | panic("fail") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 32 | } |
| 33 | } |
| 34 | } |
| 35 | |
| 36 | func main() { |
Rémy Oudompheng | 842c906 | 2012-02-06 19:16:26 +0100 | [diff] [blame] | 37 | runtime.GC() // clean up garbage from init |
| 38 | runtime.ReadMemStats(&memstats) // first call can do some allocations |
| 39 | runtime.MemProfileRate = 0 // disable profiler |
| 40 | stacks := memstats.Alloc // ignore stacks |
Russ Cox | 6eb251f | 2010-03-24 09:40:09 -0700 | [diff] [blame] | 41 | flag.Parse() |
Russ Cox | ebd27d6 | 2009-10-09 11:18:32 -0700 | [diff] [blame] | 42 | for i := 0; i < 1<<7; i++ { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 43 | for j := 1; j <= 1<<22; j <<= 1 { |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 44 | if i == 0 && *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 45 | println("First alloc:", j) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 46 | } |
Rémy Oudompheng | 842c906 | 2012-02-06 19:16:26 +0100 | [diff] [blame] | 47 | if a := memstats.Alloc - stacks; a != 0 { |
Rob Pike | 325cf8e | 2010-03-24 16:46:53 -0700 | [diff] [blame] | 48 | println("no allocations but stats report", a, "bytes allocated") |
| 49 | panic("fail") |
Russ Cox | b014be7 | 2009-06-05 10:59:37 -0700 | [diff] [blame] | 50 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 51 | b := runtime.Alloc(uintptr(j)) |
Rémy Oudompheng | 842c906 | 2012-02-06 19:16:26 +0100 | [diff] [blame] | 52 | runtime.ReadMemStats(&memstats) |
| 53 | during := memstats.Alloc - stacks |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 54 | runtime.Free(b) |
Rémy Oudompheng | 842c906 | 2012-02-06 19:16:26 +0100 | [diff] [blame] | 55 | runtime.ReadMemStats(&memstats) |
| 56 | if a := memstats.Alloc - stacks; a != 0 { |
Russ Cox | 00f9f0c | 2010-03-30 10:34:57 -0700 | [diff] [blame] | 57 | println("allocated ", j, ": wrong stats: during=", during, " after=", a, " (want 0)") |
| 58 | panic("fail") |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 59 | } |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 60 | bigger() |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 61 | } |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 62 | if i%(1<<10) == 0 && *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 63 | println(i) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 64 | } |
| 65 | if i == 0 { |
Rob Pike | c45d2a7 | 2009-01-09 13:42:46 -0800 | [diff] [blame] | 66 | if *chatty { |
Russ Cox | 33e396a | 2010-02-03 16:31:34 -0800 | [diff] [blame] | 67 | println("Primed", i) |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 68 | } |
Rob Pike | 4f61fc9 | 2010-09-04 10:36:13 +1000 | [diff] [blame] | 69 | // runtime.frozen = true |
Russ Cox | e29ce17 | 2008-12-18 15:42:28 -0800 | [diff] [blame] | 70 | } |
| 71 | } |
| 72 | } |