2019-05-27 08:55:06 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
2011-03-16 22:07:36 -07:00
/*
* TSC2005 touchscreen driver
*
* Copyright ( C ) 2006 - 2010 Nokia Corporation
2015-11-02 17:45:51 -08:00
* Copyright ( C ) 2015 QWERTY Embedded Design
* Copyright ( C ) 2015 EMAC Inc .
2011-03-16 22:07:36 -07:00
*
2015-11-02 17:45:51 -08:00
* Based on original tsc2005 . c by Lauri Leukkunen < lauri . leukkunen @ nokia . com >
2011-03-16 22:07:36 -07:00
*/
# include <linux/input.h>
2017-02-10 15:12:20 -08:00
# include <linux/module.h>
# include <linux/of.h>
2011-03-16 22:07:36 -07:00
# include <linux/spi/spi.h>
2015-07-27 17:27:25 -07:00
# include <linux/regmap.h>
2015-11-02 17:45:51 -08:00
# include "tsc200x-core.h"
2011-03-16 22:07:36 -07:00
2016-07-20 10:02:07 -07:00
static const struct input_id tsc2005_input_id = {
. bustype = BUS_SPI ,
. product = 2005 ,
} ;
2015-11-02 17:45:51 -08:00
static int tsc2005_cmd ( struct device * dev , u8 cmd )
2011-03-16 22:07:36 -07:00
{
2015-11-02 17:51:49 -08:00
u8 tx = TSC200X_CMD | TSC200X_CMD_12BIT | cmd ;
2011-03-16 22:10:52 -07:00
struct spi_transfer xfer = {
2015-11-02 17:45:51 -08:00
. tx_buf = & tx ,
. len = 1 ,
. bits_per_word = 8 ,
2011-03-16 22:10:52 -07:00
} ;
2011-03-16 22:07:36 -07:00
struct spi_message msg ;
2015-11-02 17:45:51 -08:00
struct spi_device * spi = to_spi_device ( dev ) ;
2011-03-16 22:11:25 -07:00
int error ;
2011-03-16 22:07:36 -07:00
spi_message_init ( & msg ) ;
spi_message_add_tail ( & xfer , & msg ) ;
2011-03-16 22:11:25 -07:00
2015-11-02 17:45:51 -08:00
error = spi_sync ( spi , & msg ) ;
2011-03-16 22:11:25 -07:00
if ( error ) {
2015-11-02 17:45:51 -08:00
dev_err ( dev , " %s: failed, command: %x, spi error: %d \n " ,
2011-03-16 22:11:25 -07:00
__func__ , cmd , error ) ;
return error ;
}
return 0 ;
2011-03-16 22:07:36 -07:00
}
2012-11-23 21:38:25 -08:00
static int tsc2005_probe ( struct spi_device * spi )
2011-03-16 22:07:36 -07:00
{
2011-03-16 22:09:38 -07:00
int error ;
2011-03-16 22:07:36 -07:00
2011-03-16 22:09:38 -07:00
spi - > mode = SPI_MODE_0 ;
spi - > bits_per_word = 8 ;
if ( ! spi - > max_speed_hz )
spi - > max_speed_hz = TSC2005_SPI_MAX_SPEED_HZ ;
2011-03-16 22:07:36 -07:00
2011-03-16 22:09:38 -07:00
error = spi_setup ( spi ) ;
if ( error )
return error ;
2011-03-16 22:07:36 -07:00
2016-07-20 10:02:07 -07:00
return tsc200x_probe ( & spi - > dev , spi - > irq , & tsc2005_input_id ,
2015-11-02 17:45:51 -08:00
devm_regmap_init_spi ( spi , & tsc200x_regmap_config ) ,
tsc2005_cmd ) ;
2011-03-16 22:07:36 -07:00
}
2022-01-23 18:52:01 +01:00
static void tsc2005_remove ( struct spi_device * spi )
2011-03-16 22:07:36 -07:00
{
2021-10-12 19:38:36 -07:00
tsc200x_remove ( & spi - > dev ) ;
2011-03-16 22:07:36 -07:00
}
2017-02-10 15:12:20 -08:00
# ifdef CONFIG_OF
static const struct of_device_id tsc2005_of_match [ ] = {
{ . compatible = " ti,tsc2005 " } ,
{ /* sentinel */ }
} ;
MODULE_DEVICE_TABLE ( of , tsc2005_of_match ) ;
# endif
2011-03-16 22:07:36 -07:00
static struct spi_driver tsc2005_driver = {
2011-03-16 22:08:26 -07:00
. driver = {
. name = " tsc2005 " ,
2017-02-10 15:12:20 -08:00
. of_match_table = of_match_ptr ( tsc2005_of_match ) ,
2023-01-14 17:16:13 +00:00
. pm = pm_sleep_ptr ( & tsc200x_pm_ops ) ,
2011-03-16 22:07:36 -07:00
} ,
2011-03-16 22:08:26 -07:00
. probe = tsc2005_probe ,
2012-11-23 21:27:39 -08:00
. remove = tsc2005_remove ,
2011-03-16 22:07:36 -07:00
} ;
2012-03-16 23:05:26 -07:00
module_spi_driver ( tsc2005_driver ) ;
2011-03-16 22:07:36 -07:00
2015-11-02 17:45:51 -08:00
MODULE_AUTHOR ( " Michael Welling <mwelling@ieee.org> " ) ;
2011-03-16 22:09:03 -07:00
MODULE_DESCRIPTION ( " TSC2005 Touchscreen Driver " ) ;
2011-03-16 22:07:36 -07:00
MODULE_LICENSE ( " GPL " ) ;
2013-02-16 22:01:44 -08:00
MODULE_ALIAS ( " spi:tsc2005 " ) ;