]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - drivers/staging/iio/meter/ade7854-spi.c
staging:iio:meter remove stubs from ade7854.
[karo-tx-linux.git] / drivers / staging / iio / meter / ade7854-spi.c
index fe58103ed4ca1aed737b41bfb5119026259c60a5..84da8fbde022b4a7f76eb21b0586e11288f71702 100644 (file)
@@ -22,12 +22,10 @@ static int ade7854_spi_write_reg_8(struct device *dev,
        struct spi_message msg;
        struct iio_dev *indio_dev = dev_get_drvdata(dev);
        struct ade7854_state *st = iio_dev_get_devdata(indio_dev);
-       struct spi_transfer xfers[] = {
-               {
-                       .tx_buf = st->tx,
-                       .bits_per_word = 8,
-                       .len = 4,
-               }
+       struct spi_transfer xfer = {
+               .tx_buf = st->tx,
+               .bits_per_word = 8,
+               .len = 4,
        };
 
        mutex_lock(&st->buf_lock);
@@ -37,7 +35,7 @@ static int ade7854_spi_write_reg_8(struct device *dev,
        st->tx[3] = value & 0xFF;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfer, &msg);
        ret = spi_sync(st->spi, &msg);
        mutex_unlock(&st->buf_lock);
 
@@ -52,12 +50,10 @@ static int ade7854_spi_write_reg_16(struct device *dev,
        struct spi_message msg;
        struct iio_dev *indio_dev = dev_get_drvdata(dev);
        struct ade7854_state *st = iio_dev_get_devdata(indio_dev);
-       struct spi_transfer xfers[] = {
-               {
-                       .tx_buf = st->tx,
-                       .bits_per_word = 8,
-                       .len = 5,
-               }
+       struct spi_transfer xfer = {
+               .tx_buf = st->tx,
+               .bits_per_word = 8,
+               .len = 5,
        };
 
        mutex_lock(&st->buf_lock);
@@ -68,7 +64,7 @@ static int ade7854_spi_write_reg_16(struct device *dev,
        st->tx[4] = value & 0xFF;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfer, &msg);
        ret = spi_sync(st->spi, &msg);
        mutex_unlock(&st->buf_lock);
 
@@ -83,12 +79,10 @@ static int ade7854_spi_write_reg_24(struct device *dev,
        struct spi_message msg;
        struct iio_dev *indio_dev = dev_get_drvdata(dev);
        struct ade7854_state *st = iio_dev_get_devdata(indio_dev);
-       struct spi_transfer xfers[] = {
-               {
-                       .tx_buf = st->tx,
-                       .bits_per_word = 8,
-                       .len = 6,
-               }
+       struct spi_transfer xfer = {
+               .tx_buf = st->tx,
+               .bits_per_word = 8,
+               .len = 6,
        };
 
        mutex_lock(&st->buf_lock);
@@ -100,7 +94,7 @@ static int ade7854_spi_write_reg_24(struct device *dev,
        st->tx[5] = value & 0xFF;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfer, &msg);
        ret = spi_sync(st->spi, &msg);
        mutex_unlock(&st->buf_lock);
 
@@ -115,12 +109,10 @@ static int ade7854_spi_write_reg_32(struct device *dev,
        struct spi_message msg;
        struct iio_dev *indio_dev = dev_get_drvdata(dev);
        struct ade7854_state *st = iio_dev_get_devdata(indio_dev);
-       struct spi_transfer xfers[] = {
-               {
-                       .tx_buf = st->tx,
-                       .bits_per_word = 8,
-                       .len = 7,
-               }
+       struct spi_transfer xfer = {
+               .tx_buf = st->tx,
+               .bits_per_word = 8,
+               .len = 7,
        };
 
        mutex_lock(&st->buf_lock);
@@ -133,7 +125,7 @@ static int ade7854_spi_write_reg_32(struct device *dev,
        st->tx[6] = value & 0xFF;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfer, &msg);
        ret = spi_sync(st->spi, &msg);
        mutex_unlock(&st->buf_lock);
 
@@ -152,8 +144,12 @@ static int ade7854_spi_read_reg_8(struct device *dev,
                {
                        .tx_buf = st->tx,
                        .bits_per_word = 8,
-                       .len = 4,
-               },
+                       .len = 3,
+               }, {
+                       .rx_buf = st->rx,
+                       .bits_per_word = 8,
+                       .len = 1,
+               }
        };
 
        mutex_lock(&st->buf_lock);
@@ -161,17 +157,17 @@ static int ade7854_spi_read_reg_8(struct device *dev,
        st->tx[0] = ADE7854_READ_REG;
        st->tx[1] = (reg_address >> 8) & 0xFF;
        st->tx[2] = reg_address & 0xFF;
-       st->tx[3] = 0;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfers[0], &msg);
+       spi_message_add_tail(&xfers[1], &msg);
        ret = spi_sync(st->spi, &msg);
        if (ret) {
                dev_err(&st->spi->dev, "problem when reading 8 bit register 0x%02X",
                                reg_address);
                goto error_ret;
        }
-       *val = st->rx[3];
+       *val = st->rx[0];
 
 error_ret:
        mutex_unlock(&st->buf_lock);
@@ -190,26 +186,29 @@ static int ade7854_spi_read_reg_16(struct device *dev,
                {
                        .tx_buf = st->tx,
                        .bits_per_word = 8,
-                       .len = 5,
-               },
+                       .len = 3,
+               }, {
+                       .rx_buf = st->rx,
+                       .bits_per_word = 8,
+                       .len = 2,
+               }
        };
 
        mutex_lock(&st->buf_lock);
        st->tx[0] = ADE7854_READ_REG;
        st->tx[1] = (reg_address >> 8) & 0xFF;
        st->tx[2] = reg_address & 0xFF;
-       st->tx[3] = 0;
-       st->tx[4] = 0;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfers[0], &msg);
+       spi_message_add_tail(&xfers[1], &msg);
        ret = spi_sync(st->spi, &msg);
        if (ret) {
                dev_err(&st->spi->dev, "problem when reading 16 bit register 0x%02X",
                                reg_address);
                goto error_ret;
        }
-       *val = (st->rx[3] << 8) | st->rx[4];
+       *val = be16_to_cpup((const __be16 *)st->rx);
 
 error_ret:
        mutex_unlock(&st->buf_lock);
@@ -228,8 +227,12 @@ static int ade7854_spi_read_reg_24(struct device *dev,
                {
                        .tx_buf = st->tx,
                        .bits_per_word = 8,
-                       .len = 6,
-               },
+                       .len = 3,
+               }, {
+                       .rx_buf = st->rx,
+                       .bits_per_word = 8,
+                       .len = 3,
+               }
        };
 
        mutex_lock(&st->buf_lock);
@@ -237,19 +240,17 @@ static int ade7854_spi_read_reg_24(struct device *dev,
        st->tx[0] = ADE7854_READ_REG;
        st->tx[1] = (reg_address >> 8) & 0xFF;
        st->tx[2] = reg_address & 0xFF;
-       st->tx[3] = 0;
-       st->tx[4] = 0;
-       st->tx[5] = 0;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfers[0], &msg);
+       spi_message_add_tail(&xfers[1], &msg);
        ret = spi_sync(st->spi, &msg);
        if (ret) {
                dev_err(&st->spi->dev, "problem when reading 24 bit register 0x%02X",
                                reg_address);
                goto error_ret;
        }
-       *val = (st->rx[3] << 16) | (st->rx[4] << 8) | st->rx[5];
+       *val = (st->rx[0] << 16) | (st->rx[1] << 8) | st->rx[2];
 
 error_ret:
        mutex_unlock(&st->buf_lock);
@@ -268,8 +269,12 @@ static int ade7854_spi_read_reg_32(struct device *dev,
                {
                        .tx_buf = st->tx,
                        .bits_per_word = 8,
-                       .len = 7,
-               },
+                       .len = 3,
+               }, {
+                       .rx_buf = st->rx,
+                       .bits_per_word = 8,
+                       .len = 4,
+               }
        };
 
        mutex_lock(&st->buf_lock);
@@ -277,20 +282,17 @@ static int ade7854_spi_read_reg_32(struct device *dev,
        st->tx[0] = ADE7854_READ_REG;
        st->tx[1] = (reg_address >> 8) & 0xFF;
        st->tx[2] = reg_address & 0xFF;
-       st->tx[3] = 0;
-       st->tx[4] = 0;
-       st->tx[5] = 0;
-       st->tx[6] = 0;
 
        spi_message_init(&msg);
-       spi_message_add_tail(xfers, &msg);
+       spi_message_add_tail(&xfers[0], &msg);
+       spi_message_add_tail(&xfers[1], &msg);
        ret = spi_sync(st->spi, &msg);
        if (ret) {
                dev_err(&st->spi->dev, "problem when reading 32 bit register 0x%02X",
                                reg_address);
                goto error_ret;
        }
-       *val = (st->rx[3] << 24) | (st->rx[4] << 16) | (st->rx[5] << 8) | st->rx[6];
+       *val = be32_to_cpup((const __be32 *)st->rx);
 
 error_ret:
        mutex_unlock(&st->buf_lock);
@@ -333,6 +335,13 @@ static int ade7854_spi_remove(struct spi_device *spi)
 
        return 0;
 }
+static const struct spi_device_id ade7854_id[] = {
+       { "ade7854", 0 },
+       { "ade7858", 0 },
+       { "ade7868", 0 },
+       { "ade7878", 0 },
+       { }
+};
 
 static struct spi_driver ade7854_driver = {
        .driver = {
@@ -341,6 +350,7 @@ static struct spi_driver ade7854_driver = {
        },
        .probe = ade7854_spi_probe,
        .remove = __devexit_p(ade7854_spi_remove),
+       .id_table = ade7854_id,
 };
 
 static __init int ade7854_init(void)
@@ -356,5 +366,5 @@ static __exit void ade7854_exit(void)
 module_exit(ade7854_exit);
 
 MODULE_AUTHOR("Barry Song <21cnbao@gmail.com>");
-MODULE_DESCRIPTION("Analog Devices ADE7854/58/68/78 Polyphase Multifunction Energy Metering IC SPI Driver");
+MODULE_DESCRIPTION("Analog Devices ADE7854/58/68/78 SPI Driver");
 MODULE_LICENSE("GPL v2");