compress_driver.h 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  1. /* SPDX-License-Identifier: GPL-2.0
  2. *
  3. * compress_driver.h - compress offload driver definations
  4. *
  5. * Copyright (C) 2011 Intel Corporation
  6. * Authors: Vinod Koul <[email protected]>
  7. * Pierre-Louis Bossart <[email protected]>
  8. */
  9. #ifndef __COMPRESS_DRIVER_H
  10. #define __COMPRESS_DRIVER_H
  11. #include <linux/types.h>
  12. #include <linux/sched.h>
  13. #include <linux/android_kabi.h>
  14. #include <sound/core.h>
  15. #include <sound/compress_offload.h>
  16. #include <sound/asound.h>
  17. #include <sound/pcm.h>
  18. struct snd_compr_ops;
  19. /**
  20. * struct snd_compr_runtime: runtime stream description
  21. * @state: stream state
  22. * @ops: pointer to DSP callbacks
  23. * @buffer: pointer to kernel buffer, valid only when not in mmap mode or
  24. * DSP doesn't implement copy
  25. * @buffer_size: size of the above buffer
  26. * @fragment_size: size of buffer fragment in bytes
  27. * @fragments: number of such fragments
  28. * @total_bytes_available: cumulative number of bytes made available in
  29. * the ring buffer
  30. * @total_bytes_transferred: cumulative bytes transferred by offload DSP
  31. * @sleep: poll sleep
  32. * @private_data: driver private data pointer
  33. * @dma_area: virtual buffer address
  34. * @dma_addr: physical buffer address (not accessible from main CPU)
  35. * @dma_bytes: size of DMA area
  36. * @dma_buffer_p: runtime dma buffer pointer
  37. */
  38. struct snd_compr_runtime {
  39. snd_pcm_state_t state;
  40. struct snd_compr_ops *ops;
  41. void *buffer;
  42. u64 buffer_size;
  43. u32 fragment_size;
  44. u32 fragments;
  45. u64 total_bytes_available;
  46. u64 total_bytes_transferred;
  47. wait_queue_head_t sleep;
  48. void *private_data;
  49. unsigned char *dma_area;
  50. dma_addr_t dma_addr;
  51. size_t dma_bytes;
  52. struct snd_dma_buffer *dma_buffer_p;
  53. ANDROID_KABI_RESERVE(1);
  54. };
  55. /**
  56. * struct snd_compr_stream: compressed stream
  57. * @name: device name
  58. * @ops: pointer to DSP callbacks
  59. * @runtime: pointer to runtime structure
  60. * @device: device pointer
  61. * @error_work: delayed work used when closing the stream due to an error
  62. * @direction: stream direction, playback/recording
  63. * @metadata_set: metadata set flag, true when set
  64. * @next_track: has userspace signal next track transition, true when set
  65. * @partial_drain: undergoing partial_drain for stream, true when set
  66. * @pause_in_draining: paused during draining state, true when set
  67. * @private_data: pointer to DSP private data
  68. * @dma_buffer: allocated buffer if any
  69. */
  70. struct snd_compr_stream {
  71. const char *name;
  72. struct snd_compr_ops *ops;
  73. struct snd_compr_runtime *runtime;
  74. struct snd_compr *device;
  75. struct delayed_work error_work;
  76. enum snd_compr_direction direction;
  77. bool metadata_set;
  78. bool next_track;
  79. bool partial_drain;
  80. bool pause_in_draining;
  81. void *private_data;
  82. struct snd_dma_buffer dma_buffer;
  83. ANDROID_KABI_RESERVE(1);
  84. };
  85. /**
  86. * struct snd_compr_ops: compressed path DSP operations
  87. * @open: Open the compressed stream
  88. * This callback is mandatory and shall keep dsp ready to receive the stream
  89. * parameter
  90. * @free: Close the compressed stream, mandatory
  91. * @set_params: Sets the compressed stream parameters, mandatory
  92. * This can be called in during stream creation only to set codec params
  93. * and the stream properties
  94. * @get_params: retrieve the codec parameters, mandatory
  95. * @set_metadata: Set the metadata values for a stream
  96. * @get_metadata: retrieves the requested metadata values from stream
  97. * @trigger: Trigger operations like start, pause, resume, drain, stop.
  98. * This callback is mandatory
  99. * @pointer: Retrieve current h/w pointer information. Mandatory
  100. * @copy: Copy the compressed data to/from userspace, Optional
  101. * Can't be implemented if DSP supports mmap
  102. * @mmap: DSP mmap method to mmap DSP memory
  103. * @ack: Ack for DSP when data is written to audio buffer, Optional
  104. * Not valid if copy is implemented
  105. * @get_caps: Retrieve DSP capabilities, mandatory
  106. * @get_codec_caps: Retrieve capabilities for a specific codec, mandatory
  107. */
  108. struct snd_compr_ops {
  109. int (*open)(struct snd_compr_stream *stream);
  110. int (*free)(struct snd_compr_stream *stream);
  111. int (*set_params)(struct snd_compr_stream *stream,
  112. struct snd_compr_params *params);
  113. int (*get_params)(struct snd_compr_stream *stream,
  114. struct snd_codec *params);
  115. int (*set_metadata)(struct snd_compr_stream *stream,
  116. struct snd_compr_metadata *metadata);
  117. int (*get_metadata)(struct snd_compr_stream *stream,
  118. struct snd_compr_metadata *metadata);
  119. int (*trigger)(struct snd_compr_stream *stream, int cmd);
  120. int (*pointer)(struct snd_compr_stream *stream,
  121. struct snd_compr_tstamp *tstamp);
  122. int (*copy)(struct snd_compr_stream *stream, char __user *buf,
  123. size_t count);
  124. int (*mmap)(struct snd_compr_stream *stream,
  125. struct vm_area_struct *vma);
  126. int (*ack)(struct snd_compr_stream *stream, size_t bytes);
  127. int (*get_caps) (struct snd_compr_stream *stream,
  128. struct snd_compr_caps *caps);
  129. int (*get_codec_caps) (struct snd_compr_stream *stream,
  130. struct snd_compr_codec_caps *codec);
  131. ANDROID_KABI_RESERVE(1);
  132. };
  133. /**
  134. * struct snd_compr: Compressed device
  135. * @name: DSP device name
  136. * @dev: associated device instance
  137. * @ops: pointer to DSP callbacks
  138. * @private_data: pointer to DSP pvt data
  139. * @card: sound card pointer
  140. * @direction: Playback or capture direction
  141. * @lock: device lock
  142. * @device: device id
  143. * @use_pause_in_draining: allow pause in draining, true when set
  144. */
  145. struct snd_compr {
  146. const char *name;
  147. struct device dev;
  148. struct snd_compr_ops *ops;
  149. void *private_data;
  150. struct snd_card *card;
  151. unsigned int direction;
  152. struct mutex lock;
  153. int device;
  154. bool use_pause_in_draining;
  155. #ifdef CONFIG_SND_VERBOSE_PROCFS
  156. /* private: */
  157. char id[64];
  158. struct snd_info_entry *proc_root;
  159. struct snd_info_entry *proc_info_entry;
  160. #endif
  161. ANDROID_KABI_RESERVE(1);
  162. };
  163. /* compress device register APIs */
  164. int snd_compress_new(struct snd_card *card, int device,
  165. int type, const char *id, struct snd_compr *compr);
  166. /**
  167. * snd_compr_use_pause_in_draining - Allow pause and resume in draining state
  168. * @substream: compress substream to set
  169. *
  170. * Allow pause and resume in draining state.
  171. * Only HW driver supports this transition can call this API.
  172. */
  173. static inline void snd_compr_use_pause_in_draining(struct snd_compr_stream *substream)
  174. {
  175. substream->device->use_pause_in_draining = true;
  176. }
  177. /* dsp driver callback apis
  178. * For playback: driver should call snd_compress_fragment_elapsed() to let the
  179. * framework know that a fragment has been consumed from the ring buffer
  180. *
  181. * For recording: we want to know when a frame is available or when
  182. * at least one frame is available so snd_compress_frame_elapsed()
  183. * callback should be called when a encodeded frame is available
  184. */
  185. static inline void snd_compr_fragment_elapsed(struct snd_compr_stream *stream)
  186. {
  187. wake_up(&stream->runtime->sleep);
  188. }
  189. static inline void snd_compr_drain_notify(struct snd_compr_stream *stream)
  190. {
  191. if (snd_BUG_ON(!stream))
  192. return;
  193. /* for partial_drain case we are back to running state on success */
  194. if (stream->partial_drain) {
  195. stream->runtime->state = SNDRV_PCM_STATE_RUNNING;
  196. stream->partial_drain = false; /* clear this flag as well */
  197. } else {
  198. stream->runtime->state = SNDRV_PCM_STATE_SETUP;
  199. }
  200. wake_up(&stream->runtime->sleep);
  201. }
  202. /**
  203. * snd_compr_set_runtime_buffer - Set the Compress runtime buffer
  204. * @stream: compress stream to set
  205. * @bufp: the buffer information, NULL to clear
  206. *
  207. * Copy the buffer information to runtime buffer when @bufp is non-NULL.
  208. * Otherwise it clears the current buffer information.
  209. */
  210. static inline void
  211. snd_compr_set_runtime_buffer(struct snd_compr_stream *stream,
  212. struct snd_dma_buffer *bufp)
  213. {
  214. struct snd_compr_runtime *runtime = stream->runtime;
  215. if (bufp) {
  216. runtime->dma_buffer_p = bufp;
  217. runtime->dma_area = bufp->area;
  218. runtime->dma_addr = bufp->addr;
  219. runtime->dma_bytes = bufp->bytes;
  220. } else {
  221. runtime->dma_buffer_p = NULL;
  222. runtime->dma_area = NULL;
  223. runtime->dma_addr = 0;
  224. runtime->dma_bytes = 0;
  225. }
  226. }
  227. int snd_compr_malloc_pages(struct snd_compr_stream *stream, size_t size);
  228. int snd_compr_free_pages(struct snd_compr_stream *stream);
  229. int snd_compr_stop_error(struct snd_compr_stream *stream,
  230. snd_pcm_state_t state);
  231. #endif