| // Copyright 2016 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. |
| |
| // Proc unit tests. In runtime package so can use runtime guts. |
| |
| package runtime |
| |
| func RunStealOrderTest() { |
| var ord randomOrder |
| for procs := 1; procs <= 64; procs++ { |
| ord.reset(uint32(procs)) |
| if procs >= 3 && len(ord.coprimes) < 2 { |
| panic("too few coprimes") |
| } |
| for co := 0; co < len(ord.coprimes); co++ { |
| enum := ord.start(uint32(co)) |
| checked := make([]bool, procs) |
| for p := 0; p < procs; p++ { |
| x := enum.position() |
| if checked[x] { |
| println("procs:", procs, "inc:", enum.inc) |
| panic("duplicate during enumeration") |
| } |
| checked[x] = true |
| enum.next() |
| } |
| if !enum.done() { |
| panic("not done") |
| } |
| } |
| } |
| // Make sure that different arguments to ord.start don't generate the |
| // same pos+inc twice. |
| for procs := 2; procs <= 64; procs++ { |
| ord.reset(uint32(procs)) |
| checked := make([]bool, procs*procs) |
| // We want at least procs*len(ord.coprimes) different pos+inc values |
| // before we start repeating. |
| for i := 0; i < procs*len(ord.coprimes); i++ { |
| enum := ord.start(uint32(i)) |
| j := enum.pos*uint32(procs) + enum.inc |
| if checked[j] { |
| println("procs:", procs, "pos:", enum.pos, "inc:", enum.inc) |
| panic("duplicate pos+inc during enumeration") |
| } |
| checked[j] = true |
| } |
| } |
| } |