aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/dma/ste_dma40_ll.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/dma/ste_dma40_ll.c')
-rw-r--r--drivers/dma/ste_dma40_ll.c63
1 files changed, 12 insertions, 51 deletions
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
372int 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
419struct d40_log_lli *d40_log_buf_to_lli(struct d40_log_lli *lli_sg, 372struct 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
448int d40_log_sg_to_lli(struct scatterlist *sg, 401int 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}