• Home
  • Raw
  • Download

Lines Matching refs:desc

74 	struct ccp_dma_desc *desc, *dtmp;  in ccp_free_desc_resources()  local
76 list_for_each_entry_safe(desc, dtmp, list, entry) { in ccp_free_desc_resources()
77 ccp_free_cmd_resources(ccp, &desc->active); in ccp_free_desc_resources()
78 ccp_free_cmd_resources(ccp, &desc->pending); in ccp_free_desc_resources()
80 list_del(&desc->entry); in ccp_free_desc_resources()
81 kmem_cache_free(ccp->dma_desc_cache, desc); in ccp_free_desc_resources()
106 struct ccp_dma_desc *desc, *dtmp; in ccp_cleanup_desc_resources() local
108 list_for_each_entry_safe_reverse(desc, dtmp, list, entry) { in ccp_cleanup_desc_resources()
109 if (!async_tx_test_ack(&desc->tx_desc)) in ccp_cleanup_desc_resources()
112 dev_dbg(ccp->dev, "%s - desc=%p\n", __func__, desc); in ccp_cleanup_desc_resources()
114 ccp_free_cmd_resources(ccp, &desc->active); in ccp_cleanup_desc_resources()
115 ccp_free_cmd_resources(ccp, &desc->pending); in ccp_cleanup_desc_resources()
117 list_del(&desc->entry); in ccp_cleanup_desc_resources()
118 kmem_cache_free(ccp->dma_desc_cache, desc); in ccp_cleanup_desc_resources()
137 static int ccp_issue_next_cmd(struct ccp_dma_desc *desc) in ccp_issue_next_cmd() argument
142 cmd = list_first_entry(&desc->pending, struct ccp_dma_cmd, entry); in ccp_issue_next_cmd()
143 list_move(&cmd->entry, &desc->active); in ccp_issue_next_cmd()
145 dev_dbg(desc->ccp->dev, "%s - tx %d, cmd=%p\n", __func__, in ccp_issue_next_cmd()
146 desc->tx_desc.cookie, cmd); in ccp_issue_next_cmd()
152 dev_dbg(desc->ccp->dev, "%s - error: ret=%d, tx %d, cmd=%p\n", __func__, in ccp_issue_next_cmd()
153 ret, desc->tx_desc.cookie, cmd); in ccp_issue_next_cmd()
158 static void ccp_free_active_cmd(struct ccp_dma_desc *desc) in ccp_free_active_cmd() argument
162 cmd = list_first_entry_or_null(&desc->active, struct ccp_dma_cmd, in ccp_free_active_cmd()
167 dev_dbg(desc->ccp->dev, "%s - freeing tx %d cmd=%p\n", in ccp_free_active_cmd()
168 __func__, desc->tx_desc.cookie, cmd); in ccp_free_active_cmd()
171 kmem_cache_free(desc->ccp->dma_cmd_cache, cmd); in ccp_free_active_cmd()
175 struct ccp_dma_desc *desc) in __ccp_next_dma_desc() argument
178 if (desc) in __ccp_next_dma_desc()
179 list_move(&desc->entry, &chan->complete); in __ccp_next_dma_desc()
182 desc = list_first_entry_or_null(&chan->active, struct ccp_dma_desc, in __ccp_next_dma_desc()
185 return desc; in __ccp_next_dma_desc()
189 struct ccp_dma_desc *desc) in ccp_handle_active_desc() argument
196 if (desc) { in ccp_handle_active_desc()
198 ccp_free_active_cmd(desc); in ccp_handle_active_desc()
200 if (!list_empty(&desc->pending)) { in ccp_handle_active_desc()
202 if (desc->status != DMA_ERROR) in ccp_handle_active_desc()
203 return desc; in ccp_handle_active_desc()
206 ccp_free_cmd_resources(desc->ccp, in ccp_handle_active_desc()
207 &desc->pending); in ccp_handle_active_desc()
210 tx_desc = &desc->tx_desc; in ccp_handle_active_desc()
217 if (desc) { in ccp_handle_active_desc()
218 if (desc->status != DMA_ERROR) in ccp_handle_active_desc()
219 desc->status = DMA_COMPLETE; in ccp_handle_active_desc()
221 dev_dbg(desc->ccp->dev, in ccp_handle_active_desc()
223 desc->tx_desc.cookie, desc->status); in ccp_handle_active_desc()
228 desc = __ccp_next_dma_desc(chan, desc); in ccp_handle_active_desc()
239 } while (desc); in ccp_handle_active_desc()
246 struct ccp_dma_desc *desc; in __ccp_pending_to_active() local
251 desc = list_empty(&chan->active) in __ccp_pending_to_active()
257 return desc; in __ccp_pending_to_active()
262 struct ccp_dma_desc *desc = data; in ccp_cmd_callback() local
269 chan = container_of(desc->tx_desc.chan, struct ccp_dma_chan, in ccp_cmd_callback()
273 __func__, desc->tx_desc.cookie, err); in ccp_cmd_callback()
276 desc->status = DMA_ERROR; in ccp_cmd_callback()
280 desc = ccp_handle_active_desc(chan, desc); in ccp_cmd_callback()
283 if (!desc || (chan->status == DMA_PAUSED)) in ccp_cmd_callback()
286 ret = ccp_issue_next_cmd(desc); in ccp_cmd_callback()
290 desc->status = DMA_ERROR; in ccp_cmd_callback()
298 struct ccp_dma_desc *desc = container_of(tx_desc, struct ccp_dma_desc, in ccp_tx_submit() local
309 list_del(&desc->entry); in ccp_tx_submit()
310 list_add_tail(&desc->entry, &chan->pending); in ccp_tx_submit()
334 struct ccp_dma_desc *desc; in ccp_alloc_dma_desc() local
336 desc = kmem_cache_zalloc(chan->ccp->dma_desc_cache, GFP_NOWAIT); in ccp_alloc_dma_desc()
337 if (!desc) in ccp_alloc_dma_desc()
340 dma_async_tx_descriptor_init(&desc->tx_desc, &chan->dma_chan); in ccp_alloc_dma_desc()
341 desc->tx_desc.flags = flags; in ccp_alloc_dma_desc()
342 desc->tx_desc.tx_submit = ccp_tx_submit; in ccp_alloc_dma_desc()
343 desc->ccp = chan->ccp; in ccp_alloc_dma_desc()
344 INIT_LIST_HEAD(&desc->entry); in ccp_alloc_dma_desc()
345 INIT_LIST_HEAD(&desc->pending); in ccp_alloc_dma_desc()
346 INIT_LIST_HEAD(&desc->active); in ccp_alloc_dma_desc()
347 desc->status = DMA_IN_PROGRESS; in ccp_alloc_dma_desc()
349 return desc; in ccp_alloc_dma_desc()
362 struct ccp_dma_desc *desc; in ccp_create_desc() local
378 desc = ccp_alloc_dma_desc(chan, flags); in ccp_create_desc()
379 if (!desc) in ccp_create_desc()
438 ccp_cmd->data = desc; in ccp_create_desc()
440 list_add_tail(&cmd->entry, &desc->pending); in ccp_create_desc()
456 desc->len = total_len; in ccp_create_desc()
458 if (list_empty(&desc->pending)) in ccp_create_desc()
461 dev_dbg(ccp->dev, "%s - desc=%p\n", __func__, desc); in ccp_create_desc()
465 list_add_tail(&desc->entry, &chan->created); in ccp_create_desc()
469 return desc; in ccp_create_desc()
472 ccp_free_cmd_resources(ccp, &desc->pending); in ccp_create_desc()
473 kmem_cache_free(ccp->dma_desc_cache, desc); in ccp_create_desc()
484 struct ccp_dma_desc *desc; in ccp_prep_dma_memcpy() local
499 desc = ccp_create_desc(dma_chan, &dst_sg, 1, &src_sg, 1, flags); in ccp_prep_dma_memcpy()
500 if (!desc) in ccp_prep_dma_memcpy()
503 return &desc->tx_desc; in ccp_prep_dma_memcpy()
511 struct ccp_dma_desc *desc; in ccp_prep_dma_interrupt() local
513 desc = ccp_alloc_dma_desc(chan, flags); in ccp_prep_dma_interrupt()
514 if (!desc) in ccp_prep_dma_interrupt()
517 return &desc->tx_desc; in ccp_prep_dma_interrupt()
524 struct ccp_dma_desc *desc; in ccp_issue_pending() local
531 desc = __ccp_pending_to_active(chan); in ccp_issue_pending()
536 if (desc) in ccp_issue_pending()
537 ccp_cmd_callback(desc, 0); in ccp_issue_pending()
546 struct ccp_dma_desc *desc; in ccp_tx_status() local
560 list_for_each_entry(desc, &chan->complete, entry) { in ccp_tx_status()
561 if (desc->tx_desc.cookie != cookie) in ccp_tx_status()
564 ret = desc->status; in ccp_tx_status()
593 struct ccp_dma_desc *desc; in ccp_resume() local
598 desc = list_first_entry_or_null(&chan->active, struct ccp_dma_desc, in ccp_resume()
607 if (desc) in ccp_resume()
608 ccp_cmd_callback(desc, 0); in ccp_resume()