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.

216 lines
7.5KB

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