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.

291 lines
8.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: alsa_driver.h 945 2006-05-04 15:14:45Z pbd $
  15. */
  16. #ifndef __jack_alsa_driver_h__
  17. #define __jack_alsa_driver_h__
  18. #include <alsa/asoundlib.h>
  19. #include "bitset.h"
  20. #if __BYTE_ORDER == __LITTLE_ENDIAN
  21. #define IS_LE 0
  22. #define IS_BE 1
  23. #elif __BYTE_ORDER == __BIG_ENDIAN
  24. #define IS_LE 1
  25. #define IS_BE 0
  26. #endif
  27. #define TRUE 1
  28. #define FALSE 0
  29. #include "types.h"
  30. #include "hardware.h"
  31. #include "driver.h"
  32. #include "memops.h"
  33. #include "alsa_midi.h"
  34. #ifdef __cplusplus
  35. extern "C"
  36. {
  37. #endif
  38. typedef void (*ReadCopyFunction) (jack_default_audio_sample_t *dst, char *src,
  39. unsigned long src_bytes,
  40. unsigned long src_skip_bytes);
  41. typedef void (*WriteCopyFunction) (char *dst, jack_default_audio_sample_t *src,
  42. unsigned long src_bytes,
  43. unsigned long dst_skip_bytes,
  44. dither_state_t *state);
  45. typedef struct _alsa_driver {
  46. JACK_DRIVER_NT_DECL
  47. int poll_timeout;
  48. jack_time_t poll_last;
  49. jack_time_t poll_next;
  50. char **playback_addr;
  51. char **capture_addr;
  52. const snd_pcm_channel_area_t *capture_areas;
  53. const snd_pcm_channel_area_t *playback_areas;
  54. struct pollfd *pfd;
  55. unsigned int playback_nfds;
  56. unsigned int capture_nfds;
  57. unsigned long interleave_unit;
  58. unsigned long *capture_interleave_skip;
  59. unsigned long *playback_interleave_skip;
  60. channel_t max_nchannels;
  61. channel_t user_nchannels;
  62. channel_t playback_nchannels;
  63. channel_t capture_nchannels;
  64. unsigned long playback_sample_bytes;
  65. unsigned long capture_sample_bytes;
  66. jack_nframes_t frame_rate;
  67. jack_nframes_t frames_per_cycle;
  68. jack_nframes_t capture_frame_latency;
  69. jack_nframes_t playback_frame_latency;
  70. unsigned long *silent;
  71. char *alsa_name_playback;
  72. char *alsa_name_capture;
  73. char *alsa_driver;
  74. bitset_t channels_not_done;
  75. bitset_t channels_done;
  76. snd_pcm_format_t playback_sample_format;
  77. snd_pcm_format_t capture_sample_format;
  78. float max_sample_val;
  79. unsigned long user_nperiods;
  80. unsigned int playback_nperiods;
  81. unsigned int capture_nperiods;
  82. unsigned long last_mask;
  83. snd_ctl_t *ctl_handle;
  84. snd_pcm_t *playback_handle;
  85. snd_pcm_t *capture_handle;
  86. snd_pcm_hw_params_t *playback_hw_params;
  87. snd_pcm_sw_params_t *playback_sw_params;
  88. snd_pcm_hw_params_t *capture_hw_params;
  89. snd_pcm_sw_params_t *capture_sw_params;
  90. jack_hardware_t *hw;
  91. ClockSyncStatus *clock_sync_data;
  92. jack_client_t *client;
  93. JSList *capture_ports;
  94. JSList *playback_ports;
  95. JSList *monitor_ports;
  96. unsigned long input_monitor_mask;
  97. char soft_mode;
  98. char hw_monitoring;
  99. char hw_metering;
  100. char all_monitor_in;
  101. char capture_and_playback_not_synced;
  102. char playback_interleaved;
  103. char capture_interleaved;
  104. char with_monitor_ports;
  105. char has_clock_sync_reporting;
  106. char has_hw_monitoring;
  107. char has_hw_metering;
  108. char quirk_bswap;
  109. char hw_timestamping;
  110. ReadCopyFunction read_via_copy;
  111. WriteCopyFunction write_via_copy;
  112. int dither;
  113. dither_state_t *dither_state;
  114. SampleClockMode clock_mode;
  115. JSList *clock_sync_listeners;
  116. pthread_mutex_t clock_sync_lock;
  117. unsigned long next_clock_sync_listener_id;
  118. int running;
  119. int run;
  120. int poll_late;
  121. int xrun_count;
  122. int process_count;
  123. alsa_midi_t *midi;
  124. int xrun_recovery;
  125. } alsa_driver_t;
  126. static inline void
  127. alsa_driver_mark_channel_done (alsa_driver_t *driver, channel_t chn) {
  128. bitset_remove (driver->channels_not_done, chn);
  129. driver->silent[chn] = 0;
  130. }
  131. static inline void
  132. alsa_driver_silence_on_channel (alsa_driver_t *driver, channel_t chn,
  133. jack_nframes_t nframes) {
  134. if (driver->playback_interleaved) {
  135. memset_interleave
  136. (driver->playback_addr[chn],
  137. 0, nframes * driver->playback_sample_bytes,
  138. driver->interleave_unit,
  139. driver->playback_interleave_skip[chn]);
  140. } else {
  141. memset (driver->playback_addr[chn], 0,
  142. nframes * driver->playback_sample_bytes);
  143. }
  144. alsa_driver_mark_channel_done (driver,chn);
  145. }
  146. static inline void
  147. alsa_driver_silence_on_channel_no_mark (alsa_driver_t *driver, channel_t chn,
  148. jack_nframes_t nframes) {
  149. if (driver->playback_interleaved) {
  150. memset_interleave
  151. (driver->playback_addr[chn],
  152. 0, nframes * driver->playback_sample_bytes,
  153. driver->interleave_unit,
  154. driver->playback_interleave_skip[chn]);
  155. } else {
  156. memset (driver->playback_addr[chn], 0,
  157. nframes * driver->playback_sample_bytes);
  158. }
  159. }
  160. static inline void
  161. alsa_driver_read_from_channel (alsa_driver_t *driver,
  162. channel_t channel,
  163. jack_default_audio_sample_t *buf,
  164. jack_nframes_t nsamples)
  165. {
  166. driver->read_via_copy (buf,
  167. driver->capture_addr[channel],
  168. nsamples,
  169. driver->capture_interleave_skip[channel]);
  170. }
  171. static inline void
  172. alsa_driver_write_to_channel (alsa_driver_t *driver,
  173. channel_t channel,
  174. jack_default_audio_sample_t *buf,
  175. jack_nframes_t nsamples)
  176. {
  177. driver->write_via_copy (driver->playback_addr[channel],
  178. buf,
  179. nsamples,
  180. driver->playback_interleave_skip[channel],
  181. driver->dither_state+channel);
  182. alsa_driver_mark_channel_done (driver, channel);
  183. }
  184. void alsa_driver_silence_untouched_channels (alsa_driver_t *driver,
  185. jack_nframes_t nframes);
  186. void alsa_driver_set_clock_sync_status (alsa_driver_t *driver, channel_t chn,
  187. ClockSyncStatus status);
  188. int alsa_driver_listen_for_clock_sync_status (alsa_driver_t *,
  189. ClockSyncListenerFunction,
  190. void *arg);
  191. int alsa_driver_stop_listen_for_clock_sync_status (alsa_driver_t *,
  192. unsigned int);
  193. void alsa_driver_clock_sync_notify (alsa_driver_t *, channel_t chn,
  194. ClockSyncStatus);
  195. int
  196. alsa_driver_reset_parameters (alsa_driver_t *driver,
  197. jack_nframes_t frames_per_cycle,
  198. jack_nframes_t user_nperiods,
  199. jack_nframes_t rate);
  200. jack_driver_t *
  201. alsa_driver_new (char *name, char *playback_alsa_device,
  202. char *capture_alsa_device,
  203. jack_client_t *client,
  204. jack_nframes_t frames_per_cycle,
  205. jack_nframes_t user_nperiods,
  206. jack_nframes_t rate,
  207. int hw_monitoring,
  208. int hw_metering,
  209. int capturing,
  210. int playing,
  211. DitherAlgorithm dither,
  212. int soft_mode,
  213. int monitor,
  214. int user_capture_nchnls,
  215. int user_playback_nchnls,
  216. int shorts_first,
  217. jack_nframes_t capture_latency,
  218. jack_nframes_t playback_latency,
  219. alsa_midi_t *midi_driver,
  220. int hw_timestamping
  221. );
  222. void
  223. alsa_driver_delete (alsa_driver_t *driver);
  224. int
  225. alsa_driver_start (alsa_driver_t *driver);
  226. int
  227. alsa_driver_stop (alsa_driver_t *driver);
  228. jack_nframes_t
  229. alsa_driver_wait (alsa_driver_t *driver, int extra_fd, int *status, float
  230. *delayed_usecs);
  231. int
  232. alsa_driver_read (alsa_driver_t *driver, jack_nframes_t nframes);
  233. int
  234. alsa_driver_write (alsa_driver_t* driver, jack_nframes_t nframes);
  235. jack_time_t jack_get_microseconds(void);
  236. // Code implemented in JackAlsaDriver.cpp
  237. void ReadInput(jack_nframes_t orig_nframes, snd_pcm_sframes_t contiguous, snd_pcm_sframes_t nread);
  238. void MonitorInput();
  239. void ClearOutput();
  240. void WriteOutput(jack_nframes_t orig_nframes, snd_pcm_sframes_t contiguous, snd_pcm_sframes_t nwritten);
  241. void SetTime(jack_time_t time);
  242. int Restart();
  243. #ifdef __cplusplus
  244. }
  245. #endif
  246. #endif /* __jack_alsa_driver_h__ */