mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
50fdb52a7c
Extend the k3dma driver binding to support hisi-asp hardware variants. Cc: Vinod Koul <vkoul@kernel.org> Cc: Rob Herring <robh+dt@kernel.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Zhuangluan Su <suzhuangluan@hisilicon.com> Cc: Tanglei Han <hantanglei@huawei.com> Cc: Ryan Grachek <ryan@edited.us> Cc: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org> Cc: dmaengine@vger.kernel.org Cc: devicetree@vger.kernel.org Reviewed-by: Rob Herring <robh@kernel.org> Signed-off-by: Youlin Wang <wwx575822@notesmail.huawei.com> Signed-off-by: Tanglei Han <hantanglei@huawei.com> Signed-off-by: John Stultz <john.stultz@linaro.org> Signed-off-by: Vinod Koul <vkoul@kernel.org>
48 lines
1.2 KiB
Plaintext
48 lines
1.2 KiB
Plaintext
* Hisilicon K3 DMA controller
|
|
|
|
See dma.txt first
|
|
|
|
Required properties:
|
|
- compatible: Must be one of
|
|
- "hisilicon,k3-dma-1.0"
|
|
- "hisilicon,hisi-pcm-asp-dma-1.0"
|
|
- reg: Should contain DMA registers location and length.
|
|
- interrupts: Should contain one interrupt shared by all channel
|
|
- #dma-cells: see dma.txt, should be 1, para number
|
|
- dma-channels: physical channels supported
|
|
- dma-requests: virtual channels supported, each virtual channel
|
|
have specific request line
|
|
- clocks: clock required
|
|
|
|
Example:
|
|
|
|
Controller:
|
|
dma0: dma@fcd02000 {
|
|
compatible = "hisilicon,k3-dma-1.0";
|
|
reg = <0xfcd02000 0x1000>;
|
|
#dma-cells = <1>;
|
|
dma-channels = <16>;
|
|
dma-requests = <27>;
|
|
interrupts = <0 12 4>;
|
|
clocks = <&pclk>;
|
|
};
|
|
|
|
Client:
|
|
Use specific request line passing from dmax
|
|
For example, i2c0 read channel request line is 18, while write channel use 19
|
|
|
|
i2c0: i2c@fcb08000 {
|
|
compatible = "snps,designware-i2c";
|
|
dmas = <&dma0 18 /* read channel */
|
|
&dma0 19>; /* write channel */
|
|
dma-names = "rx", "tx";
|
|
};
|
|
|
|
i2c1: i2c@fcb09000 {
|
|
compatible = "snps,designware-i2c";
|
|
dmas = <&dma0 20 /* read channel */
|
|
&dma0 21>; /* write channel */
|
|
dma-names = "rx", "tx";
|
|
};
|
|
|