Thomas Gleixner | 80503b2 | 2019-05-24 12:04:09 +0200 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0-or-later |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 2 | /* |
| 3 | * AD7879-1/AD7889-1 touchscreen (I2C bus) |
| 4 | * |
| 5 | * Copyright (C) 2008-2010 Michael Hennerich, Analog Devices Inc. |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 6 | */ |
| 7 | |
| 8 | #include <linux/input.h> /* BUS_I2C */ |
| 9 | #include <linux/i2c.h> |
| 10 | #include <linux/module.h> |
| 11 | #include <linux/types.h> |
Stefan Agner | fa6e3ca | 2016-03-08 10:35:24 -0800 | [diff] [blame] | 12 | #include <linux/of.h> |
Mark Brown | d5dc9ac | 2011-01-06 23:01:02 -0800 | [diff] [blame] | 13 | #include <linux/pm.h> |
Dmitry Torokhov | 404a24c | 2017-02-16 23:22:38 -0800 | [diff] [blame] | 14 | #include <linux/regmap.h> |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 15 | |
| 16 | #include "ad7879.h" |
| 17 | |
| 18 | #define AD7879_DEVID 0x79 /* AD7879-1/AD7889-1 */ |
| 19 | |
Dmitry Torokhov | 404a24c | 2017-02-16 23:22:38 -0800 | [diff] [blame] | 20 | static const struct regmap_config ad7879_i2c_regmap_config = { |
| 21 | .reg_bits = 8, |
| 22 | .val_bits = 16, |
| 23 | .max_register = 15, |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 24 | }; |
| 25 | |
Bill Pemberton | 5298cc4 | 2012-11-23 21:38:25 -0800 | [diff] [blame] | 26 | static int ad7879_i2c_probe(struct i2c_client *client, |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 27 | const struct i2c_device_id *id) |
| 28 | { |
Dmitry Torokhov | 404a24c | 2017-02-16 23:22:38 -0800 | [diff] [blame] | 29 | struct regmap *regmap; |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 30 | |
| 31 | if (!i2c_check_functionality(client->adapter, |
| 32 | I2C_FUNC_SMBUS_WORD_DATA)) { |
| 33 | dev_err(&client->dev, "SMBUS Word Data not Supported\n"); |
| 34 | return -EIO; |
| 35 | } |
| 36 | |
Dmitry Torokhov | 404a24c | 2017-02-16 23:22:38 -0800 | [diff] [blame] | 37 | regmap = devm_regmap_init_i2c(client, &ad7879_i2c_regmap_config); |
| 38 | if (IS_ERR(regmap)) |
| 39 | return PTR_ERR(regmap); |
| 40 | |
Dmitry Torokhov | 4e34025 | 2017-02-28 11:43:52 -0800 | [diff] [blame] | 41 | return ad7879_probe(&client->dev, regmap, client->irq, |
| 42 | BUS_I2C, AD7879_DEVID); |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 43 | } |
| 44 | |
| 45 | static const struct i2c_device_id ad7879_id[] = { |
| 46 | { "ad7879", 0 }, |
| 47 | { "ad7889", 0 }, |
| 48 | { } |
| 49 | }; |
| 50 | MODULE_DEVICE_TABLE(i2c, ad7879_id); |
| 51 | |
Stefan Agner | fa6e3ca | 2016-03-08 10:35:24 -0800 | [diff] [blame] | 52 | #ifdef CONFIG_OF |
| 53 | static const struct of_device_id ad7879_i2c_dt_ids[] = { |
| 54 | { .compatible = "adi,ad7879-1", }, |
| 55 | { } |
| 56 | }; |
| 57 | MODULE_DEVICE_TABLE(of, ad7879_i2c_dt_ids); |
| 58 | #endif |
| 59 | |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 60 | static struct i2c_driver ad7879_i2c_driver = { |
| 61 | .driver = { |
| 62 | .name = "ad7879", |
Dmitry Torokhov | 8672bd9 | 2011-11-14 00:32:09 -0800 | [diff] [blame] | 63 | .pm = &ad7879_pm_ops, |
Stefan Agner | fa6e3ca | 2016-03-08 10:35:24 -0800 | [diff] [blame] | 64 | .of_match_table = of_match_ptr(ad7879_i2c_dt_ids), |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 65 | }, |
| 66 | .probe = ad7879_i2c_probe, |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 67 | .id_table = ad7879_id, |
| 68 | }; |
| 69 | |
Axel Lin | 1b92c1c | 2012-03-16 23:05:41 -0700 | [diff] [blame] | 70 | module_i2c_driver(ad7879_i2c_driver); |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 71 | |
Michael Hennerich | 2581e5d | 2017-02-22 10:34:20 -0800 | [diff] [blame] | 72 | MODULE_AUTHOR("Michael Hennerich <michael.hennerich@analog.com>"); |
Mike Frysinger | 4397c98 | 2010-06-30 01:40:52 -0700 | [diff] [blame] | 73 | MODULE_DESCRIPTION("AD7879(-1) touchscreen I2C bus driver"); |
| 74 | MODULE_LICENSE("GPL"); |