pcap_keys.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Input driver for PCAP events:
  4. * * Power key
  5. * * Headphone button
  6. *
  7. * Copyright (c) 2008,2009 Ilya Petrov <[email protected]>
  8. */
  9. #include <linux/module.h>
  10. #include <linux/interrupt.h>
  11. #include <linux/platform_device.h>
  12. #include <linux/input.h>
  13. #include <linux/mfd/ezx-pcap.h>
  14. #include <linux/slab.h>
  15. struct pcap_keys {
  16. struct pcap_chip *pcap;
  17. struct input_dev *input;
  18. };
  19. /* PCAP2 interrupts us on keypress */
  20. static irqreturn_t pcap_keys_handler(int irq, void *_pcap_keys)
  21. {
  22. struct pcap_keys *pcap_keys = _pcap_keys;
  23. int pirq = irq_to_pcap(pcap_keys->pcap, irq);
  24. u32 pstat;
  25. ezx_pcap_read(pcap_keys->pcap, PCAP_REG_PSTAT, &pstat);
  26. pstat &= 1 << pirq;
  27. switch (pirq) {
  28. case PCAP_IRQ_ONOFF:
  29. input_report_key(pcap_keys->input, KEY_POWER, !pstat);
  30. break;
  31. case PCAP_IRQ_MIC:
  32. input_report_key(pcap_keys->input, KEY_HP, !pstat);
  33. break;
  34. }
  35. input_sync(pcap_keys->input);
  36. return IRQ_HANDLED;
  37. }
  38. static int pcap_keys_probe(struct platform_device *pdev)
  39. {
  40. int err = -ENOMEM;
  41. struct pcap_keys *pcap_keys;
  42. struct input_dev *input_dev;
  43. pcap_keys = kmalloc(sizeof(struct pcap_keys), GFP_KERNEL);
  44. if (!pcap_keys)
  45. return err;
  46. pcap_keys->pcap = dev_get_drvdata(pdev->dev.parent);
  47. input_dev = input_allocate_device();
  48. if (!input_dev)
  49. goto fail;
  50. pcap_keys->input = input_dev;
  51. platform_set_drvdata(pdev, pcap_keys);
  52. input_dev->name = pdev->name;
  53. input_dev->phys = "pcap-keys/input0";
  54. input_dev->id.bustype = BUS_HOST;
  55. input_dev->dev.parent = &pdev->dev;
  56. __set_bit(EV_KEY, input_dev->evbit);
  57. __set_bit(KEY_POWER, input_dev->keybit);
  58. __set_bit(KEY_HP, input_dev->keybit);
  59. err = input_register_device(input_dev);
  60. if (err)
  61. goto fail_allocate;
  62. err = request_irq(pcap_to_irq(pcap_keys->pcap, PCAP_IRQ_ONOFF),
  63. pcap_keys_handler, 0, "Power key", pcap_keys);
  64. if (err)
  65. goto fail_register;
  66. err = request_irq(pcap_to_irq(pcap_keys->pcap, PCAP_IRQ_MIC),
  67. pcap_keys_handler, 0, "Headphone button", pcap_keys);
  68. if (err)
  69. goto fail_pwrkey;
  70. return 0;
  71. fail_pwrkey:
  72. free_irq(pcap_to_irq(pcap_keys->pcap, PCAP_IRQ_ONOFF), pcap_keys);
  73. fail_register:
  74. input_unregister_device(input_dev);
  75. goto fail;
  76. fail_allocate:
  77. input_free_device(input_dev);
  78. fail:
  79. kfree(pcap_keys);
  80. return err;
  81. }
  82. static int pcap_keys_remove(struct platform_device *pdev)
  83. {
  84. struct pcap_keys *pcap_keys = platform_get_drvdata(pdev);
  85. free_irq(pcap_to_irq(pcap_keys->pcap, PCAP_IRQ_ONOFF), pcap_keys);
  86. free_irq(pcap_to_irq(pcap_keys->pcap, PCAP_IRQ_MIC), pcap_keys);
  87. input_unregister_device(pcap_keys->input);
  88. kfree(pcap_keys);
  89. return 0;
  90. }
  91. static struct platform_driver pcap_keys_device_driver = {
  92. .probe = pcap_keys_probe,
  93. .remove = pcap_keys_remove,
  94. .driver = {
  95. .name = "pcap-keys",
  96. }
  97. };
  98. module_platform_driver(pcap_keys_device_driver);
  99. MODULE_DESCRIPTION("Motorola PCAP2 input events driver");
  100. MODULE_AUTHOR("Ilya Petrov <[email protected]>");
  101. MODULE_LICENSE("GPL");
  102. MODULE_ALIAS("platform:pcap_keys");