Commit c1d12c78 authored by Opensource [Steve Twiss]'s avatar Opensource [Steve Twiss] Committed by Lee Jones

mfd: da9063: Add support for production silicon variant code

Add the correct silicon variant code ID (0x5) to the driver. This
new code is the 'production' variant code ID for DA9063.

This patch will remove the older variant code ID which matches the
pre-production silicon ID (0x3) for the DA9063 chip.

There is also some small amount of correction done in this patch:
it splits the revision code and correctly names it according to
the hardware specification and moves the dev_info() call before
the variant ID test.
Signed-off-by: default avatarOpensource [Steve Twiss] <stwiss.opensource@diasemi.com>
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
parent 82ae61c4
...@@ -110,7 +110,7 @@ static const struct mfd_cell da9063_devs[] = { ...@@ -110,7 +110,7 @@ static const struct mfd_cell da9063_devs[] = {
int da9063_device_init(struct da9063 *da9063, unsigned int irq) int da9063_device_init(struct da9063 *da9063, unsigned int irq)
{ {
struct da9063_pdata *pdata = da9063->dev->platform_data; struct da9063_pdata *pdata = da9063->dev->platform_data;
int model, revision; int model, variant_id, variant_code;
int ret; int ret;
if (pdata) { if (pdata) {
...@@ -141,23 +141,26 @@ int da9063_device_init(struct da9063 *da9063, unsigned int irq) ...@@ -141,23 +141,26 @@ int da9063_device_init(struct da9063 *da9063, unsigned int irq)
return -ENODEV; return -ENODEV;
} }
ret = regmap_read(da9063->regmap, DA9063_REG_CHIP_VARIANT, &revision); ret = regmap_read(da9063->regmap, DA9063_REG_CHIP_VARIANT, &variant_id);
if (ret < 0) { if (ret < 0) {
dev_err(da9063->dev, "Cannot read chip revision id.\n"); dev_err(da9063->dev, "Cannot read chip variant id.\n");
return -EIO; return -EIO;
} }
revision >>= DA9063_CHIP_VARIANT_SHIFT;
if (revision != 3) { variant_code = variant_id >> DA9063_CHIP_VARIANT_SHIFT;
dev_err(da9063->dev, "Unknown chip revision: %d\n", revision);
dev_info(da9063->dev,
"Device detected (chip-ID: 0x%02X, var-ID: 0x%02X)\n",
model, variant_id);
if (variant_code != PMIC_DA9063_BB) {
dev_err(da9063->dev, "Unknown chip variant code: 0x%02X\n",
variant_code);
return -ENODEV; return -ENODEV;
} }
da9063->model = model; da9063->model = model;
da9063->revision = revision; da9063->variant_code = variant_code;
dev_info(da9063->dev,
"Device detected (model-ID: 0x%02X rev-ID: 0x%02X)\n",
model, revision);
ret = da9063_irq_init(da9063); ret = da9063_irq_init(da9063);
if (ret) { if (ret) {
......
...@@ -33,6 +33,10 @@ enum da9063_models { ...@@ -33,6 +33,10 @@ enum da9063_models {
PMIC_DA9063 = 0x61, PMIC_DA9063 = 0x61,
}; };
enum da9063_variant_codes {
PMIC_DA9063_BB = 0x5
};
/* Interrupts */ /* Interrupts */
enum da9063_irqs { enum da9063_irqs {
DA9063_IRQ_ONKEY = 0, DA9063_IRQ_ONKEY = 0,
...@@ -72,7 +76,7 @@ struct da9063 { ...@@ -72,7 +76,7 @@ struct da9063 {
/* Device */ /* Device */
struct device *dev; struct device *dev;
unsigned short model; unsigned short model;
unsigned short revision; unsigned char variant_code;
unsigned int flags; unsigned int flags;
/* Control interface */ /* Control interface */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment