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.

307 lines
9.4KB

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