Server : LiteSpeed System : Linux in-mum-web1333.main-hosting.eu 4.18.0-553.37.1.lve.el8.x86_64 #1 SMP Mon Feb 10 22:45:17 UTC 2025 x86_64 User : u141265441 ( 141265441) PHP Version : 8.4.3 Disable Function : system, exec, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail Directory : /proc/self/root/opt/golang/1.22.0/src/runtime/ |
// 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
}
}
}