|  | Driver i2c-mlxcpld | 
|  |  | 
|  | Author: Michael Shych <michaelsh@mellanox.com> | 
|  |  | 
|  | This is the Mellanox I2C controller logic, implemented in Lattice CPLD | 
|  | device. | 
|  | Device supports: | 
|  | - Master mode. | 
|  | - One physical bus. | 
|  | - Polling mode. | 
|  |  | 
|  | This controller is equipped within the next Mellanox systems: | 
|  | "msx6710", "msx6720", "msb7700", "msn2700", "msx1410", "msn2410", "msb7800", | 
|  | "msn2740", "msn2100". | 
|  |  | 
|  | The next transaction types are supported: | 
|  | - Receive Byte/Block. | 
|  | - Send Byte/Block. | 
|  | - Read Byte/Block. | 
|  | - Write Byte/Block. | 
|  |  | 
|  | Registers: | 
|  | CPBLTY		0x0 - capability reg. | 
|  | Bits [6:5] - transaction length. b01 - 72B is supported, | 
|  | 36B in other case. | 
|  | Bit 7 - SMBus block read support. | 
|  | CTRL		0x1 - control reg. | 
|  | Resets all the registers. | 
|  | HALF_CYC	0x4 - cycle reg. | 
|  | Configure the width of I2C SCL half clock cycle (in 4 LPC_CLK | 
|  | units). | 
|  | I2C_HOLD	0x5 - hold reg. | 
|  | OE (output enable) is delayed by value set to this register | 
|  | (in LPC_CLK units) | 
|  | CMD			0x6 - command reg. | 
|  | Bit 0, 0 = write, 1 = read. | 
|  | Bits [7:1] - the 7bit Address of the I2C device. | 
|  | It should be written last as it triggers an I2C transaction. | 
|  | NUM_DATA	0x7 - data size reg. | 
|  | Number of data bytes to write in read transaction | 
|  | NUM_ADDR	0x8 - address reg. | 
|  | Number of address bytes to write in read transaction. | 
|  | STATUS		0x9 - status reg. | 
|  | Bit 0 - transaction is completed. | 
|  | Bit 4 - ACK/NACK. | 
|  | DATAx		0xa - 0x54  - 68 bytes data buffer regs. | 
|  | For write transaction address is specified in four first bytes | 
|  | (DATA1 - DATA4), data starting from DATA4. | 
|  | For read transactions address is sent in a separate transaction and | 
|  | specified in the four first bytes (DATA0 - DATA3). Data is read | 
|  | starting from DATA0. |