tsc2005.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * TSC2005 touchscreen driver
  3. *
  4. * Copyright (C) 2006-2010 Nokia Corporation
  5. * Copyright (C) 2015 QWERTY Embedded Design
  6. * Copyright (C) 2015 EMAC Inc.
  7. *
  8. * Based on original tsc2005.c by Lauri Leukkunen <lauri.leukkunen@nokia.com>
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or
  13. * (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. */
  20. #include <linux/module.h>
  21. #include <linux/input.h>
  22. #include <linux/spi/spi.h>
  23. #include <linux/regmap.h>
  24. #include "tsc200x-core.h"
  25. static const struct input_id tsc2005_input_id = {
  26. .bustype = BUS_SPI,
  27. .product = 2005,
  28. };
  29. static int tsc2005_cmd(struct device *dev, u8 cmd)
  30. {
  31. u8 tx = TSC200X_CMD | TSC200X_CMD_12BIT | cmd;
  32. struct spi_transfer xfer = {
  33. .tx_buf = &tx,
  34. .len = 1,
  35. .bits_per_word = 8,
  36. };
  37. struct spi_message msg;
  38. struct spi_device *spi = to_spi_device(dev);
  39. int error;
  40. spi_message_init(&msg);
  41. spi_message_add_tail(&xfer, &msg);
  42. error = spi_sync(spi, &msg);
  43. if (error) {
  44. dev_err(dev, "%s: failed, command: %x, spi error: %d\n",
  45. __func__, cmd, error);
  46. return error;
  47. }
  48. return 0;
  49. }
  50. static int tsc2005_probe(struct spi_device *spi)
  51. {
  52. int error;
  53. spi->mode = SPI_MODE_0;
  54. spi->bits_per_word = 8;
  55. if (!spi->max_speed_hz)
  56. spi->max_speed_hz = TSC2005_SPI_MAX_SPEED_HZ;
  57. error = spi_setup(spi);
  58. if (error)
  59. return error;
  60. return tsc200x_probe(&spi->dev, spi->irq, &tsc2005_input_id,
  61. devm_regmap_init_spi(spi, &tsc200x_regmap_config),
  62. tsc2005_cmd);
  63. }
  64. static int tsc2005_remove(struct spi_device *spi)
  65. {
  66. return tsc200x_remove(&spi->dev);
  67. }
  68. static struct spi_driver tsc2005_driver = {
  69. .driver = {
  70. .name = "tsc2005",
  71. .pm = &tsc200x_pm_ops,
  72. },
  73. .probe = tsc2005_probe,
  74. .remove = tsc2005_remove,
  75. };
  76. module_spi_driver(tsc2005_driver);
  77. MODULE_AUTHOR("Michael Welling <mwelling@ieee.org>");
  78. MODULE_DESCRIPTION("TSC2005 Touchscreen Driver");
  79. MODULE_LICENSE("GPL");
  80. MODULE_ALIAS("spi:tsc2005");