jack1 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

194 lines
6.8KB

  1. /*
  2. Copyright (C) 2001 Paul Davis
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation; either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program; if not, write to the Free Software
  13. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  14. $Id$
  15. */
  16. #ifndef __jack_alsa_driver_h__
  17. #define __jack_alsa_driver_h__
  18. #include <alsa/asoundlib.h>
  19. #include <jack/types.h>
  20. #include <jack/hardware.h>
  21. #include <jack/driver.h>
  22. #include <jack/memops.h>
  23. #include <jack/jack.h>
  24. typedef void (*ReadCopyFunction) (sample_t *dst, char *src,
  25. unsigned long src_bytes,
  26. unsigned long src_skip_bytes);
  27. typedef void (*WriteCopyFunction) (char *dst, sample_t *src,
  28. unsigned long src_bytes,
  29. unsigned long dst_skip_bytes,
  30. gain_t gain);
  31. typedef void (*CopyCopyFunction) (char *dst, char *src,
  32. unsigned long src_bytes,
  33. unsigned long dst_skip_bytes,
  34. unsigned long src_skip_byte);
  35. typedef struct {
  36. JACK_DRIVER_DECL
  37. char **playback_addr;
  38. char **capture_addr;
  39. const snd_pcm_channel_area_t *capture_areas;
  40. const snd_pcm_channel_area_t *playback_areas;
  41. struct pollfd *pfd;
  42. unsigned int playback_nfds;
  43. unsigned int capture_nfds;
  44. unsigned long interleave_unit;
  45. unsigned long capture_interleave_skip;
  46. unsigned long playback_interleave_skip;
  47. unsigned long max_nchannels;
  48. unsigned long user_nchannels;
  49. unsigned long playback_nchannels;
  50. unsigned long capture_nchannels;
  51. unsigned long sample_bytes;
  52. nframes_t frame_rate;
  53. nframes_t frames_per_cycle;
  54. nframes_t capture_frame_latency;
  55. nframes_t playback_frame_latency;
  56. unsigned long *silent;
  57. char *alsa_name;
  58. char *alsa_driver;
  59. snd_pcm_uframes_t buffer_frames;
  60. unsigned long bytes_per_cycle; /* per channel */
  61. unsigned long channels_not_done;
  62. unsigned long channel_done_bits;
  63. snd_pcm_format_t sample_format;
  64. float max_sample_val;
  65. unsigned long user_nperiods;
  66. unsigned long nfragments;
  67. int max_level;
  68. int min_level;
  69. unsigned long last_mask;
  70. unsigned long silence_pending;
  71. snd_ctl_t *ctl_handle;
  72. snd_pcm_t *playback_handle;
  73. snd_pcm_t *capture_handle;
  74. snd_pcm_hw_params_t *playback_hw_params;
  75. snd_pcm_sw_params_t *playback_sw_params;
  76. snd_pcm_hw_params_t *capture_hw_params;
  77. snd_pcm_sw_params_t *capture_sw_params;
  78. jack_hardware_t *hw;
  79. ClockSyncStatus *clock_sync_data;
  80. struct _jack_engine *engine;
  81. jack_client_t *client;
  82. GSList *capture_ports;
  83. GSList *playback_ports;
  84. unsigned long input_monitor_mask;
  85. char hw_monitoring : 1;
  86. char all_monitor_in : 1;
  87. char capture_and_playback_not_synced : 1;
  88. char interleaved : 1;
  89. ReadCopyFunction read_via_copy;
  90. WriteCopyFunction write_via_copy;
  91. CopyCopyFunction channel_copy;
  92. SampleClockMode clock_mode;
  93. GSList *clock_sync_listeners;
  94. pthread_mutex_t clock_sync_lock;
  95. unsigned long next_clock_sync_listener_id;
  96. char has_clock_sync_reporting : 1;
  97. char has_hw_monitoring : 1;
  98. } alsa_driver_t;
  99. static __inline__ void alsa_driver_mark_channel_done (alsa_driver_t *driver, channel_t chn) {
  100. driver->channels_not_done &= ~(1<<chn);
  101. driver->silent[chn] = 0;
  102. }
  103. static __inline__ void alsa_driver_silence_on_channel (alsa_driver_t *driver, channel_t chn, nframes_t nframes) {
  104. if (driver->interleaved) {
  105. memset_interleave
  106. (driver->playback_addr[chn],
  107. 0, nframes * driver->sample_bytes,
  108. driver->interleave_unit,
  109. driver->playback_interleave_skip);
  110. } else {
  111. memset (driver->playback_addr[chn], 0, nframes * driver->sample_bytes);
  112. }
  113. alsa_driver_mark_channel_done (driver,chn);
  114. }
  115. static __inline__ void alsa_driver_silence_on_channel_no_mark (alsa_driver_t *driver, channel_t chn, nframes_t nframes) {
  116. if (driver->interleaved) {
  117. memset_interleave
  118. (driver->playback_addr[chn],
  119. 0, nframes * driver->sample_bytes,
  120. driver->interleave_unit,
  121. driver->playback_interleave_skip);
  122. } else {
  123. memset (driver->playback_addr[chn], 0, nframes * driver->sample_bytes);
  124. }
  125. }
  126. static __inline__ void alsa_driver_read_from_channel (alsa_driver_t *driver,
  127. channel_t channel, sample_t *buf,
  128. nframes_t nsamples,
  129. unsigned long offset)
  130. {
  131. driver->read_via_copy (buf,
  132. driver->capture_addr[channel] + offset,
  133. nsamples,
  134. driver->capture_interleave_skip);
  135. }
  136. static __inline__ void alsa_driver_write_to_channel (alsa_driver_t *driver,
  137. channel_t channel,
  138. sample_t *buf,
  139. nframes_t nsamples,
  140. unsigned long offset,
  141. gain_t gain)
  142. {
  143. driver->write_via_copy (driver->playback_addr[channel] + offset,
  144. buf,
  145. nsamples,
  146. driver->playback_interleave_skip,
  147. gain);
  148. alsa_driver_mark_channel_done (driver, channel);
  149. }
  150. static __inline__ void alsa_driver_copy_channel (alsa_driver_t *driver,
  151. channel_t input_channel,
  152. channel_t output_channel,
  153. nframes_t nsamples) {
  154. driver->channel_copy (driver->playback_addr[output_channel],
  155. driver->capture_addr[input_channel],
  156. nsamples * driver->sample_bytes,
  157. driver->playback_interleave_skip,
  158. driver->capture_interleave_skip);
  159. alsa_driver_mark_channel_done (driver, output_channel);
  160. }
  161. void alsa_driver_set_clock_sync_status (alsa_driver_t *driver, channel_t chn, ClockSyncStatus status);
  162. int alsa_driver_listen_for_clock_sync_status (alsa_driver_t *, ClockSyncListenerFunction, void *arg);
  163. int alsa_driver_stop_listen_for_clock_sync_status (alsa_driver_t *, int);
  164. void alsa_driver_clock_sync_notify (alsa_driver_t *, channel_t chn, ClockSyncStatus);
  165. #endif /* __jack_alsa_driver_h__ */