mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	i3c: mipi-i3c-hci: Fix DAT/DCT entry sizes
MIPI I3C HCI specification v1.1 describes the ENTRY_SIZE field for the Device Address Table (DAT) and the Device Characteristics Table (DCT) section offset registers (DAT_SECTION_OFFSET and DCT_SECTION_OFFSET). That field is not documented in earlier version. ENTRY_SIZE value 0 is meant to be backward compatible. For the DAT entry size it is interpreted as 2 DWORDs (8-bytes) and for the DCT entry size as 4 DWORDs (16-bytes). Values 1-15 are reserved for future use. New version I believe fixes also the TABLE_SIZE field description. Before it was defined in DWORDs which I believe is incorrect since the DAT/DCT table entry structures, and sizes, are described having 8-bytes/16-bytes entries. This is more clear in the specification v1.1 which states the TABLE_SIZE fields are interpreted as number of entries in the DAT/DCT tables. I believe this same holds also in earlier version, at least it makes more sense. Fix code accordingly and let the DAT_entry_size and the DCT_entry_size variables carry the size as bytes. Which is how it is already interpreted in the dat_v1.c: hci_dat_v1_init(). Signed-off-by: Jarkko Nikula <jarkko.nikula@linux.intel.com> Link: https://lore.kernel.org/r/20230921055704.1087277-4-jarkko.nikula@linux.intel.com Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This commit is contained in:
		
							parent
							
								
									f656f6bd22
								
							
						
					
					
						commit
						0676bfebf5
					
				| @ -610,17 +610,17 @@ static int i3c_hci_init(struct i3c_hci *hci) | |||||||
| 	offset = FIELD_GET(DAT_TABLE_OFFSET, regval); | 	offset = FIELD_GET(DAT_TABLE_OFFSET, regval); | ||||||
| 	hci->DAT_regs = offset ? hci->base_regs + offset : NULL; | 	hci->DAT_regs = offset ? hci->base_regs + offset : NULL; | ||||||
| 	hci->DAT_entries = FIELD_GET(DAT_TABLE_SIZE, regval); | 	hci->DAT_entries = FIELD_GET(DAT_TABLE_SIZE, regval); | ||||||
| 	hci->DAT_entry_size = FIELD_GET(DAT_ENTRY_SIZE, regval); | 	hci->DAT_entry_size = FIELD_GET(DAT_ENTRY_SIZE, regval) ? 0 : 8; | ||||||
| 	dev_info(&hci->master.dev, "DAT: %u %u-bytes entries at offset %#x\n", | 	dev_info(&hci->master.dev, "DAT: %u %u-bytes entries at offset %#x\n", | ||||||
| 		 hci->DAT_entries, hci->DAT_entry_size * 4, offset); | 		 hci->DAT_entries, hci->DAT_entry_size, offset); | ||||||
| 
 | 
 | ||||||
| 	regval = reg_read(DCT_SECTION); | 	regval = reg_read(DCT_SECTION); | ||||||
| 	offset = FIELD_GET(DCT_TABLE_OFFSET, regval); | 	offset = FIELD_GET(DCT_TABLE_OFFSET, regval); | ||||||
| 	hci->DCT_regs = offset ? hci->base_regs + offset : NULL; | 	hci->DCT_regs = offset ? hci->base_regs + offset : NULL; | ||||||
| 	hci->DCT_entries = FIELD_GET(DCT_TABLE_SIZE, regval); | 	hci->DCT_entries = FIELD_GET(DCT_TABLE_SIZE, regval); | ||||||
| 	hci->DCT_entry_size = FIELD_GET(DCT_ENTRY_SIZE, regval); | 	hci->DCT_entry_size = FIELD_GET(DCT_ENTRY_SIZE, regval) ? 0 : 16; | ||||||
| 	dev_info(&hci->master.dev, "DCT: %u %u-bytes entries at offset %#x\n", | 	dev_info(&hci->master.dev, "DCT: %u %u-bytes entries at offset %#x\n", | ||||||
| 		 hci->DCT_entries, hci->DCT_entry_size * 4, offset); | 		 hci->DCT_entries, hci->DCT_entry_size, offset); | ||||||
| 
 | 
 | ||||||
| 	regval = reg_read(RING_HEADERS_SECTION); | 	regval = reg_read(RING_HEADERS_SECTION); | ||||||
| 	offset = FIELD_GET(RING_HEADERS_OFFSET, regval); | 	offset = FIELD_GET(RING_HEADERS_OFFSET, regval); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Jarkko Nikula
						Jarkko Nikula