serial: max310x: Add MAX3109 support
authorAlexander Shiyan <shc_work@mail.ru>
Sat, 29 Jun 2013 06:44:18 +0000 (10:44 +0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 26 Jul 2013 22:53:27 +0000 (15:53 -0700)
This patch adds support for MAX3109 (advanced dual universal asynchronous
receiver-transmitter) into max310x driver.

Signed-off-by: Alexander Shiyan <shc_work@mail.ru>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/Kconfig
drivers/tty/serial/max310x.c
include/linux/platform_data/max310x.h

index 25772c15276d2e8fd44ed6cec21c90131ae91b34..8e1a9c53ad7f289073ba256f6acdcc5030765c23 100644 (file)
@@ -297,7 +297,7 @@ config SERIAL_MAX310X
        default n
        help
          This selects support for an advanced UART from Maxim (Dallas).
-         Supported ICs are MAX3107, MAX3108.
+         Supported ICs are MAX3107, MAX3108, MAX3109.
          Each IC contains 128 words each of receive and transmit FIFO
          that can be controlled through I2C or high-speed SPI.
 
index 4620289e9e492010f99ae5dee1fd7a81f931bba0..a6c46427363be44235275aa518b7b4b202073cdd 100644 (file)
@@ -1,5 +1,5 @@
 /*
- *  Maxim (Dallas) MAX3107/8 serial driver
+ *  Maxim (Dallas) MAX3107/8/9 serial driver
  *
  *  Copyright (C) 2012-2013 Alexander Shiyan <shc_work@mail.ru>
  *
@@ -13,9 +13,6 @@
  *  (at your option) any later version.
  */
 
-/* TODO: MAX3109 support (Dual) */
-/* TODO: MAX14830 support (Quad) */
-
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/device.h>
 /* MAX3107 specific */
 #define MAX3107_REV_ID                 (0xa0)
 
+/* MAX3109 specific */
+#define MAX3109_REV_ID                 (0xc0)
+
 struct max310x_devtype {
        char    name[9];
        int     nr;
@@ -359,6 +359,25 @@ static int max3108_detect(struct device *dev)
        return 0;
 }
 
+static int max3109_detect(struct device *dev)
+{
+       struct max310x_port *s = dev_get_drvdata(dev);
+       unsigned int val = 0;
+       int ret;
+
+       ret = regmap_read(s->regmap, MAX310X_REVID_REG, &val);
+       if (ret)
+               return ret;
+
+       if (((val & MAX310x_REV_MASK) != MAX3109_REV_ID)) {
+               dev_err(dev,
+                       "%s ID 0x%02x does not match\n", s->devtype->name, val);
+               return -ENODEV;
+       }
+
+       return 0;
+}
+
 static void max310x_power(struct uart_port *port, int on)
 {
        max310x_port_update(port, MAX310X_MODE1_REG,
@@ -382,6 +401,13 @@ static const struct max310x_devtype max3108_devtype = {
        .power  = max310x_power,
 };
 
+static const struct max310x_devtype max3109_devtype = {
+       .name   = "MAX3109",
+       .nr     = 2,
+       .detect = max3109_detect,
+       .power  = max310x_power,
+};
+
 static bool max310x_reg_writeable(struct device *dev, unsigned int reg)
 {
        switch (reg & 0x1f) {
@@ -1226,6 +1252,7 @@ static SIMPLE_DEV_PM_OPS(max310x_pm_ops, max310x_suspend, max310x_resume);
 static const struct spi_device_id max310x_id_table[] = {
        { "max3107",    (kernel_ulong_t)&max3107_devtype, },
        { "max3108",    (kernel_ulong_t)&max3108_devtype, },
+       { "max3109",    (kernel_ulong_t)&max3109_devtype, },
        { }
 };
 MODULE_DEVICE_TABLE(spi, max310x_id_table);
index 1aec0b620ac35309147cb238f383ee292c31f4cb..4c128eda26baacea3ec3e888b4595d2b5846337d 100644 (file)
@@ -1,5 +1,5 @@
 /*
- *  Maxim (Dallas) MAX3107/8 serial driver
+ *  Maxim (Dallas) MAX3107/8/9 serial driver
  *
  *  Copyright (C) 2012 Alexander Shiyan <shc_work@mail.ru>
  *
@@ -37,7 +37,7 @@
  * };
  */
 
-#define MAX310X_MAX_UARTS      1
+#define MAX310X_MAX_UARTS      2
 
 /* MAX310X platform data structure */
 struct max310x_pdata {