emu10k1-gp.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * Copyright (c) 2001 Vojtech Pavlik
  4. */
  5. /*
  6. * EMU10k1 - SB Live / Audigy - gameport driver for Linux
  7. */
  8. #include <asm/io.h>
  9. #include <linux/module.h>
  10. #include <linux/ioport.h>
  11. #include <linux/gameport.h>
  12. #include <linux/slab.h>
  13. #include <linux/pci.h>
  14. MODULE_AUTHOR("Vojtech Pavlik <[email protected]>");
  15. MODULE_DESCRIPTION("EMU10k1 gameport driver");
  16. MODULE_LICENSE("GPL");
  17. struct emu {
  18. struct pci_dev *dev;
  19. struct gameport *gameport;
  20. int io;
  21. int size;
  22. };
  23. static const struct pci_device_id emu_tbl[] = {
  24. { 0x1102, 0x7002, PCI_ANY_ID, PCI_ANY_ID }, /* SB Live gameport */
  25. { 0x1102, 0x7003, PCI_ANY_ID, PCI_ANY_ID }, /* Audigy gameport */
  26. { 0x1102, 0x7004, PCI_ANY_ID, PCI_ANY_ID }, /* Dell SB Live */
  27. { 0x1102, 0x7005, PCI_ANY_ID, PCI_ANY_ID }, /* Audigy LS gameport */
  28. { 0, }
  29. };
  30. MODULE_DEVICE_TABLE(pci, emu_tbl);
  31. static int emu_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
  32. {
  33. struct emu *emu;
  34. struct gameport *port;
  35. int error;
  36. emu = kzalloc(sizeof(struct emu), GFP_KERNEL);
  37. port = gameport_allocate_port();
  38. if (!emu || !port) {
  39. printk(KERN_ERR "emu10k1-gp: Memory allocation failed\n");
  40. error = -ENOMEM;
  41. goto err_out_free;
  42. }
  43. error = pci_enable_device(pdev);
  44. if (error)
  45. goto err_out_free;
  46. emu->io = pci_resource_start(pdev, 0);
  47. emu->size = pci_resource_len(pdev, 0);
  48. emu->dev = pdev;
  49. emu->gameport = port;
  50. gameport_set_name(port, "EMU10K1");
  51. gameport_set_phys(port, "pci%s/gameport0", pci_name(pdev));
  52. port->dev.parent = &pdev->dev;
  53. port->io = emu->io;
  54. if (!request_region(emu->io, emu->size, "emu10k1-gp")) {
  55. printk(KERN_ERR "emu10k1-gp: unable to grab region 0x%x-0x%x\n",
  56. emu->io, emu->io + emu->size - 1);
  57. error = -EBUSY;
  58. goto err_out_disable_dev;
  59. }
  60. pci_set_drvdata(pdev, emu);
  61. gameport_register_port(port);
  62. return 0;
  63. err_out_disable_dev:
  64. pci_disable_device(pdev);
  65. err_out_free:
  66. gameport_free_port(port);
  67. kfree(emu);
  68. return error;
  69. }
  70. static void emu_remove(struct pci_dev *pdev)
  71. {
  72. struct emu *emu = pci_get_drvdata(pdev);
  73. gameport_unregister_port(emu->gameport);
  74. release_region(emu->io, emu->size);
  75. kfree(emu);
  76. pci_disable_device(pdev);
  77. }
  78. static struct pci_driver emu_driver = {
  79. .name = "Emu10k1_gameport",
  80. .id_table = emu_tbl,
  81. .probe = emu_probe,
  82. .remove = emu_remove,
  83. };
  84. module_pci_driver(emu_driver);