| 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: |
| 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. |