mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-24 20:53:48 +01:00 
			
		
		
		
	document design decisions
This commit is contained in:
		| @@ -107,7 +107,13 @@ def validate_hostname(config): | ||||
|  | ||||
|  | ||||
| def validate_ids_and_references(config: ConfigType) -> ConfigType: | ||||
|     """Validate that there are no hash collisions between IDs and that area_id references are valid.""" | ||||
|     """Validate that there are no hash collisions between IDs and that area_id references are valid. | ||||
|  | ||||
|     This validation is critical because we use 32-bit hashes for performance on microcontrollers. | ||||
|     By detecting collisions at compile time, we prevent any runtime issues while maintaining | ||||
|     optimal performance on 32-bit platforms. In practice, with typical deployments having only | ||||
|     a handful of areas and devices, hash collisions are virtually impossible. | ||||
|     """ | ||||
|  | ||||
|     # Helper to check hash collisions | ||||
|     def check_hash_collision( | ||||
|   | ||||
| @@ -30,7 +30,19 @@ def ensure_unique_string(preferred_string, current_strings): | ||||
|  | ||||
|  | ||||
| def fnv1a_32bit_hash(string: str) -> int: | ||||
|     """FNV-1a 32-bit hash function.""" | ||||
|     """FNV-1a 32-bit hash function. | ||||
|  | ||||
|     Note: This uses 32-bit hash instead of 64-bit for several reasons: | ||||
|     1. ESPHome targets 32-bit microcontrollers with limited RAM (often <320KB) | ||||
|     2. Using 64-bit hashes would double the RAM usage for storing IDs | ||||
|     3. 64-bit operations are slower on 32-bit processors | ||||
|  | ||||
|     While there's a ~50% collision probability at ~77,000 unique IDs, | ||||
|     ESPHome validates for collisions at compile time, preventing any | ||||
|     runtime issues. In practice, most ESPHome installations only have | ||||
|     a handful of area_ids and device_ids (typically <10 areas and <100 | ||||
|     devices), making collisions virtually impossible. | ||||
|     """ | ||||
|     hash_value = 2166136261 | ||||
|     for char in string: | ||||
|         hash_value ^= ord(char) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user