| // 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. | 
 |  | 
 | // +build linux | 
 | // +build mips mipsle | 
 |  | 
 | package runtime | 
 |  | 
 | var randomNumber uint32 | 
 |  | 
 | func archauxv(tag, val uintptr) { | 
 | 	switch tag { | 
 | 	case _AT_RANDOM: | 
 | 		// sysargs filled in startupRandomData, but that | 
 | 		// pointer may not be word aligned, so we must treat | 
 | 		// it as a byte array. | 
 | 		randomNumber = uint32(startupRandomData[4]) | uint32(startupRandomData[5])<<8 | | 
 | 			uint32(startupRandomData[6])<<16 | uint32(startupRandomData[7])<<24 | 
 | 	} | 
 | } | 
 |  | 
 | //go:nosplit | 
 | func cputicks() int64 { | 
 | 	// Currently cputicks() is used in blocking profiler and to seed fastrand(). | 
 | 	// nanotime() is a poor approximation of CPU ticks that is enough for the profiler. | 
 | 	// randomNumber provides better seeding of fastrand1. | 
 | 	return nanotime() + int64(randomNumber) | 
 | } | 
 |  | 
 | const ( | 
 | 	_SS_DISABLE  = 2 | 
 | 	_NSIG        = 128 + 1 | 
 | 	_SI_USER     = 0 | 
 | 	_SIG_BLOCK   = 1 | 
 | 	_SIG_UNBLOCK = 2 | 
 | 	_SIG_SETMASK = 3 | 
 | 	_RLIMIT_AS   = 6 | 
 | ) | 
 |  | 
 | type sigset [4]uint32 | 
 |  | 
 | type rlimit struct { | 
 | 	rlim_cur uintptr | 
 | 	rlim_max uintptr | 
 | } | 
 |  | 
 | var sigset_all = sigset{^uint32(0), ^uint32(0), ^uint32(0), ^uint32(0)} | 
 |  | 
 | //go:nosplit | 
 | //go:nowritebarrierrec | 
 | func sigaddset(mask *sigset, i int) { | 
 | 	(*mask)[(i-1)/32] |= 1 << ((uint32(i) - 1) & 31) | 
 | } | 
 |  | 
 | func sigdelset(mask *sigset, i int) { | 
 | 	(*mask)[(i-1)/32] &^= 1 << ((uint32(i) - 1) & 31) | 
 | } | 
 |  | 
 | func sigfillset(mask *[4]uint32) { | 
 | 	(*mask)[0], (*mask)[1], (*mask)[2], (*mask)[3] = ^uint32(0), ^uint32(0), ^uint32(0), ^uint32(0) | 
 | } |