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.

383 lines
11KB

  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_FORMAT_UNKNOWN SND_PCM_SFMT_SPECIAL
  47. #define SND_PCM_STATE_PREPARED SND_PCM_STATUS_PREPARED
  48. #define SND_PCM_STATE_SUSPENDED SND_PCM_STATUS_SUSPENDED
  49. #define SND_PCM_STATE_XRUN SND_PCM_STATUS_UNDERRUN
  50. #define SND_PCM_STATE_RUNNING SND_PCM_STATUS_RUNNING
  51. #define SND_PCM_STATE_NOTREADY SND_PCM_STATUS_NOTREADY
  52. #define SND_PCM_STREAM_PLAYBACK SND_PCM_CHANNEL_PLAYBACK
  53. #define SND_PCM_STREAM_CAPTURE SND_PCM_CHANNEL_CAPTURE
  54. typedef unsigned long snd_pcm_uframes_t;
  55. typedef signed long snd_pcm_sframes_t;
  56. typedef int32_t alsa_driver_default_format_t;
  57. #else
  58. #define SND_PCM_STATE_NOTREADY (SND_PCM_STATE_LAST + 1)
  59. #endif
  60. #define ALSA_DRIVER_FEAT_BACKEND_EVAL_ON_INIT (1 << 0)
  61. #define ALSA_DRIVER_FEAT_BACKEND_CLOSE_IDLE (1 << 1)
  62. #define ALSA_DRIVER_FEAT_UNLINKED_DEVS (1 << 2)
  63. #ifdef __cplusplus
  64. extern "C"
  65. {
  66. #endif
  67. typedef void (*ReadCopyFunction) (jack_default_audio_sample_t *dst, char *src,
  68. unsigned long src_bytes,
  69. unsigned long src_skip_bytes);
  70. typedef void (*WriteCopyFunction) (char *dst, jack_default_audio_sample_t *src,
  71. unsigned long src_bytes,
  72. unsigned long dst_skip_bytes,
  73. dither_state_t *state);
  74. typedef struct _alsa_device {
  75. #ifdef __QNXNTO__
  76. unsigned int playback_sample_format;
  77. unsigned int capture_sample_format;
  78. void *capture_areas;
  79. void *playback_areas;
  80. void *capture_areas_ptr;
  81. void *playback_areas_ptr;
  82. #else
  83. snd_pcm_format_t playback_sample_format;
  84. snd_pcm_format_t capture_sample_format;
  85. const snd_pcm_channel_area_t *capture_areas;
  86. const snd_pcm_channel_area_t *playback_areas;
  87. #endif
  88. snd_pcm_t *playback_handle;
  89. snd_pcm_t *capture_handle;
  90. char *playback_name;
  91. char *capture_name;
  92. char **playback_addr;
  93. char **capture_addr;
  94. channel_t playback_channel_offset;
  95. channel_t capture_channel_offset;
  96. channel_t playback_nchannels;
  97. channel_t capture_nchannels;
  98. channel_t max_nchannels;
  99. channel_t user_nchannels;
  100. bitset_t channels_not_done;
  101. bitset_t channels_done;
  102. char quirk_bswap;
  103. ReadCopyFunction read_via_copy;
  104. WriteCopyFunction write_via_copy;
  105. unsigned long interleave_unit;
  106. unsigned long *capture_interleave_skip;
  107. unsigned long *playback_interleave_skip;
  108. char playback_interleaved;
  109. char capture_interleaved;
  110. unsigned long *silent;
  111. unsigned long playback_sample_bytes;
  112. unsigned long capture_sample_bytes;
  113. /* device is 'snd_pcm_link' to a group, only 1 group of linked devices is allowed */
  114. int capture_linked;
  115. int playback_linked;
  116. int capture_xrun_count;
  117. int playback_xrun_count;
  118. /* desired state of device, decided by JackAlsaDriver */
  119. int capture_target_state;
  120. int playback_target_state;
  121. jack_hardware_t *hw;
  122. snd_ctl_t *ctl_handle;
  123. char *alsa_driver;
  124. JSList *clock_sync_listeners;
  125. pthread_mutex_t clock_sync_lock;
  126. unsigned long next_clock_sync_listener_id;
  127. } alsa_device_t;
  128. typedef struct _alsa_driver {
  129. JACK_DRIVER_NT_DECL
  130. #ifndef __QNXNTO__
  131. snd_pcm_hw_params_t *playback_hw_params;
  132. snd_pcm_sw_params_t *playback_sw_params;
  133. snd_pcm_hw_params_t *capture_hw_params;
  134. snd_pcm_sw_params_t *capture_sw_params;
  135. #endif
  136. int poll_timeout_ms;
  137. jack_time_t poll_last;
  138. jack_time_t poll_next;
  139. struct pollfd *pfd;
  140. unsigned int playback_nfds;
  141. unsigned int capture_nfds;
  142. channel_t playback_nchannels;
  143. channel_t capture_nchannels;
  144. jack_nframes_t frame_rate;
  145. jack_nframes_t frames_per_cycle;
  146. jack_nframes_t capture_frame_latency;
  147. jack_nframes_t playback_frame_latency;
  148. unsigned long user_nperiods;
  149. unsigned int playback_nperiods;
  150. unsigned int capture_nperiods;
  151. jack_client_t *client;
  152. unsigned long input_monitor_mask;
  153. char soft_mode;
  154. char hw_monitoring;
  155. char hw_metering;
  156. char all_monitor_in;
  157. char with_monitor_ports;
  158. char has_clock_sync_reporting;
  159. char has_hw_monitoring;
  160. char has_hw_metering;
  161. int preferred_sample_bytes;
  162. int dither;
  163. dither_state_t *dither_state;
  164. SampleClockMode clock_mode;
  165. int poll_late;
  166. int xrun_count;
  167. int process_count;
  168. alsa_midi_t *midi;
  169. int xrun_recovery;
  170. alsa_device_t *devices;
  171. int devices_count;
  172. int devices_c_count;
  173. int devices_p_count;
  174. int features;
  175. } alsa_driver_t;
  176. typedef struct _alsa_device_info {
  177. char *capture_name;
  178. char *playback_name;
  179. int capture_channels;
  180. int playback_channels;
  181. } alsa_device_info_t;
  182. typedef struct _alsa_driver_info {
  183. alsa_device_info_t *devices;
  184. uint32_t devices_capture_size;
  185. uint32_t devices_playback_size;
  186. char *midi_name;
  187. alsa_midi_t *midi_driver;
  188. jack_nframes_t frame_rate;
  189. jack_nframes_t frames_per_period;
  190. int periods_n;
  191. DitherAlgorithm dither;
  192. int shorts_first;
  193. jack_nframes_t capture_latency;
  194. jack_nframes_t playback_latency;
  195. // these 4 should be reworked as struct.features
  196. int hw_monitoring;
  197. int hw_metering;
  198. int monitor;
  199. int soft_mode;
  200. int features;
  201. } alsa_driver_info_t;
  202. static inline void
  203. alsa_driver_mark_channel_done (alsa_driver_t *driver, alsa_device_t *device, channel_t chn) {
  204. bitset_remove (device->channels_not_done, chn);
  205. device->silent[chn] = 0;
  206. }
  207. static inline void
  208. alsa_driver_silence_on_channel (alsa_driver_t *driver, alsa_device_t *device, channel_t chn,
  209. jack_nframes_t nframes) {
  210. if (device->playback_interleaved) {
  211. memset_interleave
  212. (device->playback_addr[chn],
  213. 0, nframes * device->playback_sample_bytes,
  214. device->interleave_unit,
  215. device->playback_interleave_skip[chn]);
  216. } else {
  217. memset (device->playback_addr[chn], 0,
  218. nframes * device->playback_sample_bytes);
  219. }
  220. alsa_driver_mark_channel_done (driver, device, chn);
  221. }
  222. static inline void
  223. alsa_driver_silence_on_channel_no_mark (alsa_driver_t *driver, alsa_device_t *device, channel_t chn,
  224. jack_nframes_t nframes) {
  225. if (device->playback_interleaved) {
  226. memset_interleave
  227. (device->playback_addr[chn],
  228. 0, nframes * device->playback_sample_bytes,
  229. device->interleave_unit,
  230. device->playback_interleave_skip[chn]);
  231. } else {
  232. memset (device->playback_addr[chn], 0,
  233. nframes * device->playback_sample_bytes);
  234. }
  235. }
  236. static inline void
  237. alsa_driver_read_from_channel (alsa_driver_t *driver,
  238. alsa_device_t *device,
  239. channel_t channel,
  240. jack_default_audio_sample_t *buf,
  241. jack_nframes_t nsamples)
  242. {
  243. device->read_via_copy (buf,
  244. device->capture_addr[channel],
  245. nsamples,
  246. device->capture_interleave_skip[channel]);
  247. }
  248. static inline void
  249. alsa_driver_write_to_channel (alsa_driver_t *driver,
  250. alsa_device_t *device,
  251. channel_t channel,
  252. jack_default_audio_sample_t *buf,
  253. jack_nframes_t nsamples)
  254. {
  255. device->write_via_copy (device->playback_addr[channel],
  256. buf,
  257. nsamples,
  258. device->playback_interleave_skip[channel],
  259. driver->dither_state+channel);
  260. alsa_driver_mark_channel_done (driver, device, channel);
  261. }
  262. int
  263. alsa_driver_reset_parameters (alsa_driver_t *driver,
  264. jack_nframes_t frames_per_cycle,
  265. jack_nframes_t user_nperiods,
  266. jack_nframes_t rate);
  267. jack_driver_t *
  268. alsa_driver_new (char *name, alsa_driver_info_t info, jack_client_t *client);
  269. void
  270. alsa_driver_delete (alsa_driver_t *driver);
  271. int
  272. alsa_driver_open (alsa_driver_t *driver);
  273. int
  274. alsa_driver_start (alsa_driver_t *driver);
  275. int
  276. alsa_driver_stop (alsa_driver_t *driver);
  277. int
  278. alsa_driver_close (alsa_driver_t *driver);
  279. typedef enum {
  280. ALSA_DRIVER_WAIT_OK = 0,
  281. ALSA_DRIVER_WAIT_ERROR = -1,
  282. ALSA_DRIVER_WAIT_XRUN = -2,
  283. } alsa_driver_wait_status_t;
  284. jack_nframes_t
  285. alsa_driver_wait (alsa_driver_t *driver, int extra_fd, alsa_driver_wait_status_t *status, float
  286. *delayed_usecs);
  287. int
  288. alsa_driver_read (alsa_driver_t *driver, jack_nframes_t nframes);
  289. int
  290. alsa_driver_write (alsa_driver_t* driver, jack_nframes_t nframes);
  291. int
  292. alsa_driver_xrun_recovery (alsa_driver_t *driver, float *delayed_usecs);
  293. // Code implemented in JackAlsaDriver.cpp
  294. void ReadInput(alsa_device_t *device, jack_nframes_t orig_nframes, snd_pcm_sframes_t contiguous, snd_pcm_sframes_t nread);
  295. void MonitorInput();
  296. void ClearOutput();
  297. void WriteOutput(alsa_device_t *device, jack_nframes_t orig_nframes, snd_pcm_sframes_t contiguous, snd_pcm_sframes_t nwritten);
  298. void SetTime(jack_time_t time);
  299. int Restart();
  300. #ifdef __cplusplus
  301. }
  302. #endif
  303. #endif /* __jack_alsa_driver_h__ */