diff options
-rw-r--r-- | drivers/dma/ste_dma40.c | 41 | ||||
-rw-r--r-- | drivers/dma/ste_dma40_ll.c | 63 | ||||
-rw-r--r-- | drivers/dma/ste_dma40_ll.h | 10 |
3 files changed, 29 insertions, 85 deletions
diff --git a/drivers/dma/ste_dma40.c b/drivers/dma/ste_dma40.c index 6a7a00d5d682..c597dba713b0 100644 --- a/drivers/dma/ste_dma40.c +++ b/drivers/dma/ste_dma40.c | |||
@@ -1638,37 +1638,28 @@ d40_prep_sg_log(struct d40_chan *chan, struct d40_desc *desc, | |||
1638 | unsigned int sg_len, enum dma_data_direction direction, | 1638 | unsigned int sg_len, enum dma_data_direction direction, |
1639 | dma_addr_t dev_addr) | 1639 | dma_addr_t dev_addr) |
1640 | { | 1640 | { |
1641 | dma_addr_t src_dev_addr = direction == DMA_FROM_DEVICE ? dev_addr : 0; | ||
1642 | dma_addr_t dst_dev_addr = direction == DMA_TO_DEVICE ? dev_addr : 0; | ||
1641 | struct stedma40_chan_cfg *cfg = &chan->dma_cfg; | 1643 | struct stedma40_chan_cfg *cfg = &chan->dma_cfg; |
1642 | struct stedma40_half_channel_info *src_info = &cfg->src_info; | 1644 | struct stedma40_half_channel_info *src_info = &cfg->src_info; |
1643 | struct stedma40_half_channel_info *dst_info = &cfg->dst_info; | 1645 | struct stedma40_half_channel_info *dst_info = &cfg->dst_info; |
1646 | int ret; | ||
1644 | 1647 | ||
1645 | if (direction == DMA_NONE) { | 1648 | ret = d40_log_sg_to_lli(sg_src, sg_len, |
1646 | /* memcpy */ | 1649 | src_dev_addr, |
1647 | (void) d40_log_sg_to_lli(sg_src, sg_len, | 1650 | desc->lli_log.src, |
1648 | desc->lli_log.src, | 1651 | chan->log_def.lcsp1, |
1649 | chan->log_def.lcsp1, | 1652 | src_info->data_width, |
1650 | src_info->data_width, | 1653 | dst_info->data_width); |
1651 | dst_info->data_width); | ||
1652 | |||
1653 | (void) d40_log_sg_to_lli(sg_dst, sg_len, | ||
1654 | desc->lli_log.dst, | ||
1655 | chan->log_def.lcsp3, | ||
1656 | dst_info->data_width, | ||
1657 | src_info->data_width); | ||
1658 | } else { | ||
1659 | unsigned int total_size; | ||
1660 | 1654 | ||
1661 | total_size = d40_log_sg_to_dev(sg_src, sg_len, | 1655 | ret = d40_log_sg_to_lli(sg_dst, sg_len, |
1662 | &desc->lli_log, | 1656 | dst_dev_addr, |
1663 | &chan->log_def, | 1657 | desc->lli_log.dst, |
1664 | src_info->data_width, | 1658 | chan->log_def.lcsp3, |
1665 | dst_info->data_width, | 1659 | dst_info->data_width, |
1666 | direction, dev_addr); | 1660 | src_info->data_width); |
1667 | if (total_size < 0) | ||
1668 | return -EINVAL; | ||
1669 | } | ||
1670 | 1661 | ||
1671 | return 0; | 1662 | return ret < 0 ? ret : 0; |
1672 | } | 1663 | } |
1673 | 1664 | ||
1674 | static int | 1665 | static int |
diff --git a/drivers/dma/ste_dma40_ll.c b/drivers/dma/ste_dma40_ll.c index fa6c3ab93fae..9935c6dbcfe0 100644 --- a/drivers/dma/ste_dma40_ll.c +++ b/drivers/dma/ste_dma40_ll.c | |||
@@ -369,53 +369,6 @@ static void d40_log_fill_lli(struct d40_log_lli *lli, | |||
369 | 369 | ||
370 | } | 370 | } |
371 | 371 | ||
372 | int d40_log_sg_to_dev(struct scatterlist *sg, | ||
373 | int sg_len, | ||
374 | struct d40_log_lli_bidir *lli, | ||
375 | struct d40_def_lcsp *lcsp, | ||
376 | u32 src_data_width, | ||
377 | u32 dst_data_width, | ||
378 | enum dma_data_direction direction, | ||
379 | dma_addr_t dev_addr) | ||
380 | { | ||
381 | int total_size = 0; | ||
382 | struct scatterlist *current_sg = sg; | ||
383 | int i; | ||
384 | struct d40_log_lli *lli_src = lli->src; | ||
385 | struct d40_log_lli *lli_dst = lli->dst; | ||
386 | |||
387 | for_each_sg(sg, current_sg, sg_len, i) { | ||
388 | dma_addr_t sg_addr = sg_dma_address(current_sg); | ||
389 | unsigned int len = sg_dma_len(current_sg); | ||
390 | dma_addr_t src; | ||
391 | dma_addr_t dst; | ||
392 | |||
393 | total_size += len; | ||
394 | |||
395 | if (direction == DMA_TO_DEVICE) { | ||
396 | src = sg_addr; | ||
397 | dst = dev_addr; | ||
398 | } else { | ||
399 | src = dev_addr; | ||
400 | dst = sg_addr; | ||
401 | } | ||
402 | |||
403 | lli_src = d40_log_buf_to_lli(lli_src, src, len, | ||
404 | lcsp->lcsp1, | ||
405 | src_data_width, | ||
406 | dst_data_width, | ||
407 | src == sg_addr); | ||
408 | |||
409 | lli_dst = d40_log_buf_to_lli(lli_dst, dst, len, | ||
410 | lcsp->lcsp3, | ||
411 | dst_data_width, | ||
412 | src_data_width, | ||
413 | dst == sg_addr); | ||
414 | } | ||
415 | |||
416 | return total_size; | ||
417 | } | ||
418 | |||
419 | struct d40_log_lli *d40_log_buf_to_lli(struct d40_log_lli *lli_sg, | 372 | struct d40_log_lli *d40_log_buf_to_lli(struct d40_log_lli *lli_sg, |
420 | dma_addr_t addr, | 373 | dma_addr_t addr, |
421 | int size, | 374 | int size, |
@@ -447,6 +400,7 @@ struct d40_log_lli *d40_log_buf_to_lli(struct d40_log_lli *lli_sg, | |||
447 | 400 | ||
448 | int d40_log_sg_to_lli(struct scatterlist *sg, | 401 | int d40_log_sg_to_lli(struct scatterlist *sg, |
449 | int sg_len, | 402 | int sg_len, |
403 | dma_addr_t dev_addr, | ||
450 | struct d40_log_lli *lli_sg, | 404 | struct d40_log_lli *lli_sg, |
451 | u32 lcsp13, /* src or dst*/ | 405 | u32 lcsp13, /* src or dst*/ |
452 | u32 data_width1, u32 data_width2) | 406 | u32 data_width1, u32 data_width2) |
@@ -455,14 +409,21 @@ int d40_log_sg_to_lli(struct scatterlist *sg, | |||
455 | struct scatterlist *current_sg = sg; | 409 | struct scatterlist *current_sg = sg; |
456 | int i; | 410 | int i; |
457 | struct d40_log_lli *lli = lli_sg; | 411 | struct d40_log_lli *lli = lli_sg; |
412 | bool autoinc = !dev_addr; | ||
458 | 413 | ||
459 | for_each_sg(sg, current_sg, sg_len, i) { | 414 | for_each_sg(sg, current_sg, sg_len, i) { |
415 | dma_addr_t sg_addr = sg_dma_address(current_sg); | ||
416 | unsigned int len = sg_dma_len(current_sg); | ||
417 | dma_addr_t addr = dev_addr ?: sg_addr; | ||
418 | |||
460 | total_size += sg_dma_len(current_sg); | 419 | total_size += sg_dma_len(current_sg); |
461 | lli = d40_log_buf_to_lli(lli, | 420 | |
462 | sg_dma_address(current_sg), | 421 | lli = d40_log_buf_to_lli(lli, addr, len, |
463 | sg_dma_len(current_sg), | ||
464 | lcsp13, | 422 | lcsp13, |
465 | data_width1, data_width2, true); | 423 | data_width1, |
424 | data_width2, | ||
425 | autoinc); | ||
466 | } | 426 | } |
427 | |||
467 | return total_size; | 428 | return total_size; |
468 | } | 429 | } |
diff --git a/drivers/dma/ste_dma40_ll.h b/drivers/dma/ste_dma40_ll.h index 46578a661b28..867f23f6e098 100644 --- a/drivers/dma/ste_dma40_ll.h +++ b/drivers/dma/ste_dma40_ll.h | |||
@@ -321,17 +321,9 @@ struct d40_log_lli *d40_log_buf_to_lli(struct d40_log_lli *lli_sg, | |||
321 | u32 data_width1, u32 data_width2, | 321 | u32 data_width1, u32 data_width2, |
322 | bool addr_inc); | 322 | bool addr_inc); |
323 | 323 | ||
324 | int d40_log_sg_to_dev(struct scatterlist *sg, | ||
325 | int sg_len, | ||
326 | struct d40_log_lli_bidir *lli, | ||
327 | struct d40_def_lcsp *lcsp, | ||
328 | u32 src_data_width, | ||
329 | u32 dst_data_width, | ||
330 | enum dma_data_direction direction, | ||
331 | dma_addr_t dev_addr); | ||
332 | |||
333 | int d40_log_sg_to_lli(struct scatterlist *sg, | 324 | int d40_log_sg_to_lli(struct scatterlist *sg, |
334 | int sg_len, | 325 | int sg_len, |
326 | dma_addr_t dev_addr, | ||
335 | struct d40_log_lli *lli_sg, | 327 | struct d40_log_lli *lli_sg, |
336 | u32 lcsp13, /* src or dst*/ | 328 | u32 lcsp13, /* src or dst*/ |
337 | u32 data_width1, u32 data_width2); | 329 | u32 data_width1, u32 data_width2); |