2010-06-30 01:40:52 -07:00
/*
* AD7879 - 1 / AD7889 - 1 touchscreen ( I2C bus )
*
* Copyright ( C ) 2008 - 2010 Michael Hennerich , Analog Devices Inc .
*
* Licensed under the GPL - 2 or later .
*/
# include <linux/input.h> /* BUS_I2C */
# include <linux/i2c.h>
# include <linux/module.h>
# include <linux/types.h>
2011-01-06 23:01:02 -08:00
# include <linux/pm.h>
2010-06-30 01:40:52 -07:00
# include "ad7879.h"
# define AD7879_DEVID 0x79 /* AD7879-1/AD7889-1 */
/* All registers are word-sized.
* AD7879 uses a high - byte first convention .
*/
static int ad7879_i2c_read ( struct device * dev , u8 reg )
{
struct i2c_client * client = to_i2c_client ( dev ) ;
2011-11-29 11:23:27 -08:00
return i2c_smbus_read_word_swapped ( client , reg ) ;
2010-06-30 01:40:52 -07:00
}
static int ad7879_i2c_multi_read ( struct device * dev ,
u8 first_reg , u8 count , u16 * buf )
{
2010-06-30 14:51:09 -07:00
struct i2c_client * client = to_i2c_client ( dev ) ;
2010-06-30 01:40:52 -07:00
u8 idx ;
2010-06-30 14:51:09 -07:00
i2c_smbus_read_i2c_block_data ( client , first_reg , count * 2 , ( u8 * ) buf ) ;
2010-06-30 01:40:52 -07:00
for ( idx = 0 ; idx < count ; + + idx )
2010-06-30 14:51:09 -07:00
buf [ idx ] = swab16 ( buf [ idx ] ) ;
2010-06-30 01:40:52 -07:00
return 0 ;
}
static int ad7879_i2c_write ( struct device * dev , u8 reg , u16 val )
{
struct i2c_client * client = to_i2c_client ( dev ) ;
2011-11-29 11:23:27 -08:00
return i2c_smbus_write_word_swapped ( client , reg , val ) ;
2010-06-30 01:40:52 -07:00
}
static const struct ad7879_bus_ops ad7879_i2c_bus_ops = {
. bustype = BUS_I2C ,
. read = ad7879_i2c_read ,
. multi_read = ad7879_i2c_multi_read ,
. write = ad7879_i2c_write ,
} ;
2012-11-23 21:38:25 -08:00
static int ad7879_i2c_probe ( struct i2c_client * client ,
2010-06-30 01:40:52 -07:00
const struct i2c_device_id * id )
{
struct ad7879 * ts ;
if ( ! i2c_check_functionality ( client - > adapter ,
I2C_FUNC_SMBUS_WORD_DATA ) ) {
dev_err ( & client - > dev , " SMBUS Word Data not Supported \n " ) ;
return - EIO ;
}
ts = ad7879_probe ( & client - > dev , AD7879_DEVID , client - > irq ,
& ad7879_i2c_bus_ops ) ;
if ( IS_ERR ( ts ) )
return PTR_ERR ( ts ) ;
i2c_set_clientdata ( client , ts ) ;
return 0 ;
}
2012-11-23 21:50:47 -08:00
static int ad7879_i2c_remove ( struct i2c_client * client )
2010-06-30 01:40:52 -07:00
{
struct ad7879 * ts = i2c_get_clientdata ( client ) ;
ad7879_remove ( ts ) ;
return 0 ;
}
static const struct i2c_device_id ad7879_id [ ] = {
{ " ad7879 " , 0 } ,
{ " ad7889 " , 0 } ,
{ }
} ;
MODULE_DEVICE_TABLE ( i2c , ad7879_id ) ;
static struct i2c_driver ad7879_i2c_driver = {
. driver = {
. name = " ad7879 " ,
2011-11-14 00:32:09 -08:00
. pm = & ad7879_pm_ops ,
2010-06-30 01:40:52 -07:00
} ,
. probe = ad7879_i2c_probe ,
2012-11-23 21:27:39 -08:00
. remove = ad7879_i2c_remove ,
2010-06-30 01:40:52 -07:00
. id_table = ad7879_id ,
} ;
2012-03-16 23:05:41 -07:00
module_i2c_driver ( ad7879_i2c_driver ) ;
2010-06-30 01:40:52 -07:00
MODULE_AUTHOR ( " Michael Hennerich <hennerich@blackfin.uclinux.org> " ) ;
MODULE_DESCRIPTION ( " AD7879(-1) touchscreen I2C bus driver " ) ;
MODULE_LICENSE ( " GPL " ) ;