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