mirror of
				https://github.com/golang/go.git
				synced 2025-10-22 12:33:19 +00:00 
			
		
		
		
	internal/sync: warn about incorrect unsafe usage in HashTrieMap
When the HashTrieMap expand method runs out of bits, it can be because the user mutated a key after insertion using unsafe or similar in violation of the HashTrieMap invariants. Adjust the panic message to help triage and debugging by more directly suggesting unsafe code might be at fault. CL 694635 is a follow-up change that attempts to detect and report illegally mutated keys sooner and more precisely. Updates #74948 Updates #73427 Change-Id: Ib2bca067f0e212b8765c61183f59ac229513a823 Reviewed-on: https://go-review.googlesource.com/c/go/+/694376 Reviewed-by: Michael Knyszek <mknyszek@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com>
This commit is contained in:
		
							parent
							
								
									084c0f8494
								
							
						
					
					
						commit
						1718828c81
					
				
					 1 changed files with 1 additions and 1 deletions
				
			
		|  | @ -178,7 +178,7 @@ func (ht *HashTrieMap[K, V]) expand(oldEntry, newEntry *entry[K, V], newHash uin | ||||||
| 	top := newIndirect | 	top := newIndirect | ||||||
| 	for { | 	for { | ||||||
| 		if hashShift == 0 { | 		if hashShift == 0 { | ||||||
| 			panic("internal/sync.HashTrieMap: ran out of hash bits while inserting") | 			panic("internal/sync.HashTrieMap: ran out of hash bits while inserting (incorrect use of unsafe or cgo, or data race?)") | ||||||
| 		} | 		} | ||||||
| 		hashShift -= nChildrenLog2 // hashShift is for the level parent is at. We need to go deeper. | 		hashShift -= nChildrenLog2 // hashShift is for the level parent is at. We need to go deeper. | ||||||
| 		oi := (oldHash >> hashShift) & nChildrenMask | 		oi := (oldHash >> hashShift) & nChildrenMask | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 thepudds
						thepudds