|
@@ -144,49 +144,52 @@ static int start_i2c_msg_xfer(struct slimpro_i2c_dev *ctx)
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
-static int slimpro_i2c_rd(struct slimpro_i2c_dev *ctx, u32 chip,
|
|
|
|
- u32 addr, u32 addrlen, u32 protocol,
|
|
|
|
- u32 readlen, u32 *data)
|
|
|
|
|
|
+static int slimpro_i2c_send_msg(struct slimpro_i2c_dev *ctx,
|
|
|
|
+ u32 *msg,
|
|
|
|
+ u32 *data)
|
|
{
|
|
{
|
|
- u32 msg[3];
|
|
|
|
int rc;
|
|
int rc;
|
|
|
|
|
|
- msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip,
|
|
|
|
- SLIMPRO_IIC_READ, protocol, addrlen, readlen);
|
|
|
|
- msg[1] = SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
|
|
- msg[2] = 0;
|
|
|
|
ctx->resp_msg = data;
|
|
ctx->resp_msg = data;
|
|
- rc = mbox_send_message(ctx->mbox_chan, &msg);
|
|
|
|
|
|
+
|
|
|
|
+ rc = mbox_send_message(ctx->mbox_chan, msg);
|
|
if (rc < 0)
|
|
if (rc < 0)
|
|
goto err;
|
|
goto err;
|
|
|
|
|
|
rc = start_i2c_msg_xfer(ctx);
|
|
rc = start_i2c_msg_xfer(ctx);
|
|
|
|
+
|
|
err:
|
|
err:
|
|
ctx->resp_msg = NULL;
|
|
ctx->resp_msg = NULL;
|
|
|
|
+
|
|
return rc;
|
|
return rc;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static int slimpro_i2c_rd(struct slimpro_i2c_dev *ctx, u32 chip,
|
|
|
|
+ u32 addr, u32 addrlen, u32 protocol,
|
|
|
|
+ u32 readlen, u32 *data)
|
|
|
|
+{
|
|
|
|
+ u32 msg[3];
|
|
|
|
+
|
|
|
|
+ msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip,
|
|
|
|
+ SLIMPRO_IIC_READ, protocol, addrlen, readlen);
|
|
|
|
+ msg[1] = SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
|
|
+ msg[2] = 0;
|
|
|
|
+
|
|
|
|
+ return slimpro_i2c_send_msg(ctx, msg, data);
|
|
|
|
+}
|
|
|
|
+
|
|
static int slimpro_i2c_wr(struct slimpro_i2c_dev *ctx, u32 chip,
|
|
static int slimpro_i2c_wr(struct slimpro_i2c_dev *ctx, u32 chip,
|
|
u32 addr, u32 addrlen, u32 protocol, u32 writelen,
|
|
u32 addr, u32 addrlen, u32 protocol, u32 writelen,
|
|
u32 data)
|
|
u32 data)
|
|
{
|
|
{
|
|
u32 msg[3];
|
|
u32 msg[3];
|
|
- int rc;
|
|
|
|
|
|
|
|
msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip,
|
|
msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip,
|
|
SLIMPRO_IIC_WRITE, protocol, addrlen, writelen);
|
|
SLIMPRO_IIC_WRITE, protocol, addrlen, writelen);
|
|
msg[1] = SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
msg[1] = SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
msg[2] = data;
|
|
msg[2] = data;
|
|
- ctx->resp_msg = msg;
|
|
|
|
-
|
|
|
|
- rc = mbox_send_message(ctx->mbox_chan, &msg);
|
|
|
|
- if (rc < 0)
|
|
|
|
- goto err;
|
|
|
|
|
|
|
|
- rc = start_i2c_msg_xfer(ctx);
|
|
|
|
-err:
|
|
|
|
- ctx->resp_msg = NULL;
|
|
|
|
- return rc;
|
|
|
|
|
|
+ return slimpro_i2c_send_msg(ctx, msg, msg);
|
|
}
|
|
}
|
|
|
|
|
|
static int slimpro_i2c_blkrd(struct slimpro_i2c_dev *ctx, u32 chip, u32 addr,
|
|
static int slimpro_i2c_blkrd(struct slimpro_i2c_dev *ctx, u32 chip, u32 addr,
|
|
@@ -201,8 +204,7 @@ static int slimpro_i2c_blkrd(struct slimpro_i2c_dev *ctx, u32 chip, u32 addr,
|
|
if (dma_mapping_error(ctx->dev, paddr)) {
|
|
if (dma_mapping_error(ctx->dev, paddr)) {
|
|
dev_err(&ctx->adapter.dev, "Error in mapping dma buffer %p\n",
|
|
dev_err(&ctx->adapter.dev, "Error in mapping dma buffer %p\n",
|
|
ctx->dma_buffer);
|
|
ctx->dma_buffer);
|
|
- rc = -ENOMEM;
|
|
|
|
- goto err;
|
|
|
|
|
|
+ return -ENOMEM;
|
|
}
|
|
}
|
|
|
|
|
|
msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip, SLIMPRO_IIC_READ,
|
|
msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip, SLIMPRO_IIC_READ,
|
|
@@ -212,21 +214,13 @@ static int slimpro_i2c_blkrd(struct slimpro_i2c_dev *ctx, u32 chip, u32 addr,
|
|
SLIMPRO_IIC_ENCODE_UPPER_BUFADDR(paddr) |
|
|
SLIMPRO_IIC_ENCODE_UPPER_BUFADDR(paddr) |
|
|
SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
msg[2] = (u32)paddr;
|
|
msg[2] = (u32)paddr;
|
|
- ctx->resp_msg = msg;
|
|
|
|
|
|
|
|
- rc = mbox_send_message(ctx->mbox_chan, &msg);
|
|
|
|
- if (rc < 0)
|
|
|
|
- goto err_unmap;
|
|
|
|
-
|
|
|
|
- rc = start_i2c_msg_xfer(ctx);
|
|
|
|
|
|
+ rc = slimpro_i2c_send_msg(ctx, msg, msg);
|
|
|
|
|
|
/* Copy to destination */
|
|
/* Copy to destination */
|
|
memcpy(data, ctx->dma_buffer, readlen);
|
|
memcpy(data, ctx->dma_buffer, readlen);
|
|
|
|
|
|
-err_unmap:
|
|
|
|
dma_unmap_single(ctx->dev, paddr, readlen, DMA_FROM_DEVICE);
|
|
dma_unmap_single(ctx->dev, paddr, readlen, DMA_FROM_DEVICE);
|
|
-err:
|
|
|
|
- ctx->resp_msg = NULL;
|
|
|
|
return rc;
|
|
return rc;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -244,8 +238,7 @@ static int slimpro_i2c_blkwr(struct slimpro_i2c_dev *ctx, u32 chip,
|
|
if (dma_mapping_error(ctx->dev, paddr)) {
|
|
if (dma_mapping_error(ctx->dev, paddr)) {
|
|
dev_err(&ctx->adapter.dev, "Error in mapping dma buffer %p\n",
|
|
dev_err(&ctx->adapter.dev, "Error in mapping dma buffer %p\n",
|
|
ctx->dma_buffer);
|
|
ctx->dma_buffer);
|
|
- rc = -ENOMEM;
|
|
|
|
- goto err;
|
|
|
|
|
|
+ return -ENOMEM;
|
|
}
|
|
}
|
|
|
|
|
|
msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip, SLIMPRO_IIC_WRITE,
|
|
msg[0] = SLIMPRO_IIC_ENCODE_MSG(SLIMPRO_IIC_BUS, chip, SLIMPRO_IIC_WRITE,
|
|
@@ -254,21 +247,13 @@ static int slimpro_i2c_blkwr(struct slimpro_i2c_dev *ctx, u32 chip,
|
|
SLIMPRO_IIC_ENCODE_UPPER_BUFADDR(paddr) |
|
|
SLIMPRO_IIC_ENCODE_UPPER_BUFADDR(paddr) |
|
|
SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
SLIMPRO_IIC_ENCODE_ADDR(addr);
|
|
msg[2] = (u32)paddr;
|
|
msg[2] = (u32)paddr;
|
|
- ctx->resp_msg = msg;
|
|
|
|
|
|
|
|
if (ctx->mbox_client.tx_block)
|
|
if (ctx->mbox_client.tx_block)
|
|
reinit_completion(&ctx->rd_complete);
|
|
reinit_completion(&ctx->rd_complete);
|
|
|
|
|
|
- rc = mbox_send_message(ctx->mbox_chan, &msg);
|
|
|
|
- if (rc < 0)
|
|
|
|
- goto err_unmap;
|
|
|
|
-
|
|
|
|
- rc = start_i2c_msg_xfer(ctx);
|
|
|
|
|
|
+ rc = slimpro_i2c_send_msg(ctx, msg, msg);
|
|
|
|
|
|
-err_unmap:
|
|
|
|
dma_unmap_single(ctx->dev, paddr, writelen, DMA_TO_DEVICE);
|
|
dma_unmap_single(ctx->dev, paddr, writelen, DMA_TO_DEVICE);
|
|
-err:
|
|
|
|
- ctx->resp_msg = NULL;
|
|
|
|
return rc;
|
|
return rc;
|
|
}
|
|
}
|
|
|
|
|