Lines Matching defs:hsu
26 #include "hsu.h"
151 if (nr >= chip->hsu->nr_channels)
154 hsuc = &chip->hsu->chan[nr];
209 if (nr >= chip->hsu->nr_channels)
212 hsuc = &chip->hsu->chan[nr];
418 struct hsu_dma *hsu;
423 hsu = devm_kzalloc(chip->dev, sizeof(*hsu), GFP_KERNEL);
424 if (!hsu)
427 chip->hsu = hsu;
430 hsu->nr_channels = (chip->length - chip->offset) / HSU_DMA_CHAN_LENGTH;
432 hsu->chan = devm_kcalloc(chip->dev, hsu->nr_channels,
433 sizeof(*hsu->chan), GFP_KERNEL);
434 if (!hsu->chan)
437 INIT_LIST_HEAD(&hsu->dma.channels);
438 for (i = 0; i < hsu->nr_channels; i++) {
439 struct hsu_dma_chan *hsuc = &hsu->chan[i];
442 vchan_init(&hsuc->vchan, &hsu->dma);
448 dma_cap_set(DMA_SLAVE, hsu->dma.cap_mask);
449 dma_cap_set(DMA_PRIVATE, hsu->dma.cap_mask);
451 hsu->dma.device_free_chan_resources = hsu_dma_free_chan_resources;
453 hsu->dma.device_prep_slave_sg = hsu_dma_prep_slave_sg;
455 hsu->dma.device_issue_pending = hsu_dma_issue_pending;
456 hsu->dma.device_tx_status = hsu_dma_tx_status;
458 hsu->dma.device_config = hsu_dma_slave_config;
459 hsu->dma.device_pause = hsu_dma_pause;
460 hsu->dma.device_resume = hsu_dma_resume;
461 hsu->dma.device_terminate_all = hsu_dma_terminate_all;
462 hsu->dma.device_synchronize = hsu_dma_synchronize;
464 hsu->dma.src_addr_widths = HSU_DMA_BUSWIDTHS;
465 hsu->dma.dst_addr_widths = HSU_DMA_BUSWIDTHS;
466 hsu->dma.directions = BIT(DMA_DEV_TO_MEM) | BIT(DMA_MEM_TO_DEV);
467 hsu->dma.residue_granularity = DMA_RESIDUE_GRANULARITY_BURST;
469 hsu->dma.dev = chip->dev;
471 dma_set_max_seg_size(hsu->dma.dev, HSU_CH_DxTSR_MASK);
473 ret = dma_async_device_register(&hsu->dma);
477 dev_info(chip->dev, "Found HSU DMA, %d channels\n", hsu->nr_channels);
484 struct hsu_dma *hsu = chip->hsu;
487 dma_async_device_unregister(&hsu->dma);
489 for (i = 0; i < hsu->nr_channels; i++) {
490 struct hsu_dma_chan *hsuc = &hsu->chan[i];