Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp242009pxb; Fri, 15 Jan 2021 02:00:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJxd19w+7CwrCA07T2AW4TQO6m3F8p5wrKgSKNavyTdUPTgc4jQiiP62ZSL9AG5lyiBzKwWr X-Received: by 2002:a17:906:b002:: with SMTP id v2mr8303057ejy.531.1610704852815; Fri, 15 Jan 2021 02:00:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610704852; cv=none; d=google.com; s=arc-20160816; b=dCMS3oKKh5T84tILPPhcMjhA3z1RU1MwyGC0o9q/gVu85aJQoq1XmOrk/pwHawOpZd QMhfAQIFyvRqyhxrlPLrRuZu/1QcKEhmVAe8eKlnFXRi1vS6b3TSJm6jU+f3KEYbMF15 XevUzOHiKYgR9UmwD9hgk38Uctu2+Hmd+x09PkEPspIfH2ie2zhBm9V0+yzuEHUIoiDJ ZU5hg309U57SweBigRy7tSZAOKVwATKkKPXd3N6d9Ua9yTYnXdB+YJxpH5oe8hkd1DNz ehpmbHxWC75nIaeNlEmNcSnBqsyTIxW8GX7BaXY2YRaF7A4mEc5rHV5ZV0vHzxQLDIKl 7Pow== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:references:in-reply-to :message-id:date:subject:cc:to:from:ironport-sdr:ironport-sdr; bh=/rhw4e0SWpgRKl3WhXaJRlIkIu9tmsR24BjdmzlX4a8=; b=m+cV55xtRe0XxzPcP0MggYeG4SFV1PYksXlnUsRQbKAucGlWw6abFXRA70Yx+L1003 U1Qi9Kl2u8oakaGOs/FGBJM81BpKvUPvGJjnCwwozOqKd4XKjORSNZjFgIStU5C6hqVJ JCZgMMPqBSuMyYzD48vtHNNCWM/H9hK0NG6W2igGJXFn6hbIbFM39Mk8a8HY6OC+GBkr FH3aa90BCXl1mAntGq2SLAnBzrl0ggTifkZ6kyPT79WKwgDWIFiww0nnP6QLsBv/sX3I yNHq6nrLJgXg02cNskbInn8VF8gX/5LHeXrL1t13333f/L0CKw9VmPRpADKfkpEAZaXd DyCg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c25si3635965edw.609.2021.01.15.02.00.28; Fri, 15 Jan 2021 02:00:52 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730722AbhAOJ6B (ORCPT + 99 others); Fri, 15 Jan 2021 04:58:01 -0500 Received: from mga07.intel.com ([134.134.136.100]:10905 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728971AbhAOJ57 (ORCPT ); Fri, 15 Jan 2021 04:57:59 -0500 IronPort-SDR: /1K4ferONoqXKgUIchnWcrZi1fOgafLiKEGRvwr44G7IhAunkihCo2UOLfjyz27LLmOQL9n9OG 8RJDtvVz3tyw== X-IronPort-AV: E=McAfee;i="6000,8403,9864"; a="242596629" X-IronPort-AV: E=Sophos;i="5.79,349,1602572400"; d="scan'208";a="242596629" Received: from orsmga006.jf.intel.com ([10.7.209.51]) by orsmga105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jan 2021 01:56:17 -0800 IronPort-SDR: +pif3MmG5DIcLRHM0k7nhGgfMTA7YLVCbH5BEUwnotP7FuaGBeAOzyXUZH03D3ehozqBeTcX8k LNaaveAztJTQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.79,349,1602572400"; d="scan'208";a="352762504" Received: from sgsxdev004.isng.phoenix.local (HELO localhost) ([10.226.81.179]) by orsmga006.jf.intel.com with ESMTP; 15 Jan 2021 01:56:14 -0800 From: Amireddy Mallikarjuna reddy To: dmaengine@vger.kernel.org, vkoul@kernel.org, devicetree@vger.kernel.org, robh+dt@kernel.org Cc: linux-kernel@vger.kernel.org, andriy.shevchenko@intel.com, chuanhua.lei@linux.intel.com, cheol.yong.kim@intel.com, qi-ming.wu@intel.com, mallikarjunax.reddy@linux.intel.com, malliamireddy009@gmail.com, rtanwar@maxlinear.com, lchuanhua@maxlinear.com Subject: [PATCH v11 1/2] dt-bindings: dma: Add bindings for Intel LGM SoC Date: Fri, 15 Jan 2021 17:56:02 +0800 Message-Id: <0864b9bfa6e2b8b5e7ad9a7a739ca3274f66493c.1610703653.git.mallikarjunax.reddy@linux.intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: References: In-Reply-To: References: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add DT bindings YAML schema for DMA controller driver of Lightning Mountain (LGM) SoC. Signed-off-by: Amireddy Mallikarjuna reddy Reviewed-by: Rob Herring --- v1: - Initial version. v2: - Fix bot errors. v3: - No change. v4: - Address Thomas langer comments - use node name pattern as dma-controller as in common binding. - Remove "_" (underscore) in instance name. - Remove "port-" and "chan-" in attribute name for both 'dma-ports' & 'dma-channels' child nodes. v5: - Moved some of the attributes in 'dma-ports' & 'dma-channels' child nodes to dma client/consumer side as cells in 'dmas' properties. v6: - Add additionalProperties: false - completely removed 'dma-ports' and 'dma-channels' child nodes. - Moved channel dt properties to client side dmas. - Use standard dma-channels and dma-channel-mask properties. - Documented reset-names - Add description for dma-cells v7: - modified compatible to oneof - Reduced number of dma-cells to 3 - Fine tune the description of some properties. v7-resend: - rebase to 5.10-rc1 - No change. v8: - rebased to 5.10-rc3 - Fixing the bot issues (wrong indentation) v9: - Use 'enum' instead of oneOf+const - Drop '#dma-cells' in required:, already covered in dma-common.yaml - Drop nodename Already covered by dma-controller.yaml v10: - rebased to 5.10-rc6 - Add Reviewed-by: Rob Herring - Fixed typo. - moved property dma-desc-in-sram to driver side. - Moved property dma-orrc to driver side. v10-resend: - rebased to 5.10 - No change v11: - Since v10 was sent, there have been some fixes for JSON pointers and tools check now got this is missing a '/'. Add missing a '/' in '/schemas/types.yaml#definitions/uint32' --- .../devicetree/bindings/dma/intel,ldma.yaml | 116 ++++++++++++++++++ 1 file changed, 116 insertions(+) create mode 100644 Documentation/devicetree/bindings/dma/intel,ldma.yaml diff --git a/Documentation/devicetree/bindings/dma/intel,ldma.yaml b/Documentation/devicetree/bindings/dma/intel,ldma.yaml new file mode 100644 index 000000000000..a5c4be783593 --- /dev/null +++ b/Documentation/devicetree/bindings/dma/intel,ldma.yaml @@ -0,0 +1,116 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/dma/intel,ldma.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Lightning Mountain centralized DMA controllers. + +maintainers: + - chuanhua.lei@intel.com + - mallikarjunax.reddy@intel.com + +allOf: + - $ref: "dma-controller.yaml#" + +properties: + compatible: + enum: + - intel,lgm-cdma + - intel,lgm-dma2tx + - intel,lgm-dma1rx + - intel,lgm-dma1tx + - intel,lgm-dma0tx + - intel,lgm-dma3 + - intel,lgm-toe-dma30 + - intel,lgm-toe-dma31 + + reg: + maxItems: 1 + + "#dma-cells": + const: 3 + description: + The first cell is the peripheral's DMA request line. + The second cell is the peripheral's (port) number corresponding to the channel. + The third cell is the burst length of the channel. + + dma-channels: + minimum: 1 + maximum: 16 + + dma-channel-mask: + maxItems: 1 + + clocks: + maxItems: 1 + + resets: + maxItems: 1 + + reset-names: + items: + - const: ctrl + + interrupts: + maxItems: 1 + + intel,dma-poll-cnt: + $ref: /schemas/types.yaml#/definitions/uint32 + description: + DMA descriptor polling counter is used to control the poling mechanism + for the descriptor fetching for all channels. + + intel,dma-byte-en: + type: boolean + description: + DMA byte enable is only valid for DMA write(RX). + Byte enable(1) means DMA write will be based on the number of dwords + instead of the whole burst. + + intel,dma-drb: + type: boolean + description: + DMA descriptor read back to make sure data and desc synchronization. + + intel,dma-dburst-wr: + type: boolean + description: + Enable RX dynamic burst write. When it is enabled, the DMA does RX dynamic burst; + if it is disabled, the DMA RX will still support programmable fixed burst size of 2,4,8,16. + It only applies to RX DMA and memcopy DMA. + +required: + - compatible + - reg + +additionalProperties: false + +examples: + - | + dma0: dma-controller@e0e00000 { + compatible = "intel,lgm-cdma"; + reg = <0xe0e00000 0x1000>; + #dma-cells = <3>; + dma-channels = <16>; + dma-channel-mask = <0xFFFF>; + interrupt-parent = <&ioapic1>; + interrupts = <82 1>; + resets = <&rcu0 0x30 0>; + reset-names = "ctrl"; + clocks = <&cgu0 80>; + intel,dma-poll-cnt = <4>; + intel,dma-byte-en; + intel,dma-drb; + }; + - | + dma3: dma-controller@ec800000 { + compatible = "intel,lgm-dma3"; + reg = <0xec800000 0x1000>; + clocks = <&cgu0 71>; + resets = <&rcu0 0x10 9>; + #dma-cells = <3>; + intel,dma-poll-cnt = <16>; + intel,dma-byte-en; + intel,dma-dburst-wr; + }; -- 2.17.1