jack2 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.

249 lines
7.7KB

  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. */
  15. #ifndef __jack_alsa_driver_h__
  16. #define __jack_alsa_driver_h__
  17. #include <alsa/asoundlib.h>
  18. #include "bitset.h"
  19. #if __BYTE_ORDER == __LITTLE_ENDIAN
  20. #define SND_PCM_FORMAT_S24_3 SND_PCM_FORMAT_S24_3LE
  21. #elif __BYTE_ORDER == __BIG_ENDIAN
  22. #define SND_PCM_FORMAT_S24_3 SND_PCM_FORMAT_S24_3BE
  23. #endif
  24. #include "types.h"
  25. #include "hardware.h"
  26. #include "driver.h"
  27. #include "memops.h"
  28. typedef void (*ReadCopyFunction) (jack_default_audio_sample_t *dst, char *src,
  29. unsigned long src_bytes,
  30. unsigned long src_skip_bytes);
  31. typedef void (*WriteCopyFunction) (char *dst, jack_default_audio_sample_t *src,
  32. unsigned long src_bytes,
  33. unsigned long dst_skip_bytes,
  34. dither_state_t *state);
  35. typedef void (*CopyCopyFunction) (char *dst, char *src,
  36. unsigned long src_bytes,
  37. unsigned long dst_skip_bytes,
  38. unsigned long src_skip_byte);
  39. typedef struct _alsa_driver
  40. {
  41. JACK_DRIVER_NT_DECL
  42. int poll_timeout;
  43. jack_time_t poll_last;
  44. jack_time_t poll_next;
  45. char **playback_addr;
  46. char **capture_addr;
  47. const snd_pcm_channel_area_t *capture_areas;
  48. const snd_pcm_channel_area_t *playback_areas;
  49. struct pollfd *pfd;
  50. unsigned int playback_nfds;
  51. unsigned int capture_nfds;
  52. unsigned long interleave_unit;
  53. unsigned long* capture_interleave_skip;
  54. unsigned long* playback_interleave_skip;
  55. channel_t max_nchannels;
  56. channel_t user_nchannels;
  57. channel_t playback_nchannels;
  58. channel_t capture_nchannels;
  59. unsigned long playback_sample_bytes;
  60. unsigned long capture_sample_bytes;
  61. jack_nframes_t frame_rate;
  62. jack_nframes_t frames_per_cycle;
  63. jack_nframes_t capture_frame_latency;
  64. jack_nframes_t playback_frame_latency;
  65. unsigned long *silent;
  66. char *alsa_name_playback;
  67. char *alsa_name_capture;
  68. char *alsa_driver;
  69. bitset_t channels_not_done;
  70. bitset_t channels_done;
  71. snd_pcm_format_t playback_sample_format;
  72. snd_pcm_format_t capture_sample_format;
  73. float max_sample_val;
  74. unsigned long user_nperiods;
  75. unsigned int playback_nperiods;
  76. unsigned int capture_nperiods;
  77. unsigned long last_mask;
  78. snd_ctl_t *ctl_handle;
  79. snd_pcm_t *playback_handle;
  80. snd_pcm_t *capture_handle;
  81. snd_pcm_hw_params_t *playback_hw_params;
  82. snd_pcm_sw_params_t *playback_sw_params;
  83. snd_pcm_hw_params_t *capture_hw_params;
  84. snd_pcm_sw_params_t *capture_sw_params;
  85. jack_hardware_t *hw;
  86. ClockSyncStatus *clock_sync_data;
  87. jack_client_t *client;
  88. JSList *capture_ports;
  89. JSList *playback_ports;
  90. JSList *monitor_ports;
  91. unsigned long input_monitor_mask;
  92. char soft_mode :
  93. 1;
  94. char hw_monitoring :
  95. 1;
  96. char hw_metering :
  97. 1;
  98. char all_monitor_in :
  99. 1;
  100. char capture_and_playback_not_synced :
  101. 1;
  102. char playback_interleaved :
  103. 1;
  104. char capture_interleaved :
  105. 1;
  106. char with_monitor_ports :
  107. 1;
  108. ReadCopyFunction read_via_copy;
  109. WriteCopyFunction write_via_copy;
  110. CopyCopyFunction channel_copy;
  111. int dither;
  112. dither_state_t *dither_state;
  113. SampleClockMode clock_mode;
  114. JSList *clock_sync_listeners;
  115. pthread_mutex_t clock_sync_lock;
  116. unsigned long next_clock_sync_listener_id;
  117. char has_clock_sync_reporting :
  118. 1;
  119. char has_hw_monitoring :
  120. 1;
  121. char has_hw_metering :
  122. 1;
  123. int running;
  124. int run;
  125. int poll_late;
  126. int xrun_count;
  127. int process_count;
  128. }
  129. alsa_driver_t;
  130. static inline void
  131. alsa_driver_mark_channel_done (alsa_driver_t *driver, channel_t chn)
  132. {
  133. bitset_remove (driver->channels_not_done, chn);
  134. driver->silent[chn] = 0;
  135. }
  136. static inline void
  137. alsa_driver_silence_on_channel (alsa_driver_t *driver, channel_t chn,
  138. jack_nframes_t nframes)
  139. {
  140. if (driver->playback_interleaved) {
  141. memset_interleave
  142. (driver->playback_addr[chn],
  143. 0, nframes * driver->playback_sample_bytes,
  144. driver->interleave_unit,
  145. driver->playback_interleave_skip[chn]);
  146. } else {
  147. memset (driver->playback_addr[chn], 0,
  148. nframes * driver->playback_sample_bytes);
  149. }
  150. alsa_driver_mark_channel_done (driver, chn);
  151. }
  152. static inline void
  153. alsa_driver_silence_on_channel_no_mark (alsa_driver_t *driver, channel_t chn,
  154. jack_nframes_t nframes)
  155. {
  156. if (driver->playback_interleaved) {
  157. memset_interleave
  158. (driver->playback_addr[chn],
  159. 0, nframes * driver->playback_sample_bytes,
  160. driver->interleave_unit,
  161. driver->playback_interleave_skip[chn]);
  162. } else {
  163. memset (driver->playback_addr[chn], 0,
  164. nframes * driver->playback_sample_bytes);
  165. }
  166. }
  167. static inline void
  168. alsa_driver_read_from_channel (alsa_driver_t *driver,
  169. channel_t channel,
  170. jack_default_audio_sample_t *buf,
  171. jack_nframes_t nsamples)
  172. {
  173. driver->read_via_copy (buf,
  174. driver->capture_addr[channel],
  175. nsamples,
  176. driver->capture_interleave_skip[channel]);
  177. }
  178. static inline void
  179. alsa_driver_write_to_channel (alsa_driver_t *driver,
  180. channel_t channel,
  181. jack_default_audio_sample_t *buf,
  182. jack_nframes_t nsamples)
  183. {
  184. driver->write_via_copy (driver->playback_addr[channel],
  185. buf,
  186. nsamples,
  187. driver->playback_interleave_skip[channel],
  188. driver->dither_state + channel);
  189. alsa_driver_mark_channel_done (driver, channel);
  190. }
  191. static inline void
  192. alsa_driver_copy_channel (alsa_driver_t *driver,
  193. channel_t input_channel,
  194. channel_t output_channel,
  195. jack_nframes_t nsamples)
  196. {
  197. driver->channel_copy (driver->playback_addr[output_channel],
  198. driver->capture_addr[input_channel],
  199. nsamples * driver->playback_sample_bytes,
  200. driver->playback_interleave_skip[output_channel],
  201. driver->capture_interleave_skip[input_channel]);
  202. alsa_driver_mark_channel_done (driver, output_channel);
  203. }
  204. void alsa_driver_silence_untouched_channels (alsa_driver_t *driver,
  205. jack_nframes_t nframes);
  206. void alsa_driver_set_clock_sync_status (alsa_driver_t *driver, channel_t chn,
  207. ClockSyncStatus status);
  208. int alsa_driver_listen_for_clock_sync_status (alsa_driver_t *,
  209. ClockSyncListenerFunction,
  210. void *arg);
  211. int alsa_driver_stop_listen_for_clock_sync_status (alsa_driver_t *,
  212. unsigned int);
  213. void alsa_driver_clock_sync_notify (alsa_driver_t *, channel_t chn,
  214. ClockSyncStatus);
  215. #endif /* __jack_alsa_driver_h__ */