seq.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * ALSA sequencer main module
  4. * Copyright (c) 1998-1999 by Frank van de Pol <fvdpol@coil.demon.nl>
  5. */
  6. #include <linux/init.h>
  7. #include <linux/module.h>
  8. #include <linux/device.h>
  9. #include <sound/core.h>
  10. #include <sound/initval.h>
  11. #include <sound/seq_kernel.h>
  12. #include "seq_clientmgr.h"
  13. #include "seq_memory.h"
  14. #include "seq_queue.h"
  15. #include "seq_lock.h"
  16. #include "seq_timer.h"
  17. #include "seq_system.h"
  18. #include "seq_info.h"
  19. #include <sound/minors.h>
  20. #include <sound/seq_device.h>
  21. #if defined(CONFIG_SND_SEQ_DUMMY_MODULE)
  22. int seq_client_load[15] = {[0] = SNDRV_SEQ_CLIENT_DUMMY, [1 ... 14] = -1};
  23. #else
  24. int seq_client_load[15] = {[0 ... 14] = -1};
  25. #endif
  26. int seq_default_timer_class = SNDRV_TIMER_CLASS_GLOBAL;
  27. int seq_default_timer_sclass = SNDRV_TIMER_SCLASS_NONE;
  28. int seq_default_timer_card = -1;
  29. int seq_default_timer_device =
  30. #ifdef CONFIG_SND_SEQ_HRTIMER_DEFAULT
  31. SNDRV_TIMER_GLOBAL_HRTIMER
  32. #else
  33. SNDRV_TIMER_GLOBAL_SYSTEM
  34. #endif
  35. ;
  36. int seq_default_timer_subdevice = 0;
  37. int seq_default_timer_resolution = 0; /* Hz */
  38. MODULE_AUTHOR("Frank van de Pol <fvdpol@coil.demon.nl>, Jaroslav Kysela <perex@perex.cz>");
  39. MODULE_DESCRIPTION("Advanced Linux Sound Architecture sequencer.");
  40. MODULE_LICENSE("GPL");
  41. module_param_array(seq_client_load, int, NULL, 0444);
  42. MODULE_PARM_DESC(seq_client_load, "The numbers of global (system) clients to load through kmod.");
  43. module_param(seq_default_timer_class, int, 0644);
  44. MODULE_PARM_DESC(seq_default_timer_class, "The default timer class.");
  45. module_param(seq_default_timer_sclass, int, 0644);
  46. MODULE_PARM_DESC(seq_default_timer_sclass, "The default timer slave class.");
  47. module_param(seq_default_timer_card, int, 0644);
  48. MODULE_PARM_DESC(seq_default_timer_card, "The default timer card number.");
  49. module_param(seq_default_timer_device, int, 0644);
  50. MODULE_PARM_DESC(seq_default_timer_device, "The default timer device number.");
  51. module_param(seq_default_timer_subdevice, int, 0644);
  52. MODULE_PARM_DESC(seq_default_timer_subdevice, "The default timer subdevice number.");
  53. module_param(seq_default_timer_resolution, int, 0644);
  54. MODULE_PARM_DESC(seq_default_timer_resolution, "The default timer resolution in Hz.");
  55. MODULE_ALIAS_CHARDEV(CONFIG_SND_MAJOR, SNDRV_MINOR_SEQUENCER);
  56. MODULE_ALIAS("devname:snd/seq");
  57. /*
  58. * INIT PART
  59. */
  60. static int __init alsa_seq_init(void)
  61. {
  62. int err;
  63. err = client_init_data();
  64. if (err < 0)
  65. goto error;
  66. /* register sequencer device */
  67. err = snd_sequencer_device_init();
  68. if (err < 0)
  69. goto error;
  70. /* register proc interface */
  71. err = snd_seq_info_init();
  72. if (err < 0)
  73. goto error_device;
  74. /* register our internal client */
  75. err = snd_seq_system_client_init();
  76. if (err < 0)
  77. goto error_info;
  78. snd_seq_autoload_init();
  79. return 0;
  80. error_info:
  81. snd_seq_info_done();
  82. error_device:
  83. snd_sequencer_device_done();
  84. error:
  85. return err;
  86. }
  87. static void __exit alsa_seq_exit(void)
  88. {
  89. /* unregister our internal client */
  90. snd_seq_system_client_done();
  91. /* unregister proc interface */
  92. snd_seq_info_done();
  93. /* delete timing queues */
  94. snd_seq_queues_delete();
  95. /* unregister sequencer device */
  96. snd_sequencer_device_done();
  97. snd_seq_autoload_exit();
  98. }
  99. module_init(alsa_seq_init)
  100. module_exit(alsa_seq_exit)