dmaengine: idma64: set maximum allowed segment size for DMA
This tells, for example, IOMMU what the maximum size of a segment the DMA controller can send. Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Signed-off-by: Vinod Koul <vinod.koul@intel.com>
This commit is contained in:
parent
37580559f3
commit
e3fdb1894c
@ -588,6 +588,8 @@ static int idma64_probe(struct idma64_chip *chip)
|
|||||||
|
|
||||||
idma64->dma.dev = chip->dev;
|
idma64->dma.dev = chip->dev;
|
||||||
|
|
||||||
|
dma_set_max_seg_size(idma64->dma.dev, IDMA64C_CTLH_BLOCK_TS_MASK);
|
||||||
|
|
||||||
ret = dma_async_device_register(&idma64->dma);
|
ret = dma_async_device_register(&idma64->dma);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -54,7 +54,8 @@
|
|||||||
#define IDMA64C_CTLL_LLP_S_EN (1 << 28) /* src block chain */
|
#define IDMA64C_CTLL_LLP_S_EN (1 << 28) /* src block chain */
|
||||||
|
|
||||||
/* Bitfields in CTL_HI */
|
/* Bitfields in CTL_HI */
|
||||||
#define IDMA64C_CTLH_BLOCK_TS(x) ((x) & ((1 << 17) - 1))
|
#define IDMA64C_CTLH_BLOCK_TS_MASK ((1 << 17) - 1)
|
||||||
|
#define IDMA64C_CTLH_BLOCK_TS(x) ((x) & IDMA64C_CTLH_BLOCK_TS_MASK)
|
||||||
#define IDMA64C_CTLH_DONE (1 << 17)
|
#define IDMA64C_CTLH_DONE (1 << 17)
|
||||||
|
|
||||||
/* Bitfields in CFG_LO */
|
/* Bitfields in CFG_LO */
|
||||||
|
Loading…
Reference in New Issue
Block a user