[rtems commit] i2c: Fix endian issue
Sebastian Huber
sebh at rtems.org
Mon Nov 24 10:58:12 UTC 2014
Module: rtems
Branch: master
Commit: cfc53c11b32f55003c63ad2051b47fa34a095841
Changeset: http://git.rtems.org/rtems/commit/?id=cfc53c11b32f55003c63ad2051b47fa34a095841
Author: Sebastian Huber <sebastian.huber at embedded-brains.de>
Date: Mon Nov 24 11:55:44 2014 +0100
i2c: Fix endian issue
---
cpukit/dev/i2c/gpio-nxp-pca9535.c | 23 ++++++++++++++---------
1 file changed, 14 insertions(+), 9 deletions(-)
diff --git a/cpukit/dev/i2c/gpio-nxp-pca9535.c b/cpukit/dev/i2c/gpio-nxp-pca9535.c
index 65df969..ea56cee 100644
--- a/cpukit/dev/i2c/gpio-nxp-pca9535.c
+++ b/cpukit/dev/i2c/gpio-nxp-pca9535.c
@@ -43,22 +43,27 @@ static int gpio_nxp_pca9535_get_reg(
uint16_t *val
)
{
- uint8_t buf[1] = { port };
+ uint8_t out[1] = { port };
+ uint8_t in[sizeof(*val)];
i2c_msg msgs[2] = {
{
.addr = dev->address,
.flags = 0,
- .len = (uint16_t) sizeof(buf),
- .buf = &buf[0]
+ .len = (uint16_t) sizeof(out),
+ .buf = &out[0]
}, {
.addr = dev->address,
.flags = I2C_M_RD,
- .len = (uint16_t) sizeof(*val),
- .buf = (uint8_t *) val
+ .len = (uint16_t) sizeof(in),
+ .buf = &in[0]
}
};
+ int err;
- return i2c_bus_transfer(dev->bus, &msgs[0], RTEMS_ARRAY_SIZE(msgs));
+ err = i2c_bus_transfer(dev->bus, &msgs[0], RTEMS_ARRAY_SIZE(msgs));
+ *val = in[0] | (in[1] << 8);
+
+ return err;
}
static int gpio_nxp_pca9535_set_reg(
@@ -67,13 +72,13 @@ static int gpio_nxp_pca9535_set_reg(
uint16_t val
)
{
- uint8_t buf[3] = { port, (uint8_t) val, (uint8_t) (val >> 8) };
+ uint8_t out[3] = { port, (uint8_t) val, (uint8_t) (val >> 8) };
i2c_msg msgs[1] = {
{
.addr = dev->address,
.flags = 0,
- .len = (uint16_t) sizeof(buf),
- .buf = &buf[0]
+ .len = (uint16_t) sizeof(out),
+ .buf = &out[0]
}
};
More information about the vc
mailing list