update structs
This commit is contained in:
		
							
								
								
									
										21
									
								
								Hwid.md
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								Hwid.md
									
									
									
									
									
								
							| @@ -50,8 +50,8 @@ The Hardware ID is a magical data structure built by evaluationg the system's ha | ||||
| ```c | ||||
| struct HWID_BLOCK { | ||||
|     uint16_t wSize; | ||||
|     uint16_t wVersion; // 0 for all tools | ||||
|     uint16_t threshold; // (TBV) Set to 0x13 | ||||
|     uint16_t wVersion; // 0 for all | ||||
|     uint16_t threshold; // Set to 0x13 | ||||
|     struct HWID hwid; // variable length | ||||
|     struct TIMEWEIGHT tw; // variable length | ||||
| } | ||||
| @@ -61,17 +61,22 @@ struct HWID_BLOCK { | ||||
|  | ||||
| ```c | ||||
| struct HWID { | ||||
|     uint32_t dwSize; // no version here, I think | ||||
|     uint16_t nInstances[9]; | ||||
|     uint16_t bDockOrPCMCIA; | ||||
|     uint16_t size; | ||||
|     uint16_t version; | ||||
|     uint16_t instances[9]; | ||||
|     uint16_t dock_or_PCMCIA; | ||||
|     uint16_t hashRAM; | ||||
|     uint16_t hashSMBIOS; | ||||
|     uint16_t instanceHashes[nInstances]; | ||||
| } | ||||
|     uint16_t hashBIOS; | ||||
|     uint16_t instanceHashes[]; | ||||
| }; | ||||
| ``` | ||||
|  | ||||
| The hashes are all SHA-256 truncated to 15 bits; the 16th bit is set to whether the device is removable (1 if removable). | ||||
|  | ||||
| #### `version` | ||||
|  | ||||
| This is the version of the hardware ID. It is set to `0` for all implementations I'm aware of. | ||||
|  | ||||
| #### `nInstances` | ||||
|  | ||||
| This is an array of 9 counts of instances of hardware per type of hardware. The types are, in order (by 0-based index): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 awuctl
					awuctl