| 
									
										
										
										
											2021-08-29 15:41:41 +01:00
										 |  |  | // Copyright 2020 The Libc Authors. All rights reserved. | 
					
						
							|  |  |  | // Use of this source code is governed by a BSD-style | 
					
						
							|  |  |  | // license that can be found in the LICENSE file. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-08 21:12:23 +01:00
										 |  |  | //go:build 386 || arm | 
					
						
							| 
									
										
										
										
											2021-08-29 15:41:41 +01:00
										 |  |  | // +build 386 arm | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package libc // import "modernc.org/libc" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type ( | 
					
						
							|  |  |  | 	// RawMem represents the biggest byte array the runtime can handle | 
					
						
							|  |  |  | 	RawMem [1<<31 - 1]byte | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// 32-5*4 = 12 bytes left to pad | 
					
						
							|  |  |  | 	stackHeaderPadding struct { | 
					
						
							|  |  |  | 		a uintptr | 
					
						
							|  |  |  | 		b uintptr | 
					
						
							|  |  |  | 		c uintptr | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type bits []int | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func newBits(n int) (r bits)  { return make(bits, (n+31)>>5) } | 
					
						
							|  |  |  | func (b bits) has(n int) bool { return b != nil && b[n>>5]&(1<<uint(n&31)) != 0 } | 
					
						
							|  |  |  | func (b bits) set(n int)      { b[n>>5] |= 1 << uint(n&31) } |