xref: /linux/sound/core/compress_offload.c (revision 4b660dbd9ee2059850fd30e0df420ca7a38a1856)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  *  compress_core.c - compress offload core
4  *
5  *  Copyright (C) 2011 Intel Corporation
6  *  Authors:	Vinod Koul <vinod.koul@linux.intel.com>
7  *		Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
8  *  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
9  *
10  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
11  */
12 #define FORMAT(fmt) "%s: %d: " fmt, __func__, __LINE__
13 #define pr_fmt(fmt) KBUILD_MODNAME ": " FORMAT(fmt)
14 
15 #include <linux/file.h>
16 #include <linux/fs.h>
17 #include <linux/list.h>
18 #include <linux/math64.h>
19 #include <linux/mm.h>
20 #include <linux/mutex.h>
21 #include <linux/poll.h>
22 #include <linux/slab.h>
23 #include <linux/sched.h>
24 #include <linux/types.h>
25 #include <linux/uio.h>
26 #include <linux/uaccess.h>
27 #include <linux/module.h>
28 #include <linux/compat.h>
29 #include <sound/core.h>
30 #include <sound/initval.h>
31 #include <sound/info.h>
32 #include <sound/compress_params.h>
33 #include <sound/compress_offload.h>
34 #include <sound/compress_driver.h>
35 
36 /* struct snd_compr_codec_caps overflows the ioctl bit size for some
37  * architectures, so we need to disable the relevant ioctls.
38  */
39 #if _IOC_SIZEBITS < 14
40 #define COMPR_CODEC_CAPS_OVERFLOW
41 #endif
42 
43 /* TODO:
44  * - add substream support for multiple devices in case of
45  *	SND_DYNAMIC_MINORS is not used
46  * - Multiple node representation
47  *	driver should be able to register multiple nodes
48  */
49 
50 struct snd_compr_file {
51 	unsigned long caps;
52 	struct snd_compr_stream stream;
53 };
54 
55 static void error_delayed_work(struct work_struct *work);
56 
57 /*
58  * a note on stream states used:
59  * we use following states in the compressed core
60  * SNDRV_PCM_STATE_OPEN: When stream has been opened.
61  * SNDRV_PCM_STATE_SETUP: When stream has been initialized. This is done by
62  *	calling SNDRV_COMPRESS_SET_PARAMS. Running streams will come to this
63  *	state at stop by calling SNDRV_COMPRESS_STOP, or at end of drain.
64  * SNDRV_PCM_STATE_PREPARED: When a stream has been written to (for
65  *	playback only). User after setting up stream writes the data buffer
66  *	before starting the stream.
67  * SNDRV_PCM_STATE_RUNNING: When stream has been started and is
68  *	decoding/encoding and rendering/capturing data.
69  * SNDRV_PCM_STATE_DRAINING: When stream is draining current data. This is done
70  *	by calling SNDRV_COMPRESS_DRAIN.
71  * SNDRV_PCM_STATE_PAUSED: When stream is paused. This is done by calling
72  *	SNDRV_COMPRESS_PAUSE. It can be stopped or resumed by calling
73  *	SNDRV_COMPRESS_STOP or SNDRV_COMPRESS_RESUME respectively.
74  */
75 static int snd_compr_open(struct inode *inode, struct file *f)
76 {
77 	struct snd_compr *compr;
78 	struct snd_compr_file *data;
79 	struct snd_compr_runtime *runtime;
80 	enum snd_compr_direction dirn;
81 	int maj = imajor(inode);
82 	int ret;
83 
84 	if ((f->f_flags & O_ACCMODE) == O_WRONLY)
85 		dirn = SND_COMPRESS_PLAYBACK;
86 	else if ((f->f_flags & O_ACCMODE) == O_RDONLY)
87 		dirn = SND_COMPRESS_CAPTURE;
88 	else
89 		return -EINVAL;
90 
91 	if (maj == snd_major)
92 		compr = snd_lookup_minor_data(iminor(inode),
93 					SNDRV_DEVICE_TYPE_COMPRESS);
94 	else
95 		return -EBADFD;
96 
97 	if (compr == NULL) {
98 		pr_err("no device data!!!\n");
99 		return -ENODEV;
100 	}
101 
102 	if (dirn != compr->direction) {
103 		pr_err("this device doesn't support this direction\n");
104 		snd_card_unref(compr->card);
105 		return -EINVAL;
106 	}
107 
108 	data = kzalloc(sizeof(*data), GFP_KERNEL);
109 	if (!data) {
110 		snd_card_unref(compr->card);
111 		return -ENOMEM;
112 	}
113 
114 	INIT_DELAYED_WORK(&data->stream.error_work, error_delayed_work);
115 
116 	data->stream.ops = compr->ops;
117 	data->stream.direction = dirn;
118 	data->stream.private_data = compr->private_data;
119 	data->stream.device = compr;
120 	runtime = kzalloc(sizeof(*runtime), GFP_KERNEL);
121 	if (!runtime) {
122 		kfree(data);
123 		snd_card_unref(compr->card);
124 		return -ENOMEM;
125 	}
126 	runtime->state = SNDRV_PCM_STATE_OPEN;
127 	init_waitqueue_head(&runtime->sleep);
128 	data->stream.runtime = runtime;
129 	f->private_data = (void *)data;
130 	scoped_guard(mutex, &compr->lock)
131 		ret = compr->ops->open(&data->stream);
132 	if (ret) {
133 		kfree(runtime);
134 		kfree(data);
135 	}
136 	snd_card_unref(compr->card);
137 	return ret;
138 }
139 
140 static int snd_compr_free(struct inode *inode, struct file *f)
141 {
142 	struct snd_compr_file *data = f->private_data;
143 	struct snd_compr_runtime *runtime = data->stream.runtime;
144 
145 	cancel_delayed_work_sync(&data->stream.error_work);
146 
147 	switch (runtime->state) {
148 	case SNDRV_PCM_STATE_RUNNING:
149 	case SNDRV_PCM_STATE_DRAINING:
150 	case SNDRV_PCM_STATE_PAUSED:
151 		data->stream.ops->trigger(&data->stream, SNDRV_PCM_TRIGGER_STOP);
152 		break;
153 	default:
154 		break;
155 	}
156 
157 	data->stream.ops->free(&data->stream);
158 	if (!data->stream.runtime->dma_buffer_p)
159 		kfree(data->stream.runtime->buffer);
160 	kfree(data->stream.runtime);
161 	kfree(data);
162 	return 0;
163 }
164 
165 static int snd_compr_update_tstamp(struct snd_compr_stream *stream,
166 		struct snd_compr_tstamp *tstamp)
167 {
168 	if (!stream->ops->pointer)
169 		return -ENOTSUPP;
170 	stream->ops->pointer(stream, tstamp);
171 	pr_debug("dsp consumed till %d total %d bytes\n",
172 		tstamp->byte_offset, tstamp->copied_total);
173 	if (stream->direction == SND_COMPRESS_PLAYBACK)
174 		stream->runtime->total_bytes_transferred = tstamp->copied_total;
175 	else
176 		stream->runtime->total_bytes_available = tstamp->copied_total;
177 	return 0;
178 }
179 
180 static size_t snd_compr_calc_avail(struct snd_compr_stream *stream,
181 		struct snd_compr_avail *avail)
182 {
183 	memset(avail, 0, sizeof(*avail));
184 	snd_compr_update_tstamp(stream, &avail->tstamp);
185 	/* Still need to return avail even if tstamp can't be filled in */
186 
187 	if (stream->runtime->total_bytes_available == 0 &&
188 			stream->runtime->state == SNDRV_PCM_STATE_SETUP &&
189 			stream->direction == SND_COMPRESS_PLAYBACK) {
190 		pr_debug("detected init and someone forgot to do a write\n");
191 		return stream->runtime->buffer_size;
192 	}
193 	pr_debug("app wrote %lld, DSP consumed %lld\n",
194 			stream->runtime->total_bytes_available,
195 			stream->runtime->total_bytes_transferred);
196 	if (stream->runtime->total_bytes_available ==
197 				stream->runtime->total_bytes_transferred) {
198 		if (stream->direction == SND_COMPRESS_PLAYBACK) {
199 			pr_debug("both pointers are same, returning full avail\n");
200 			return stream->runtime->buffer_size;
201 		} else {
202 			pr_debug("both pointers are same, returning no avail\n");
203 			return 0;
204 		}
205 	}
206 
207 	avail->avail = stream->runtime->total_bytes_available -
208 			stream->runtime->total_bytes_transferred;
209 	if (stream->direction == SND_COMPRESS_PLAYBACK)
210 		avail->avail = stream->runtime->buffer_size - avail->avail;
211 
212 	pr_debug("ret avail as %lld\n", avail->avail);
213 	return avail->avail;
214 }
215 
216 static inline size_t snd_compr_get_avail(struct snd_compr_stream *stream)
217 {
218 	struct snd_compr_avail avail;
219 
220 	return snd_compr_calc_avail(stream, &avail);
221 }
222 
223 static int
224 snd_compr_ioctl_avail(struct snd_compr_stream *stream, unsigned long arg)
225 {
226 	struct snd_compr_avail ioctl_avail;
227 	size_t avail;
228 
229 	avail = snd_compr_calc_avail(stream, &ioctl_avail);
230 	ioctl_avail.avail = avail;
231 
232 	switch (stream->runtime->state) {
233 	case SNDRV_PCM_STATE_OPEN:
234 		return -EBADFD;
235 	case SNDRV_PCM_STATE_XRUN:
236 		return -EPIPE;
237 	default:
238 		break;
239 	}
240 
241 	if (copy_to_user((__u64 __user *)arg,
242 				&ioctl_avail, sizeof(ioctl_avail)))
243 		return -EFAULT;
244 	return 0;
245 }
246 
247 static int snd_compr_write_data(struct snd_compr_stream *stream,
248 	       const char __user *buf, size_t count)
249 {
250 	void *dstn;
251 	size_t copy;
252 	struct snd_compr_runtime *runtime = stream->runtime;
253 	/* 64-bit Modulus */
254 	u64 app_pointer = div64_u64(runtime->total_bytes_available,
255 				    runtime->buffer_size);
256 	app_pointer = runtime->total_bytes_available -
257 		      (app_pointer * runtime->buffer_size);
258 
259 	dstn = runtime->buffer + app_pointer;
260 	pr_debug("copying %ld at %lld\n",
261 			(unsigned long)count, app_pointer);
262 	if (count < runtime->buffer_size - app_pointer) {
263 		if (copy_from_user(dstn, buf, count))
264 			return -EFAULT;
265 	} else {
266 		copy = runtime->buffer_size - app_pointer;
267 		if (copy_from_user(dstn, buf, copy))
268 			return -EFAULT;
269 		if (copy_from_user(runtime->buffer, buf + copy, count - copy))
270 			return -EFAULT;
271 	}
272 	/* if DSP cares, let it know data has been written */
273 	if (stream->ops->ack)
274 		stream->ops->ack(stream, count);
275 	return count;
276 }
277 
278 static ssize_t snd_compr_write(struct file *f, const char __user *buf,
279 		size_t count, loff_t *offset)
280 {
281 	struct snd_compr_file *data = f->private_data;
282 	struct snd_compr_stream *stream;
283 	size_t avail;
284 	int retval;
285 
286 	if (snd_BUG_ON(!data))
287 		return -EFAULT;
288 
289 	stream = &data->stream;
290 	guard(mutex)(&stream->device->lock);
291 	/* write is allowed when stream is running or has been steup */
292 	switch (stream->runtime->state) {
293 	case SNDRV_PCM_STATE_SETUP:
294 	case SNDRV_PCM_STATE_PREPARED:
295 	case SNDRV_PCM_STATE_RUNNING:
296 		break;
297 	default:
298 		return -EBADFD;
299 	}
300 
301 	avail = snd_compr_get_avail(stream);
302 	pr_debug("avail returned %ld\n", (unsigned long)avail);
303 	/* calculate how much we can write to buffer */
304 	if (avail > count)
305 		avail = count;
306 
307 	if (stream->ops->copy) {
308 		char __user* cbuf = (char __user*)buf;
309 		retval = stream->ops->copy(stream, cbuf, avail);
310 	} else {
311 		retval = snd_compr_write_data(stream, buf, avail);
312 	}
313 	if (retval > 0)
314 		stream->runtime->total_bytes_available += retval;
315 
316 	/* while initiating the stream, write should be called before START
317 	 * call, so in setup move state */
318 	if (stream->runtime->state == SNDRV_PCM_STATE_SETUP) {
319 		stream->runtime->state = SNDRV_PCM_STATE_PREPARED;
320 		pr_debug("stream prepared, Houston we are good to go\n");
321 	}
322 
323 	return retval;
324 }
325 
326 
327 static ssize_t snd_compr_read(struct file *f, char __user *buf,
328 		size_t count, loff_t *offset)
329 {
330 	struct snd_compr_file *data = f->private_data;
331 	struct snd_compr_stream *stream;
332 	size_t avail;
333 	int retval;
334 
335 	if (snd_BUG_ON(!data))
336 		return -EFAULT;
337 
338 	stream = &data->stream;
339 	guard(mutex)(&stream->device->lock);
340 
341 	/* read is allowed when stream is running, paused, draining and setup
342 	 * (yes setup is state which we transition to after stop, so if user
343 	 * wants to read data after stop we allow that)
344 	 */
345 	switch (stream->runtime->state) {
346 	case SNDRV_PCM_STATE_OPEN:
347 	case SNDRV_PCM_STATE_PREPARED:
348 	case SNDRV_PCM_STATE_SUSPENDED:
349 	case SNDRV_PCM_STATE_DISCONNECTED:
350 		return -EBADFD;
351 	case SNDRV_PCM_STATE_XRUN:
352 		return -EPIPE;
353 	}
354 
355 	avail = snd_compr_get_avail(stream);
356 	pr_debug("avail returned %ld\n", (unsigned long)avail);
357 	/* calculate how much we can read from buffer */
358 	if (avail > count)
359 		avail = count;
360 
361 	if (stream->ops->copy)
362 		retval = stream->ops->copy(stream, buf, avail);
363 	else
364 		return -ENXIO;
365 	if (retval > 0)
366 		stream->runtime->total_bytes_transferred += retval;
367 
368 	return retval;
369 }
370 
371 static int snd_compr_mmap(struct file *f, struct vm_area_struct *vma)
372 {
373 	return -ENXIO;
374 }
375 
376 static __poll_t snd_compr_get_poll(struct snd_compr_stream *stream)
377 {
378 	if (stream->direction == SND_COMPRESS_PLAYBACK)
379 		return EPOLLOUT | EPOLLWRNORM;
380 	else
381 		return EPOLLIN | EPOLLRDNORM;
382 }
383 
384 static __poll_t snd_compr_poll(struct file *f, poll_table *wait)
385 {
386 	struct snd_compr_file *data = f->private_data;
387 	struct snd_compr_stream *stream;
388 	size_t avail;
389 	__poll_t retval = 0;
390 
391 	if (snd_BUG_ON(!data))
392 		return EPOLLERR;
393 
394 	stream = &data->stream;
395 
396 	guard(mutex)(&stream->device->lock);
397 
398 	switch (stream->runtime->state) {
399 	case SNDRV_PCM_STATE_OPEN:
400 	case SNDRV_PCM_STATE_XRUN:
401 		return snd_compr_get_poll(stream) | EPOLLERR;
402 	default:
403 		break;
404 	}
405 
406 	poll_wait(f, &stream->runtime->sleep, wait);
407 
408 	avail = snd_compr_get_avail(stream);
409 	pr_debug("avail is %ld\n", (unsigned long)avail);
410 	/* check if we have at least one fragment to fill */
411 	switch (stream->runtime->state) {
412 	case SNDRV_PCM_STATE_DRAINING:
413 		/* stream has been woken up after drain is complete
414 		 * draining done so set stream state to stopped
415 		 */
416 		retval = snd_compr_get_poll(stream);
417 		stream->runtime->state = SNDRV_PCM_STATE_SETUP;
418 		break;
419 	case SNDRV_PCM_STATE_RUNNING:
420 	case SNDRV_PCM_STATE_PREPARED:
421 	case SNDRV_PCM_STATE_PAUSED:
422 		if (avail >= stream->runtime->fragment_size)
423 			retval = snd_compr_get_poll(stream);
424 		break;
425 	default:
426 		return snd_compr_get_poll(stream) | EPOLLERR;
427 	}
428 
429 	return retval;
430 }
431 
432 static int
433 snd_compr_get_caps(struct snd_compr_stream *stream, unsigned long arg)
434 {
435 	int retval;
436 	struct snd_compr_caps caps;
437 
438 	if (!stream->ops->get_caps)
439 		return -ENXIO;
440 
441 	memset(&caps, 0, sizeof(caps));
442 	retval = stream->ops->get_caps(stream, &caps);
443 	if (retval)
444 		goto out;
445 	if (copy_to_user((void __user *)arg, &caps, sizeof(caps)))
446 		retval = -EFAULT;
447 out:
448 	return retval;
449 }
450 
451 #ifndef COMPR_CODEC_CAPS_OVERFLOW
452 static int
453 snd_compr_get_codec_caps(struct snd_compr_stream *stream, unsigned long arg)
454 {
455 	int retval;
456 	struct snd_compr_codec_caps *caps __free(kfree) = NULL;
457 
458 	if (!stream->ops->get_codec_caps)
459 		return -ENXIO;
460 
461 	caps = kzalloc(sizeof(*caps), GFP_KERNEL);
462 	if (!caps)
463 		return -ENOMEM;
464 
465 	retval = stream->ops->get_codec_caps(stream, caps);
466 	if (retval)
467 		return retval;
468 	if (copy_to_user((void __user *)arg, caps, sizeof(*caps)))
469 		return -EFAULT;
470 	return retval;
471 }
472 #endif /* !COMPR_CODEC_CAPS_OVERFLOW */
473 
474 int snd_compr_malloc_pages(struct snd_compr_stream *stream, size_t size)
475 {
476 	struct snd_dma_buffer *dmab;
477 	int ret;
478 
479 	if (snd_BUG_ON(!(stream) || !(stream)->runtime))
480 		return -EINVAL;
481 	dmab = kzalloc(sizeof(*dmab), GFP_KERNEL);
482 	if (!dmab)
483 		return -ENOMEM;
484 	dmab->dev = stream->dma_buffer.dev;
485 	ret = snd_dma_alloc_pages(dmab->dev.type, dmab->dev.dev, size, dmab);
486 	if (ret < 0) {
487 		kfree(dmab);
488 		return ret;
489 	}
490 
491 	snd_compr_set_runtime_buffer(stream, dmab);
492 	stream->runtime->dma_bytes = size;
493 	return 1;
494 }
495 EXPORT_SYMBOL(snd_compr_malloc_pages);
496 
497 int snd_compr_free_pages(struct snd_compr_stream *stream)
498 {
499 	struct snd_compr_runtime *runtime;
500 
501 	if (snd_BUG_ON(!(stream) || !(stream)->runtime))
502 		return -EINVAL;
503 	runtime = stream->runtime;
504 	if (runtime->dma_area == NULL)
505 		return 0;
506 	if (runtime->dma_buffer_p != &stream->dma_buffer) {
507 		/* It's a newly allocated buffer. Release it now. */
508 		snd_dma_free_pages(runtime->dma_buffer_p);
509 		kfree(runtime->dma_buffer_p);
510 	}
511 
512 	snd_compr_set_runtime_buffer(stream, NULL);
513 	return 0;
514 }
515 EXPORT_SYMBOL(snd_compr_free_pages);
516 
517 /* revisit this with snd_pcm_preallocate_xxx */
518 static int snd_compr_allocate_buffer(struct snd_compr_stream *stream,
519 		struct snd_compr_params *params)
520 {
521 	unsigned int buffer_size;
522 	void *buffer = NULL;
523 
524 	buffer_size = params->buffer.fragment_size * params->buffer.fragments;
525 	if (stream->ops->copy) {
526 		buffer = NULL;
527 		/* if copy is defined the driver will be required to copy
528 		 * the data from core
529 		 */
530 	} else {
531 		if (stream->runtime->dma_buffer_p) {
532 
533 			if (buffer_size > stream->runtime->dma_buffer_p->bytes)
534 				dev_err(stream->device->dev,
535 						"Not enough DMA buffer");
536 			else
537 				buffer = stream->runtime->dma_buffer_p->area;
538 
539 		} else {
540 			buffer = kmalloc(buffer_size, GFP_KERNEL);
541 		}
542 
543 		if (!buffer)
544 			return -ENOMEM;
545 	}
546 	stream->runtime->fragment_size = params->buffer.fragment_size;
547 	stream->runtime->fragments = params->buffer.fragments;
548 	stream->runtime->buffer = buffer;
549 	stream->runtime->buffer_size = buffer_size;
550 	return 0;
551 }
552 
553 static int snd_compress_check_input(struct snd_compr_params *params)
554 {
555 	/* first let's check the buffer parameter's */
556 	if (params->buffer.fragment_size == 0 ||
557 	    params->buffer.fragments > U32_MAX / params->buffer.fragment_size ||
558 	    params->buffer.fragments == 0)
559 		return -EINVAL;
560 
561 	/* now codec parameters */
562 	if (params->codec.id == 0 || params->codec.id > SND_AUDIOCODEC_MAX)
563 		return -EINVAL;
564 
565 	if (params->codec.ch_in == 0 || params->codec.ch_out == 0)
566 		return -EINVAL;
567 
568 	return 0;
569 }
570 
571 static int
572 snd_compr_set_params(struct snd_compr_stream *stream, unsigned long arg)
573 {
574 	struct snd_compr_params *params __free(kfree) = NULL;
575 	int retval;
576 
577 	if (stream->runtime->state == SNDRV_PCM_STATE_OPEN || stream->next_track) {
578 		/*
579 		 * we should allow parameter change only when stream has been
580 		 * opened not in other cases
581 		 */
582 		params = memdup_user((void __user *)arg, sizeof(*params));
583 		if (IS_ERR(params))
584 			return PTR_ERR(no_free_ptr(params));
585 
586 		retval = snd_compress_check_input(params);
587 		if (retval)
588 			return retval;
589 
590 		retval = snd_compr_allocate_buffer(stream, params);
591 		if (retval)
592 			return -ENOMEM;
593 
594 		retval = stream->ops->set_params(stream, params);
595 		if (retval)
596 			return retval;
597 
598 		if (stream->next_track)
599 			return retval;
600 
601 		stream->metadata_set = false;
602 		stream->next_track = false;
603 
604 		stream->runtime->state = SNDRV_PCM_STATE_SETUP;
605 	} else {
606 		return -EPERM;
607 	}
608 	return retval;
609 }
610 
611 static int
612 snd_compr_get_params(struct snd_compr_stream *stream, unsigned long arg)
613 {
614 	struct snd_codec *params __free(kfree) = NULL;
615 	int retval;
616 
617 	if (!stream->ops->get_params)
618 		return -EBADFD;
619 
620 	params = kzalloc(sizeof(*params), GFP_KERNEL);
621 	if (!params)
622 		return -ENOMEM;
623 	retval = stream->ops->get_params(stream, params);
624 	if (retval)
625 		return retval;
626 	if (copy_to_user((char __user *)arg, params, sizeof(*params)))
627 		return -EFAULT;
628 	return retval;
629 }
630 
631 static int
632 snd_compr_get_metadata(struct snd_compr_stream *stream, unsigned long arg)
633 {
634 	struct snd_compr_metadata metadata;
635 	int retval;
636 
637 	if (!stream->ops->get_metadata)
638 		return -ENXIO;
639 
640 	if (copy_from_user(&metadata, (void __user *)arg, sizeof(metadata)))
641 		return -EFAULT;
642 
643 	retval = stream->ops->get_metadata(stream, &metadata);
644 	if (retval != 0)
645 		return retval;
646 
647 	if (copy_to_user((void __user *)arg, &metadata, sizeof(metadata)))
648 		return -EFAULT;
649 
650 	return 0;
651 }
652 
653 static int
654 snd_compr_set_metadata(struct snd_compr_stream *stream, unsigned long arg)
655 {
656 	struct snd_compr_metadata metadata;
657 	int retval;
658 
659 	if (!stream->ops->set_metadata)
660 		return -ENXIO;
661 	/*
662 	* we should allow parameter change only when stream has been
663 	* opened not in other cases
664 	*/
665 	if (copy_from_user(&metadata, (void __user *)arg, sizeof(metadata)))
666 		return -EFAULT;
667 
668 	retval = stream->ops->set_metadata(stream, &metadata);
669 	stream->metadata_set = true;
670 
671 	return retval;
672 }
673 
674 static inline int
675 snd_compr_tstamp(struct snd_compr_stream *stream, unsigned long arg)
676 {
677 	struct snd_compr_tstamp tstamp = {0};
678 	int ret;
679 
680 	ret = snd_compr_update_tstamp(stream, &tstamp);
681 	if (ret == 0)
682 		ret = copy_to_user((struct snd_compr_tstamp __user *)arg,
683 			&tstamp, sizeof(tstamp)) ? -EFAULT : 0;
684 	return ret;
685 }
686 
687 static int snd_compr_pause(struct snd_compr_stream *stream)
688 {
689 	int retval;
690 
691 	switch (stream->runtime->state) {
692 	case SNDRV_PCM_STATE_RUNNING:
693 		retval = stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_PAUSE_PUSH);
694 		if (!retval)
695 			stream->runtime->state = SNDRV_PCM_STATE_PAUSED;
696 		break;
697 	case SNDRV_PCM_STATE_DRAINING:
698 		if (!stream->device->use_pause_in_draining)
699 			return -EPERM;
700 		retval = stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_PAUSE_PUSH);
701 		if (!retval)
702 			stream->pause_in_draining = true;
703 		break;
704 	default:
705 		return -EPERM;
706 	}
707 	return retval;
708 }
709 
710 static int snd_compr_resume(struct snd_compr_stream *stream)
711 {
712 	int retval;
713 
714 	switch (stream->runtime->state) {
715 	case SNDRV_PCM_STATE_PAUSED:
716 		retval = stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_PAUSE_RELEASE);
717 		if (!retval)
718 			stream->runtime->state = SNDRV_PCM_STATE_RUNNING;
719 		break;
720 	case SNDRV_PCM_STATE_DRAINING:
721 		if (!stream->pause_in_draining)
722 			return -EPERM;
723 		retval = stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_PAUSE_RELEASE);
724 		if (!retval)
725 			stream->pause_in_draining = false;
726 		break;
727 	default:
728 		return -EPERM;
729 	}
730 	return retval;
731 }
732 
733 static int snd_compr_start(struct snd_compr_stream *stream)
734 {
735 	int retval;
736 
737 	switch (stream->runtime->state) {
738 	case SNDRV_PCM_STATE_SETUP:
739 		if (stream->direction != SND_COMPRESS_CAPTURE)
740 			return -EPERM;
741 		break;
742 	case SNDRV_PCM_STATE_PREPARED:
743 		break;
744 	default:
745 		return -EPERM;
746 	}
747 
748 	retval = stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_START);
749 	if (!retval)
750 		stream->runtime->state = SNDRV_PCM_STATE_RUNNING;
751 	return retval;
752 }
753 
754 static int snd_compr_stop(struct snd_compr_stream *stream)
755 {
756 	int retval;
757 
758 	switch (stream->runtime->state) {
759 	case SNDRV_PCM_STATE_OPEN:
760 	case SNDRV_PCM_STATE_SETUP:
761 	case SNDRV_PCM_STATE_PREPARED:
762 		return -EPERM;
763 	default:
764 		break;
765 	}
766 
767 	retval = stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_STOP);
768 	if (!retval) {
769 		/* clear flags and stop any drain wait */
770 		stream->partial_drain = false;
771 		stream->metadata_set = false;
772 		stream->pause_in_draining = false;
773 		snd_compr_drain_notify(stream);
774 		stream->runtime->total_bytes_available = 0;
775 		stream->runtime->total_bytes_transferred = 0;
776 	}
777 	return retval;
778 }
779 
780 static void error_delayed_work(struct work_struct *work)
781 {
782 	struct snd_compr_stream *stream;
783 
784 	stream = container_of(work, struct snd_compr_stream, error_work.work);
785 
786 	guard(mutex)(&stream->device->lock);
787 
788 	stream->ops->trigger(stream, SNDRV_PCM_TRIGGER_STOP);
789 	wake_up(&stream->runtime->sleep);
790 }
791 
792 /**
793  * snd_compr_stop_error: Report a fatal error on a stream
794  * @stream: pointer to stream
795  * @state: state to transition the stream to
796  *
797  * Stop the stream and set its state.
798  *
799  * Should be called with compressed device lock held.
800  *
801  * Return: zero if successful, or a negative error code
802  */
803 int snd_compr_stop_error(struct snd_compr_stream *stream,
804 			 snd_pcm_state_t state)
805 {
806 	if (stream->runtime->state == state)
807 		return 0;
808 
809 	stream->runtime->state = state;
810 
811 	pr_debug("Changing state to: %d\n", state);
812 
813 	queue_delayed_work(system_power_efficient_wq, &stream->error_work, 0);
814 
815 	return 0;
816 }
817 EXPORT_SYMBOL_GPL(snd_compr_stop_error);
818 
819 static int snd_compress_wait_for_drain(struct snd_compr_stream *stream)
820 {
821 	int ret;
822 
823 	/*
824 	 * We are called with lock held. So drop the lock while we wait for
825 	 * drain complete notification from the driver
826 	 *
827 	 * It is expected that driver will notify the drain completion and then
828 	 * stream will be moved to SETUP state, even if draining resulted in an
829 	 * error. We can trigger next track after this.
830 	 */
831 	stream->runtime->state = SNDRV_PCM_STATE_DRAINING;
832 	mutex_unlock(&stream->device->lock);
833 
834 	/* we wait for drain to complete here, drain can return when
835 	 * interruption occurred, wait returned error or success.
836 	 * For the first two cases we don't do anything different here and
837 	 * return after waking up
838 	 */
839 
840 	ret = wait_event_interruptible(stream->runtime->sleep,
841 			(stream->runtime->state != SNDRV_PCM_STATE_DRAINING));
842 	if (ret == -ERESTARTSYS)
843 		pr_debug("wait aborted by a signal\n");
844 	else if (ret)
845 		pr_debug("wait for drain failed with %d\n", ret);
846 
847 
848 	wake_up(&stream->runtime->sleep);
849 	mutex_lock(&stream->device->lock);
850 
851 	return ret;
852 }
853 
854 static int snd_compr_drain(struct snd_compr_stream *stream)
855 {
856 	int retval;
857 
858 	switch (stream->runtime->state) {
859 	case SNDRV_PCM_STATE_OPEN:
860 	case SNDRV_PCM_STATE_SETUP:
861 	case SNDRV_PCM_STATE_PREPARED:
862 	case SNDRV_PCM_STATE_PAUSED:
863 		return -EPERM;
864 	case SNDRV_PCM_STATE_XRUN:
865 		return -EPIPE;
866 	default:
867 		break;
868 	}
869 
870 	retval = stream->ops->trigger(stream, SND_COMPR_TRIGGER_DRAIN);
871 	if (retval) {
872 		pr_debug("SND_COMPR_TRIGGER_DRAIN failed %d\n", retval);
873 		wake_up(&stream->runtime->sleep);
874 		return retval;
875 	}
876 
877 	return snd_compress_wait_for_drain(stream);
878 }
879 
880 static int snd_compr_next_track(struct snd_compr_stream *stream)
881 {
882 	int retval;
883 
884 	/* only a running stream can transition to next track */
885 	if (stream->runtime->state != SNDRV_PCM_STATE_RUNNING)
886 		return -EPERM;
887 
888 	/* next track doesn't have any meaning for capture streams */
889 	if (stream->direction == SND_COMPRESS_CAPTURE)
890 		return -EPERM;
891 
892 	/* you can signal next track if this is intended to be a gapless stream
893 	 * and current track metadata is set
894 	 */
895 	if (stream->metadata_set == false)
896 		return -EPERM;
897 
898 	retval = stream->ops->trigger(stream, SND_COMPR_TRIGGER_NEXT_TRACK);
899 	if (retval != 0)
900 		return retval;
901 	stream->metadata_set = false;
902 	stream->next_track = true;
903 	return 0;
904 }
905 
906 static int snd_compr_partial_drain(struct snd_compr_stream *stream)
907 {
908 	int retval;
909 
910 	switch (stream->runtime->state) {
911 	case SNDRV_PCM_STATE_OPEN:
912 	case SNDRV_PCM_STATE_SETUP:
913 	case SNDRV_PCM_STATE_PREPARED:
914 	case SNDRV_PCM_STATE_PAUSED:
915 		return -EPERM;
916 	case SNDRV_PCM_STATE_XRUN:
917 		return -EPIPE;
918 	default:
919 		break;
920 	}
921 
922 	/* partial drain doesn't have any meaning for capture streams */
923 	if (stream->direction == SND_COMPRESS_CAPTURE)
924 		return -EPERM;
925 
926 	/* stream can be drained only when next track has been signalled */
927 	if (stream->next_track == false)
928 		return -EPERM;
929 
930 	stream->partial_drain = true;
931 	retval = stream->ops->trigger(stream, SND_COMPR_TRIGGER_PARTIAL_DRAIN);
932 	if (retval) {
933 		pr_debug("Partial drain returned failure\n");
934 		wake_up(&stream->runtime->sleep);
935 		return retval;
936 	}
937 
938 	stream->next_track = false;
939 	return snd_compress_wait_for_drain(stream);
940 }
941 
942 static long snd_compr_ioctl(struct file *f, unsigned int cmd, unsigned long arg)
943 {
944 	struct snd_compr_file *data = f->private_data;
945 	struct snd_compr_stream *stream;
946 
947 	if (snd_BUG_ON(!data))
948 		return -EFAULT;
949 
950 	stream = &data->stream;
951 
952 	guard(mutex)(&stream->device->lock);
953 	switch (_IOC_NR(cmd)) {
954 	case _IOC_NR(SNDRV_COMPRESS_IOCTL_VERSION):
955 		return put_user(SNDRV_COMPRESS_VERSION,
956 				(int __user *)arg) ? -EFAULT : 0;
957 	case _IOC_NR(SNDRV_COMPRESS_GET_CAPS):
958 		return snd_compr_get_caps(stream, arg);
959 #ifndef COMPR_CODEC_CAPS_OVERFLOW
960 	case _IOC_NR(SNDRV_COMPRESS_GET_CODEC_CAPS):
961 		return snd_compr_get_codec_caps(stream, arg);
962 #endif
963 	case _IOC_NR(SNDRV_COMPRESS_SET_PARAMS):
964 		return snd_compr_set_params(stream, arg);
965 	case _IOC_NR(SNDRV_COMPRESS_GET_PARAMS):
966 		return snd_compr_get_params(stream, arg);
967 	case _IOC_NR(SNDRV_COMPRESS_SET_METADATA):
968 		return snd_compr_set_metadata(stream, arg);
969 	case _IOC_NR(SNDRV_COMPRESS_GET_METADATA):
970 		return snd_compr_get_metadata(stream, arg);
971 	case _IOC_NR(SNDRV_COMPRESS_TSTAMP):
972 		return snd_compr_tstamp(stream, arg);
973 	case _IOC_NR(SNDRV_COMPRESS_AVAIL):
974 		return snd_compr_ioctl_avail(stream, arg);
975 	case _IOC_NR(SNDRV_COMPRESS_PAUSE):
976 		return snd_compr_pause(stream);
977 	case _IOC_NR(SNDRV_COMPRESS_RESUME):
978 		return snd_compr_resume(stream);
979 	case _IOC_NR(SNDRV_COMPRESS_START):
980 		return snd_compr_start(stream);
981 	case _IOC_NR(SNDRV_COMPRESS_STOP):
982 		return snd_compr_stop(stream);
983 	case _IOC_NR(SNDRV_COMPRESS_DRAIN):
984 		return snd_compr_drain(stream);
985 	case _IOC_NR(SNDRV_COMPRESS_PARTIAL_DRAIN):
986 		return snd_compr_partial_drain(stream);
987 	case _IOC_NR(SNDRV_COMPRESS_NEXT_TRACK):
988 		return snd_compr_next_track(stream);
989 	}
990 
991 	return -ENOTTY;
992 }
993 
994 /* support of 32bit userspace on 64bit platforms */
995 #ifdef CONFIG_COMPAT
996 static long snd_compr_ioctl_compat(struct file *file, unsigned int cmd,
997 						unsigned long arg)
998 {
999 	return snd_compr_ioctl(file, cmd, (unsigned long)compat_ptr(arg));
1000 }
1001 #endif
1002 
1003 static const struct file_operations snd_compr_file_ops = {
1004 		.owner =	THIS_MODULE,
1005 		.open =		snd_compr_open,
1006 		.release =	snd_compr_free,
1007 		.write =	snd_compr_write,
1008 		.read =		snd_compr_read,
1009 		.unlocked_ioctl = snd_compr_ioctl,
1010 #ifdef CONFIG_COMPAT
1011 		.compat_ioctl = snd_compr_ioctl_compat,
1012 #endif
1013 		.mmap =		snd_compr_mmap,
1014 		.poll =		snd_compr_poll,
1015 };
1016 
1017 static int snd_compress_dev_register(struct snd_device *device)
1018 {
1019 	int ret;
1020 	struct snd_compr *compr;
1021 
1022 	if (snd_BUG_ON(!device || !device->device_data))
1023 		return -EBADFD;
1024 	compr = device->device_data;
1025 
1026 	pr_debug("reg device %s, direction %d\n", compr->name,
1027 			compr->direction);
1028 	/* register compressed device */
1029 	ret = snd_register_device(SNDRV_DEVICE_TYPE_COMPRESS,
1030 				  compr->card, compr->device,
1031 				  &snd_compr_file_ops, compr, compr->dev);
1032 	if (ret < 0) {
1033 		pr_err("snd_register_device failed %d\n", ret);
1034 		return ret;
1035 	}
1036 	return ret;
1037 
1038 }
1039 
1040 static int snd_compress_dev_disconnect(struct snd_device *device)
1041 {
1042 	struct snd_compr *compr;
1043 
1044 	compr = device->device_data;
1045 	snd_unregister_device(compr->dev);
1046 	return 0;
1047 }
1048 
1049 #ifdef CONFIG_SND_VERBOSE_PROCFS
1050 static void snd_compress_proc_info_read(struct snd_info_entry *entry,
1051 					struct snd_info_buffer *buffer)
1052 {
1053 	struct snd_compr *compr = (struct snd_compr *)entry->private_data;
1054 
1055 	snd_iprintf(buffer, "card: %d\n", compr->card->number);
1056 	snd_iprintf(buffer, "device: %d\n", compr->device);
1057 	snd_iprintf(buffer, "stream: %s\n",
1058 			compr->direction == SND_COMPRESS_PLAYBACK
1059 				? "PLAYBACK" : "CAPTURE");
1060 	snd_iprintf(buffer, "id: %s\n", compr->id);
1061 }
1062 
1063 static int snd_compress_proc_init(struct snd_compr *compr)
1064 {
1065 	struct snd_info_entry *entry;
1066 	char name[16];
1067 
1068 	sprintf(name, "compr%i", compr->device);
1069 	entry = snd_info_create_card_entry(compr->card, name,
1070 					   compr->card->proc_root);
1071 	if (!entry)
1072 		return -ENOMEM;
1073 	entry->mode = S_IFDIR | 0555;
1074 	compr->proc_root = entry;
1075 
1076 	entry = snd_info_create_card_entry(compr->card, "info",
1077 					   compr->proc_root);
1078 	if (entry)
1079 		snd_info_set_text_ops(entry, compr,
1080 				      snd_compress_proc_info_read);
1081 	compr->proc_info_entry = entry;
1082 
1083 	return 0;
1084 }
1085 
1086 static void snd_compress_proc_done(struct snd_compr *compr)
1087 {
1088 	snd_info_free_entry(compr->proc_info_entry);
1089 	compr->proc_info_entry = NULL;
1090 	snd_info_free_entry(compr->proc_root);
1091 	compr->proc_root = NULL;
1092 }
1093 
1094 static inline void snd_compress_set_id(struct snd_compr *compr, const char *id)
1095 {
1096 	strscpy(compr->id, id, sizeof(compr->id));
1097 }
1098 #else
1099 static inline int snd_compress_proc_init(struct snd_compr *compr)
1100 {
1101 	return 0;
1102 }
1103 
1104 static inline void snd_compress_proc_done(struct snd_compr *compr)
1105 {
1106 }
1107 
1108 static inline void snd_compress_set_id(struct snd_compr *compr, const char *id)
1109 {
1110 }
1111 #endif
1112 
1113 static int snd_compress_dev_free(struct snd_device *device)
1114 {
1115 	struct snd_compr *compr;
1116 
1117 	compr = device->device_data;
1118 	snd_compress_proc_done(compr);
1119 	put_device(compr->dev);
1120 	return 0;
1121 }
1122 
1123 /**
1124  * snd_compress_new: create new compress device
1125  * @card: sound card pointer
1126  * @device: device number
1127  * @dirn: device direction, should be of type enum snd_compr_direction
1128  * @id: ID string
1129  * @compr: compress device pointer
1130  *
1131  * Return: zero if successful, or a negative error code
1132  */
1133 int snd_compress_new(struct snd_card *card, int device,
1134 			int dirn, const char *id, struct snd_compr *compr)
1135 {
1136 	static const struct snd_device_ops ops = {
1137 		.dev_free = snd_compress_dev_free,
1138 		.dev_register = snd_compress_dev_register,
1139 		.dev_disconnect = snd_compress_dev_disconnect,
1140 	};
1141 	int ret;
1142 
1143 	compr->card = card;
1144 	compr->device = device;
1145 	compr->direction = dirn;
1146 	mutex_init(&compr->lock);
1147 
1148 	snd_compress_set_id(compr, id);
1149 
1150 	ret = snd_device_alloc(&compr->dev, card);
1151 	if (ret)
1152 		return ret;
1153 	dev_set_name(compr->dev, "comprC%iD%i", card->number, device);
1154 
1155 	ret = snd_device_new(card, SNDRV_DEV_COMPRESS, compr, &ops);
1156 	if (ret == 0)
1157 		snd_compress_proc_init(compr);
1158 	else
1159 		put_device(compr->dev);
1160 
1161 	return ret;
1162 }
1163 EXPORT_SYMBOL_GPL(snd_compress_new);
1164 
1165 MODULE_DESCRIPTION("ALSA Compressed offload framework");
1166 MODULE_AUTHOR("Vinod Koul <vinod.koul@linux.intel.com>");
1167 MODULE_LICENSE("GPL v2");
1168