Hi Leif,
From: Leif Lindholm [mailto:leif.lindholm@linaro.org] Sent: Saturday, November 05, 2016 4:04 AM
On Tue, Oct 18, 2016 at 01:34:08AM +0530, Bhupesh Sharma wrote:
From: Sakar Arora Sakar.Arora@nxp.com
This patch adds a library which performs I2C bus initialization and provides I2C read and write APIs for the I2C controller present on
the
LS1043A SOC.
Signed-off-by: Meenakshi Aggarwal meenakshi.aggarwal@nxp.com Signed-off-by: Bhupesh Sharma bhupesh.sharma@nxp.com
Chips/Nxp/QoriqLs/Include/Library/I2c.h | 199 ++++++++ Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.c | 513
+++++++++++++++++++++
Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.inf | 41 ++ .../Nxp/LS1043aRdb/Include/Library/PlatformLib.h | 1 + .../Library/LS1043aSocLib/LS1043aSocLib.c | 17 + 5 files changed, 771 insertions(+) create mode 100644 Chips/Nxp/QoriqLs/Include/Library/I2c.h create mode 100644 Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.c create mode 100644 Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.inf
diff --git a/Chips/Nxp/QoriqLs/Include/Library/I2c.h b/Chips/Nxp/QoriqLs/Include/Library/I2c.h new file mode 100644 index 0000000..e9d5d61 --- /dev/null +++ b/Chips/Nxp/QoriqLs/Include/Library/I2c.h @@ -0,0 +1,199 @@ +/** @I2c.h
- Header defining the constant, base address amd function for I2C
+controller
- Copyright (c) 2016, Freescale Semiconductor, Inc. All rights
reserved.
- This program and the accompanying materials are licensed and made
- available under the terms and conditions of the BSD License which
- accompanies this distribution. The full text of the license may be
- found at http://opensource.org/licenses/bsd-license.php
- THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS"
- BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER
EXPRESS OR IMPLIED.
+**/
+#ifndef __I2C_H___ +#define __I2C_H__
The two lines above don't match.
Oops. Will fix in v2.
+#include <Uefi.h> +#include <Library/TimerLib.h>
+#define I2C0 0 +#define I2C1 1 +#define I2C2 2 +#define I2C3 3
+/// +/// Define the I2C flags +/// +/// I2C read operation when set +#define I2C_READ_FLAG 0x1 +#define I2C_WRITE_FLAG 0x2
+#define I2C_CR_IIEN (1 << 6) +#define I2C_CR_MSTA (1 << 5) +#define I2C_CR_MTX (1 << 4) +#define I2C_CR_TX_NO_AK (1 << 3) +#define I2C_CR_RSTA (1 << 2)
+#define I2C_SR_ICF (1 << 7) +#define I2C_SR_IBB (1 << 5) +#define I2C_SR_IAL (1 << 4) +#define I2C_SR_IIF (1 << 1) +#define I2C_SR_RX_NO_AK (1 << 0)
+#define I2C_CR_IEN (0 << 7) +#define I2C_CR_IDIS (1 << 7) +#define I2C_SR_IIF_CLEAR (1 << 1)
+#define BUS_IDLE (0 | (I2C_SR_IBB << 8)) #define BUS_BUSY
(I2C_SR_IBB
+| (I2C_SR_IBB << 8)) #define IIF (I2C_SR_IIF | (I2C_SR_IIF << 8))
+#define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
Can be deleted when you update to a more recent edk2.
Sure.
+/**
- Record defining i2c registers
+**/
+struct I2cRegs {
- UINT8 I2cAdr;
- UINT8 I2cFdr;
- UINT8 I2cCr;
- UINT8 I2cSr;
- UINT8 I2cDr;
+};
typedef?
Will make this a typedef in V2.
+/**
- Function to initialize i2c bus
+**/ +VOID +I2cBusInit (
VOID
- );
+/**
- Function to read data usin i2c
- @param Base A pointer to the base address of
I2c Controller
- @param Chip Address of slave device from where
data to be read
- @param Offset Offset of slave memory
- @param Alen Address length of slave
- @param Buffer A pointer to the destination buffer
for the data
- @param Len Length of data to be read
- @retval EFI_NOT_READY Arbitration lost
- @retval EFI_TIMEOUT Failed to initialize data transfer
in predefined time
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Read was successful
+**/ +EFI_STATUS +I2cDataRead (
- IN UINT32 I2cBus,
- IN UINT8 Chip,
- IN UINT32 Offset,
- IN UINT32 Alen,
- OUT UINT8 *Buffer,
- IN UINT32 Len
- );
+/**
- Function to set I2c bus speed
- @param BaseAddress Base address of I2c controller
- @param Speed value to be set
+**/ +EFI_STATUS +EFIAPI +I2cSetBusSpeed (
- IN UINT32 I2cBus,
- IN UINT32 Speed
- );
+/**
- Function to stop transaction on i2c bus
- @param I2cRegs Pointer to i2c registers
- @retval EFI_NOT_READY Arbitration was lost
- @retval EFI_TIMEOUT Timeout occured
- @retval EFI_SUCCESS Stop operation was successful
+**/ +EFI_STATUS +I2cStop (
- IN struct I2cRegs *I2cRegs
- );
+/**
- Function to initiate data transfer on i2c bus
- @param I2cRegs Pointer to i2c base registers
- @param Chip Chip Address
- @param Offset Slave memory's offset
- @param Alen length of chip address
- @retval EFI_NOT_READY Arbitration lost
- @retval EFI_TIMEOUT Failed to initialize data
transfer in predefined time
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Read was successful
+**/ +EFI_STATUS +I2cBusInitTransfer (
- IN struct I2cRegs *I2cRegs,
- IN UINT8 Chip,
- IN UINT32 Offset,
- IN INT32 Alen
- );
+/**
- Function to write data using i2c bus
- @param Base Pointer to the base address of
I2c Controller
- @param Chip Address of slave device where
data to be written
- @param Offset Offset of slave memory
- @param Alen Address length of slave
- @param Buffer A pointer to the source buffer
for the data
- @param Len Length of data to be write
- @retval EFI_NOT_READY Arbitration lost
- @retval EFI_TIMEOUT Failed to initialize data
transfer in predefined time
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Read was successful
+**/ +EFI_STATUS +I2cDataWrite (
- IN UINT32 I2cBus,
- IN UINT8 Chip,
- IN UINT32 Offset,
- IN INT32 Alen,
- OUT UINT8 *Buffer,
- IN INT32 Len
- );
+/**
- Function to reset I2c
+**/
+VOID +I2cReset (
- UINT32 I2cBus
- );
+EFI_STATUS +EFIAPI +I2cProbeDevices (
- IN INT16 I2c,
- IN UINT8 Chip
- );
+#endif diff --git a/Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.c b/Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.c new file mode 100644 index 0000000..0050783 --- /dev/null +++ b/Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.c @@ -0,0 +1,513 @@ +/** I2cLib.c
- I2c Library containing functions for read, write, initialize, set
+speed etc
- Copyright (c) 2016, Freescale Semiconductor, Inc. All rights
reserved.
- This program and the accompanying materials are licensed and made
- available under the terms and conditions of the BSD License which
- accompanies this distribution. The full text of the license may be
- found at http://opensource.org/licenses/bsd-license.php
- THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS"
- BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER
EXPRESS OR IMPLIED.
+**/
+#include <Base.h> +#include <Library/DebugLib.h> +#include <Library/IoLib.h> +#include <Library/BaseMemoryLib.h> +#include <Library/BaseMemoryLib/MemLibInternals.h> +#include <Library/BaseLib.h> +#include <Library/I2c.h>
Please sort the above alphabetically.
Ok.
+extern UINT32 I2cBusAddrArr(EFI_PHYSICAL_ADDRESS **I2cAddrArr); +extern UINT32 CalculateI2cClockRate(VOID);
These should be pulled in from an include file.
Sure.
+EFI_PHYSICAL_ADDRESS *I2cAddrArr; +UINT32 I2cAddrArrSize;
Global variables should have g or m prefix. If they're only used in this file, then m, and also make them STATIC.
Ok, thanks for the pointers :)
+UINT16 ClkDiv[60][2] = {
- { 20, 0x00 }, { 22, 0x01 }, { 24, 0x02 }, { 26, 0x03 },
- { 28, 0x04 }, { 30, 0x05 }, { 32, 0x09 }, { 34, 0x06 },
- { 36, 0x0A }, { 40, 0x07 }, { 44, 0x0C }, { 48, 0x0D },
- { 52, 0x43 }, { 56, 0x0E }, { 60, 0x45 }, { 64, 0x12 },
- { 68, 0x0F }, { 72, 0x13 }, { 80, 0x14 }, { 88, 0x15 },
- { 96, 0x19 }, { 104, 0x16 }, { 112, 0x1A }, { 128, 0x17 },
- { 136, 0x4F }, { 144, 0x1C }, { 160, 0x1D }, { 176, 0x55 },
- { 192, 0x1E }, { 208, 0x56 }, { 224, 0x22 }, { 228, 0x24 },
- { 240, 0x1F }, { 256, 0x23 }, { 288, 0x5C }, { 320, 0x25 },
- { 384, 0x26 }, { 448, 0x2A }, { 480, 0x27 }, { 512, 0x2B },
- { 576, 0x2C }, { 640, 0x2D }, { 768, 0x31 }, { 896, 0x32 },
- { 960, 0x2F }, { 1024, 0x33 }, { 1152, 0x34 },{ 1280, 0x35 },
- { 1536, 0x36 }, { 1792, 0x3A }, { 1920, 0x37 }, { 2048, 0x3B },
- { 2304, 0x3C }, { 2560, 0x3D }, { 3072, 0x3E }, { 3584, 0x7A },
- { 3840, 0x3F }, { 4096, 0x7B }, { 5120, 0x7D }, { 6144, 0x7E }, };
+/**
- Calculate and set proper clock divider
- @param Rate clock rate
- @retval ClkDiv Value used to get frequency divider value
+**/
STATIC?
Ok.
+UINT8 +GetClk(
- IN UINT32 Rate
- )
+{
- UINTN ClkRate;
- UINT32 Div;
- UINT8 ClkDivx;
- ClkRate = CalculateI2cClockRate();
- Div = (ClkRate + Rate - 1) / Rate;
- if (Div < ClkDiv[0][0])
- ClkDivx = 0;
- else if (Div > ClkDiv[ARRAY_SIZE(ClkDiv) - 1][0])
- ClkDivx = ARRAY_SIZE(ClkDiv) - 1; else
- for (ClkDivx = 0; ClkDiv[ClkDivx][0] < Div; ClkDivx++);
- return ClkDivx;
+}
+/**
- Function to reset I2C module
+**/
+VOID +I2cReset (
- UINT32 I2cBus
- )
+{
- struct I2cRegs *I2cRegs = (struct I2cRegs *)I2cAddrArr[I2cBus];
- /** Reset module */
- MmioWrite8((UINTN)&I2cRegs->I2cCr, I2C_CR_IDIS);
- MmioWrite8((UINTN)&I2cRegs->I2cSr, 0); }
+/**
- Function to set I2c bus speed
- @param BaseAddress Base address of I2c controller
- @param Speed value to be set
+**/ +EFI_STATUS +EFIAPI +I2cSetBusSpeed (
- IN UINT32 I2cBus,
- IN UINT32 Speed
- )
+{
- struct I2cRegs *I2cRegs = (struct I2cRegs *)I2cAddrArr[I2cBus];
- ASSERT(I2cRegs);
- UINT8 ClkId = GetClk(Speed);
- UINT8 SpeedId = ClkDiv[ClkId][1];
- /** Store divider value */
- MmioWrite8((UINTN)&I2cRegs->I2cFdr, SpeedId); I2cReset(I2cBus);
- return EFI_SUCCESS;
+}
+/**
- Function used to check if i2c is in mentioned state or not
- @param I2cRegs Pointer to I2C registers
- @param State i2c state need to be checked
- @retval EFI_NOT_READY Arbitration was lost
- @retval EFI_TIMEOUT Timeout occured
- @retval CurrState Value of state register
+**/ +EFI_STATUS +WaitForI2cState (
- IN struct I2cRegs *I2cRegs,
- IN UINT32 State
- )
+{
- UINT8 CurrState;
- UINT64 Cnt = 0;
- for (Cnt = 0; Cnt < 50; Cnt++) {
- CurrState = MmioRead8((UINTN)&I2cRegs->I2cSr);
- if (CurrState & I2C_SR_IAL) {
MmioWrite8((UINTN)&I2cRegs->I2cSr, CurrState | I2C_SR_IAL);
return EFI_NOT_READY;
- }
- if ((CurrState & (State >> 8)) == (UINT8)State)
return CurrState;
- MicroSecondDelay(300);
Why 300?
Ok, will add appropriate comment here.
- }
- return EFI_TIMEOUT;
+}
+/**
- Function to transfer byte on i2c
- @param I2cRegs Pointer to i2c registers
- @param Byte Byte to be transferred on i2c bus
- @retval EFI_NOT_READY Arbitration was lost
- @retval EFI_TIMEOUT Timeout occured
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Data transfer was succesful
+**/
STATIC?
Ok.
+EFI_STATUS +TransferByte (
- IN struct I2cRegs *I2cRegs,
- IN UINT8 Byte
- )
+{
- EFI_STATUS Ret;
- MmioWrite8((UINTN)&I2cRegs->I2cSr, I2C_SR_IIF_CLEAR);
- MmioWrite8((UINTN)&I2cRegs->I2cDr, Byte);
- Ret = WaitForI2cState(I2cRegs, IIF); if ((Ret == EFI_TIMEOUT) ||
- (Ret == EFI_NOT_READY))
- return Ret;
- if (Ret & I2C_SR_RX_NO_AK) {
- return EFI_NOT_FOUND;
- }
- return EFI_SUCCESS;
+}
+/**
- Function to stop transaction on i2c bus
- @param I2cRegs Pointer to i2c registers
- @retval EFI_NOT_READY Arbitration was lost
- @retval EFI_TIMEOUT Timeout occured
- @retval EFI_SUCCESS Stop operation was successful
+**/ +EFI_STATUS +I2cStop (
- IN struct I2cRegs *I2cRegs
- )
+{
- INT32 Ret;
- UINT32 Temp = MmioRead8((UINTN)&I2cRegs->I2cCr);
- Temp &= ~(I2C_CR_MSTA | I2C_CR_MTX);
- MmioWrite8((UINTN)&I2cRegs->I2cCr, Temp); Ret =
- WaitForI2cState(I2cRegs, BUS_IDLE); if (Ret < 0)
Always braces with if/else.
Sure.
- return Ret;
- else
- return EFI_SUCCESS;
+}
+/**
- Function to send start signal, Chip Address and
- memory offset
- @param I2cRegs Pointer to i2c base registers
- @param Chip Chip Address
- @param Offset Slave memory's offset
- @param Alen length of chip address
- @retval EFI_NOT_READY Arbitration lost
- @retval EFI_TIMEOUT Failed to initialize data
transfer in predefined time
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Read was successful
+**/ +EFI_STATUS +InitTransfer (
- IN struct I2cRegs *I2cRegs,
- IN UINT8 Chip,
- IN UINT32 Offset,
- IN INT32 Alen
- )
+{
- UINT32 Temp;
- EFI_STATUS Ret;
- /** Enable I2C controller */
- if (MmioRead8((UINTN)&I2cRegs->I2cCr) & I2C_CR_IDIS)
Always braces with if/else. (please address globally)
Ok.
- MmioWrite8((UINTN)&I2cRegs->I2cCr, I2C_CR_IEN);
- if (MmioRead8((UINTN)&I2cRegs->I2cAdr) == (Chip << 1))
- MmioWrite8((UINTN)&I2cRegs->I2cAdr, (Chip << 1) ^ 2);
- MmioWrite8((UINTN)&I2cRegs->I2cSr, I2C_SR_IIF_CLEAR); Ret =
- WaitForI2cState(I2cRegs, BUS_IDLE); if ((Ret == EFI_TIMEOUT) ||
- (Ret == EFI_NOT_READY))
- return Ret;
- /** Start I2C transaction */
- Temp = MmioRead8((UINTN)&I2cRegs->I2cCr);
- /** set to master mode */
- Temp |= I2C_CR_MSTA;
- MmioWrite8((UINTN)&I2cRegs->I2cCr, Temp);
- Ret = WaitForI2cState(I2cRegs, BUS_BUSY); if ((Ret ==
EFI_TIMEOUT)
- || (Ret == EFI_NOT_READY))
- return Ret;
- Temp |= I2C_CR_MTX | I2C_CR_TX_NO_AK;
- MmioWrite8((UINTN)&I2cRegs->I2cCr, Temp);
- /** write slave Address */
- Ret = TransferByte(I2cRegs, Chip << 1);
Can we have a macro instead of that inline <<?
Yes, will change in V2.
- if (Ret != EFI_SUCCESS)
- return Ret;
- if (Alen >= 0) {
- while (Alen--) {
Ret = TransferByte(I2cRegs, (Offset >> (Alen * 8)) & 0xff);
Can we have a macro instead of that inline Offset/Alen manipulation?
Yes, will change in V2.
if (Ret != EFI_SUCCESS)
return Ret;
- }
- }
- return EFI_SUCCESS;
+}
+/**
- Function to check if i2c bud is idle
- @param Base Pointer to base address of I2c controller
- @retval EFI_SUCCESS
+**/ +INT32 +I2cBusIdle (
- IN VOID *Base
- )
+{
- return EFI_SUCCESS;
+}
+/**
- Function to initiate data transfer on i2c bus
- @param I2cRegs Pointer to i2c base registers
- @param Chip Chip Address
- @param Offset Slave memory's offset
- @param Alen length of chip address
- @retval EFI_NOT_READY Arbitration lost
- @retval EFI_TIMEOUT Failed to initialize data
transfer in predefined time
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Read was successful
+**/ +EFI_STATUS +InitDataTransfer (
- IN struct I2cRegs *I2cRegs,
- IN UINT8 Chip,
- IN UINT32 Offset,
- IN INT32 Alen
- )
+{
- INT32 Retry;
- EFI_STATUS Ret;
- for (Retry = 0; Retry < 3; Retry++) {
- Ret = InitTransfer(I2cRegs, Chip, Offset, Alen);
- if (Ret == EFI_SUCCESS)
return EFI_SUCCESS;
- I2cStop(I2cRegs);
- if (EFI_NOT_FOUND == Ret) {
return Ret;
- }
- /** Disable controller */
- if (Ret != EFI_NOT_READY)
MmioWrite8((UINTN)&I2cRegs->I2cCr, I2C_CR_IDIS);
- if (I2cBusIdle(I2cRegs) < 0)
break;
- }
- return Ret;
+}
+/**
- Function to read data using i2c bus
- @param Base A pointer to the base address of
I2c Controller
- @param Chip Address of slave device from
where data to be read
- @param Offset Offset of slave memory
- @param Alen Address length of slave
- @param Buffer A pointer to the destination
buffer for the data
- @param Len Length of data to be read
- @retval EFI_NOT_READY Arbitration lost
- @retval EFI_TIMEOUT Failed to initialize data
transfer in predefined time
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Read was successful
+**/ +EFI_STATUS +I2cDataRead (
- IN UINT32 I2cBus,
- IN UINT8 Chip,
- IN UINT32 Offset,
- IN UINT32 Alen,
- IN UINT8 *Buffer,
- IN UINT32 Len
- )
+{
- EFI_STATUS Ret;
- UINT32 Temp;
- INT32 i;
- struct I2cRegs *I2cRegs = (struct I2cRegs *)I2cAddrArr[I2cBus];
- ASSERT(I2cRegs);
- Ret = InitDataTransfer(I2cRegs, Chip, Offset, Alen);
- if (Ret != EFI_SUCCESS)
- return Ret;
- Temp = MmioRead8((UINTN)&I2cRegs->I2cCr);
- Temp |= I2C_CR_RSTA;
- MmioWrite8((UINTN)&I2cRegs->I2cCr, Temp);
- Ret = TransferByte(I2cRegs, (Chip << 1) | 1);
Can we have a macro instead of that inline manipulation of Chip? Or can the prototype of TransferByte be extended to make the code more obvious?
Yes, will change in V2.
- if (Ret != EFI_SUCCESS) {
- I2cStop(I2cRegs);
- return Ret;
- }
- /** setup bus to read data */
- Temp = MmioRead8((UINTN)&I2cRegs->I2cCr);
- Temp &= ~(I2C_CR_MTX | I2C_CR_TX_NO_AK); if (Len == 1)
- Temp |= I2C_CR_TX_NO_AK;
- MmioWrite8((UINTN)&I2cRegs->I2cCr, Temp);
- MmioWrite8((UINTN)&I2cRegs->I2cSr, I2C_SR_IIF_CLEAR);
- /** read data */
- /** Dummy Read to initiate recieve operation */
- MmioRead8((UINTN)&I2cRegs->I2cDr);
- for (i = 0; i < Len; i++) {
- Ret = WaitForI2cState(I2cRegs, IIF);
- if ((Ret == EFI_TIMEOUT) || (Ret == EFI_NOT_READY)) {
I2cStop(I2cRegs);
return Ret;
- }
- /**
It must generate STOP before read I2DR to prevent
controller from generating another clock cycle
- **/
- if (i == (Len - 1)) {
I2cStop(I2cRegs);
- } else if (i == (Len - 2)) {
Temp = MmioRead8((UINTN)&I2cRegs->I2cCr);
Temp |= I2C_CR_TX_NO_AK;
MmioWrite8((UINTN)&I2cRegs->I2cCr, Temp);
- }
- MmioWrite8((UINTN)&I2cRegs->I2cSr, I2C_SR_IIF_CLEAR);
- Buffer[i] = MmioRead8((UINTN)&I2cRegs->I2cDr);
- }
- I2cStop(I2cRegs);
- return EFI_SUCCESS;
+}
+/**
- Function to write data using i2c bus
- @param Base Pointer to the base address of
I2c Controller
- @param Chip Address of slave device where
data to be written
- @param Offset Offset of slave memory
- @param Alen Address length of slave
- @param Buffer A pointer to the source buffer
for the data
- @param Len Length of data to be write
- @retval EFI_NOT_READY Arbitration lost
- @retval EFI_TIMEOUT Failed to initialize data
transfer in predefined time
- @retval EFI_NOT_FOUND ACK was not recieved
- @retval EFI_SUCCESS Read was successful
+**/ +EFI_STATUS +I2cDataWrite (
- IN UINT32 I2cBus,
- IN UINT8 Chip,
- IN UINT32 Offset,
- IN INT32 Alen,
- OUT UINT8 *Buffer,
- IN INT32 Len
- )
+{
- EFI_STATUS Ret;
- INT32 I;
- struct I2cRegs *I2cRegs = (struct I2cRegs *)I2cAddrArr[I2cBus];
- ASSERT(I2cRegs);
- Ret = InitDataTransfer(I2cRegs, Chip, Offset, Alen); if (Ret !=
- EFI_SUCCESS)
- return Ret;
- /** write data */
- /** Dummy write to initiate write operation */
- for (I = 0; I < Len; I++) {
- Ret = TransferByte(I2cRegs, Buffer[I]);
- if (Ret != EFI_SUCCESS)
break;
- }
- I2cStop(I2cRegs);
- return Ret;
+}
+/**
- Function to Probe i2c bus
- @param I2c parameter defining I2c controller
no
- @retval EFI_INVALID_PARAMETER Input parametr I2c was invalid
- @retval EFI_SUCCESS I2c was initialized successfully
+**/ +EFI_STATUS +EFIAPI +I2cProbeDevices (
- IN INT16 I2c,
- IN UINT8 ChipAdd
- )
+{
- ASSERT(I2cAddrArr);
- if(I2c >= I2cAddrArrSize || I2cAddrArr[I2c] == 0x0)
Parenthesis around each comparison statement, please.
Ok.
- return EFI_INVALID_PARAMETER;
- return I2cDataWrite(I2c, ChipAdd, 0, 0, NULL, 0); }
+/**
- Function to initialize i2c bus
+**/ +VOID +I2cBusInit (
VOID
- )
+{
- I2cAddrArrSize = I2cBusAddrArr(&I2cAddrArr); }
diff --git a/Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.inf b/Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.inf new file mode 100644 index 0000000..f148c36 --- /dev/null +++ b/Chips/Nxp/QoriqLs/Library/I2cLib/I2cLib.inf @@ -0,0 +1,41 @@ +#/** I2cLib.inf +# +# Component description file for I2cLib module # # Copyright (c) +2016, Freescale Semiconductor, Inc. All rights reserved. +# +# This program and the accompanying materials # are licensed and +made available under the terms and conditions of the BSD License # +which accompanies this distribution. The full text of the license
may
+be found at # http://opensource.org/licenses/bsd-license.php +# +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" +BASIS, # WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER
EXPRESS OR IMPLIED.
+# +#**/
+[Defines]
- INF_VERSION = 0x00010005
- BASE_NAME = I2cLib
- FILE_GUID = 8ecefc8f-a2c4-4091-b81f-
20f7aeb0567f
- MODULE_TYPE = BASE
- VERSION_STRING = 1.0
- LIBRARY_CLASS = I2cLib
+[Sources.common]
- I2cLib.c
+[LibraryClasses]
- ArmLib
- IoLib
- BaseMemoryLib
- BaseLib
- SocLib
- TimerLib
+[Packages]
- EmbeddedPkg/EmbeddedPkg.dec
- MdePkg/MdePkg.dec
- MdeModulePkg/MdeModulePkg.dec
- ArmPlatformPkg/ArmPlatformPkg.dec
- OpenPlatformPkg/Chips/Nxp/QoriqLs/NxpQoriqLs.dec
Please sort file names and LibraryClasses in this file.
Ok.
diff --git a/Platforms/Nxp/LS1043aRdb/Include/Library/PlatformLib.h b/Platforms/Nxp/LS1043aRdb/Include/Library/PlatformLib.h index 39247e8..a4d26e8 100644 --- a/Platforms/Nxp/LS1043aRdb/Include/Library/PlatformLib.h +++ b/Platforms/Nxp/LS1043aRdb/Include/Library/PlatformLib.h @@ -73,6 +73,7 @@ #define I2C2_BASE_ADDRESS 0x021A0000 #define I2C3_BASE_ADDRESS 0x02183000 #define I2C_SIZE 0x10000
- #define I2C_BUS_MAX 4 #define DSPI_MEMORY_SIZE 0x10000 #define DDRC_MEMORY_SIZE 0x10000 #define SDXC_MEMORY_SIZE 0x10000
diff --git a/Platforms/Nxp/LS1043aRdb/Library/LS1043aSocLib/LS1043aSocLib.c b/Platforms/Nxp/LS1043aRdb/Library/LS1043aSocLib/LS1043aSocLib.c index 2a7cb38..8a2a0e0 100644 --- a/Platforms/Nxp/LS1043aRdb/Library/LS1043aSocLib/LS1043aSocLib.c +++ b/Platforms/Nxp/LS1043aRdb/Library/LS1043aSocLib/LS1043aSocLib.c @@ -115,6 +115,13 @@ static struct CsuNsDev NonSecureDevices[] = {SEC_UNIT_CSLX_DSCR, SEC_UNIT_ALL_RW}, };
+EFI_PHYSICAL_ADDRESS I2cAddress[] = {
(EFI_PHYSICAL_ADDRESS)I2C0_BASE_ADDRESS,
(EFI_PHYSICAL_ADDRESS)I2C1_BASE_ADDRESS,
(EFI_PHYSICAL_ADDRESS)I2C2_BASE_ADDRESS,
(EFI_PHYSICAL_ADDRESS)I2C3_BASE_ADDRESS
+};
char *StringToMHz ( char *Buf, unsigned long Hz @@ -800,3 +807,13 @@ CalculateI2cClockRate(
return SocSysInfo.FreqSystemBus; }
+UINT32 +I2cBusAddrArr(
EFI_PHYSICAL_ADDRESS **Arr
)
+{
- *Arr = (EFI_PHYSICAL_ADDRESS*)I2cAddress;
- return I2C_BUS_MAX;
+}
1.9.1