2019-04-08 17:38:38 -03:00
|
|
|
#include "common.h"
|
2019-04-09 09:33:52 -03:00
|
|
|
#include "arm.h"
|
2017-07-10 01:46:52 +02:00
|
|
|
|
2019-04-08 17:38:38 -03:00
|
|
|
#include "i2c.h"
|
|
|
|
#include "pxi.h"
|
2017-07-10 01:46:52 +02:00
|
|
|
|
2019-09-02 23:34:27 -03:00
|
|
|
// buffer is allocated only once and remains through runtime
|
|
|
|
static char *i2c_xfer_buf = NULL;
|
|
|
|
|
|
|
|
static bool I2C_AllocBuffer(void)
|
2017-11-24 02:48:56 +01:00
|
|
|
{
|
2019-09-02 23:34:27 -03:00
|
|
|
if (!i2c_xfer_buf) {
|
|
|
|
u32 xbuf = PXI_DoCMD(PXI_XALLOC, (u32[]){256}, 1);
|
|
|
|
if (xbuf == 0 || xbuf == 0xFFFFFFFF)
|
|
|
|
return false;
|
|
|
|
i2c_xfer_buf = (char*)xbuf;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2017-11-24 02:48:56 +01:00
|
|
|
|
2019-09-02 23:34:27 -03:00
|
|
|
bool I2C_readRegBuf(I2cDevice devId, u8 regAddr, u8 *out, u32 size)
|
|
|
|
{
|
2019-04-08 17:38:38 -03:00
|
|
|
int ret;
|
2019-09-02 23:34:27 -03:00
|
|
|
u32 *args;
|
2016-02-13 17:29:56 +01:00
|
|
|
|
2019-09-02 23:34:27 -03:00
|
|
|
if (!I2C_AllocBuffer())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
args = (u32[]){devId, regAddr, (u32)i2c_xfer_buf, size};
|
|
|
|
|
|
|
|
ARM_WbDC_Range(i2c_xfer_buf, size);
|
2019-04-11 18:16:20 -03:00
|
|
|
ARM_DSB();
|
2016-02-13 17:29:56 +01:00
|
|
|
|
2019-04-08 17:38:38 -03:00
|
|
|
ret = PXI_DoCMD(PXI_I2C_READ, args, 4);
|
2017-11-24 02:48:56 +01:00
|
|
|
|
2019-09-02 23:34:27 -03:00
|
|
|
ARM_InvDC_Range(i2c_xfer_buf, size);
|
|
|
|
memcpy(out, i2c_xfer_buf, size);
|
2019-04-08 17:38:38 -03:00
|
|
|
return ret;
|
2016-02-13 17:29:56 +01:00
|
|
|
}
|
|
|
|
|
2019-04-08 17:38:38 -03:00
|
|
|
bool I2C_writeRegBuf(I2cDevice devId, u8 regAddr, const u8 *in, u32 size)
|
2017-07-10 01:46:52 +02:00
|
|
|
{
|
2019-04-08 17:38:38 -03:00
|
|
|
int ret;
|
2016-02-13 17:29:56 +01:00
|
|
|
|
2019-09-02 23:34:27 -03:00
|
|
|
if (!I2C_AllocBuffer())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
u32 args[] = {devId, regAddr, (u32)i2c_xfer_buf, size};
|
|
|
|
|
|
|
|
memcpy(i2c_xfer_buf, in, size);
|
|
|
|
ARM_WbDC_Range(i2c_xfer_buf, size);
|
2019-04-11 18:16:20 -03:00
|
|
|
ARM_DSB();
|
2016-02-13 17:29:56 +01:00
|
|
|
|
2019-04-08 17:38:38 -03:00
|
|
|
ret = PXI_DoCMD(PXI_I2C_WRITE, args, 4);
|
|
|
|
return ret;
|
2016-02-13 17:29:56 +01:00
|
|
|
}
|
|
|
|
|
2017-11-24 02:48:56 +01:00
|
|
|
u8 I2C_readReg(I2cDevice devId, u8 regAddr)
|
|
|
|
{
|
|
|
|
u8 data;
|
2019-04-08 17:38:38 -03:00
|
|
|
if (!I2C_readRegBuf(devId, regAddr, &data, 1))
|
|
|
|
data = 0xFF;
|
2017-11-24 02:48:56 +01:00
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool I2C_writeReg(I2cDevice devId, u8 regAddr, u8 data)
|
|
|
|
{
|
|
|
|
return I2C_writeRegBuf(devId, regAddr, &data, 1);
|
|
|
|
}
|