Lines Matching full:sub
29 struct uniphier_aio_sub *sub = &aio->sub[compr->direction]; in uniphier_aio_comprdma_new() local
37 sub->compr_area = kzalloc(size, GFP_KERNEL); in uniphier_aio_comprdma_new()
38 if (!sub->compr_area) in uniphier_aio_comprdma_new()
41 if (sub->swm->dir == PORT_DIR_OUTPUT) in uniphier_aio_comprdma_new()
44 sub->compr_addr = dma_map_single(dev, sub->compr_area, size, dma_dir); in uniphier_aio_comprdma_new()
45 if (dma_mapping_error(dev, sub->compr_addr)) { in uniphier_aio_comprdma_new()
46 kfree(sub->compr_area); in uniphier_aio_comprdma_new()
47 sub->compr_area = NULL; in uniphier_aio_comprdma_new()
52 sub->compr_bytes = size; in uniphier_aio_comprdma_new()
62 struct uniphier_aio_sub *sub = &aio->sub[compr->direction]; in uniphier_aio_comprdma_free() local
65 if (sub->swm->dir == PORT_DIR_OUTPUT) in uniphier_aio_comprdma_free()
68 dma_unmap_single(dev, sub->compr_addr, sub->compr_bytes, dma_dir); in uniphier_aio_comprdma_free()
69 kfree(sub->compr_area); in uniphier_aio_comprdma_free()
70 sub->compr_area = NULL; in uniphier_aio_comprdma_free()
80 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_open() local
83 if (sub->cstream) in uniphier_aio_compr_open()
86 sub->cstream = cstream; in uniphier_aio_compr_open()
87 sub->pass_through = 1; in uniphier_aio_compr_open()
88 sub->use_mmap = false; in uniphier_aio_compr_open()
94 ret = aio_init(sub); in uniphier_aio_compr_open()
106 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_free() local
116 sub->cstream = NULL; in uniphier_aio_compr_free()
127 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_get_params() local
129 *params = sub->cparams.codec; in uniphier_aio_compr_get_params()
140 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_set_params() local
156 sub->iec_pc = IEC61937_PC_AAC; in uniphier_aio_compr_set_params()
158 sub->cparams = *params; in uniphier_aio_compr_set_params()
159 sub->setting = 1; in uniphier_aio_compr_set_params()
161 aio_port_reset(sub); in uniphier_aio_compr_set_params()
162 aio_src_reset(sub); in uniphier_aio_compr_set_params()
176 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_hw_free() local
178 sub->setting = 0; in uniphier_aio_compr_hw_free()
189 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_prepare() local
194 ret = aiodma_ch_set_param(sub); in uniphier_aio_compr_prepare()
198 spin_lock_irqsave(&sub->lock, flags); in uniphier_aio_compr_prepare()
199 ret = aiodma_rb_set_buffer(sub, sub->compr_addr, in uniphier_aio_compr_prepare()
200 sub->compr_addr + sub->compr_bytes, in uniphier_aio_compr_prepare()
202 spin_unlock_irqrestore(&sub->lock, flags); in uniphier_aio_compr_prepare()
206 ret = aio_port_set_param(sub, sub->pass_through, &sub->params); in uniphier_aio_compr_prepare()
209 ret = aio_oport_set_stream_type(sub, sub->iec_pc); in uniphier_aio_compr_prepare()
212 aio_port_set_enable(sub, 1); in uniphier_aio_compr_prepare()
214 ret = aio_if_set_param(sub, sub->pass_through); in uniphier_aio_compr_prepare()
228 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_trigger() local
233 spin_lock_irqsave(&sub->lock, flags); in uniphier_aio_compr_trigger()
236 aiodma_rb_sync(sub, sub->compr_addr, sub->compr_bytes, bytes); in uniphier_aio_compr_trigger()
237 aiodma_ch_set_enable(sub, 1); in uniphier_aio_compr_trigger()
238 sub->running = 1; in uniphier_aio_compr_trigger()
242 sub->running = 0; in uniphier_aio_compr_trigger()
243 aiodma_ch_set_enable(sub, 0); in uniphier_aio_compr_trigger()
250 spin_unlock_irqrestore(&sub->lock, flags); in uniphier_aio_compr_trigger()
262 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_pointer() local
267 spin_lock_irqsave(&sub->lock, flags); in uniphier_aio_compr_pointer()
269 aiodma_rb_sync(sub, sub->compr_addr, sub->compr_bytes, bytes); in uniphier_aio_compr_pointer()
271 if (sub->swm->dir == PORT_DIR_OUTPUT) { in uniphier_aio_compr_pointer()
272 pos = sub->rd_offs; in uniphier_aio_compr_pointer()
274 tstamp->copied_total = sub->rd_total / 2; in uniphier_aio_compr_pointer()
276 pos = sub->wr_offs; in uniphier_aio_compr_pointer()
277 tstamp->copied_total = sub->rd_total; in uniphier_aio_compr_pointer()
281 spin_unlock_irqrestore(&sub->lock, flags); in uniphier_aio_compr_pointer()
286 static int aio_compr_send_to_hw(struct uniphier_aio_sub *sub, in aio_compr_send_to_hw() argument
290 u32 *dstbuf = (u32 *)(sub->compr_area + sub->wr_offs); in aio_compr_send_to_hw()
307 sub->iec_header = true; in aio_compr_send_to_hw()
311 if (sub->iec_header && sub->iec_pc != pc) { in aio_compr_send_to_hw()
313 sub->iec_pc = pc; in aio_compr_send_to_hw()
314 ret = aio_oport_set_stream_type(sub, pc); in aio_compr_send_to_hw()
318 sub->iec_header = false; in aio_compr_send_to_hw()
337 struct uniphier_aio_sub *sub = &aio->sub[cstream->direction]; in uniphier_aio_compr_copy() local
338 size_t cnt = min_t(size_t, count, aio_rb_space_to_end(sub) / 2); in uniphier_aio_compr_copy()
347 if (sub->swm->dir == PORT_DIR_OUTPUT) { in uniphier_aio_compr_copy()
348 dma_addr_t dmapos = sub->compr_addr + sub->wr_offs; in uniphier_aio_compr_copy()
354 ret = aio_compr_send_to_hw(sub, buf, s); in uniphier_aio_compr_copy()
357 dma_addr_t dmapos = sub->compr_addr + sub->rd_offs; in uniphier_aio_compr_copy()
362 ret = copy_to_user(buf, sub->compr_area + sub->rd_offs, s); in uniphier_aio_compr_copy()
368 spin_lock_irqsave(&sub->lock, flags); in uniphier_aio_compr_copy()
370 sub->threshold = 2 * bytes; in uniphier_aio_compr_copy()
371 aiodma_rb_set_threshold(sub, sub->compr_bytes, 2 * bytes); in uniphier_aio_compr_copy()
373 if (sub->swm->dir == PORT_DIR_OUTPUT) { in uniphier_aio_compr_copy()
374 sub->wr_offs += s; in uniphier_aio_compr_copy()
375 if (sub->wr_offs >= sub->compr_bytes) in uniphier_aio_compr_copy()
376 sub->wr_offs -= sub->compr_bytes; in uniphier_aio_compr_copy()
378 sub->rd_offs += s; in uniphier_aio_compr_copy()
379 if (sub->rd_offs >= sub->compr_bytes) in uniphier_aio_compr_copy()
380 sub->rd_offs -= sub->compr_bytes; in uniphier_aio_compr_copy()
382 aiodma_rb_sync(sub, sub->compr_addr, sub->compr_bytes, bytes); in uniphier_aio_compr_copy()
384 spin_unlock_irqrestore(&sub->lock, flags); in uniphier_aio_compr_copy()