Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp270164pxu; Wed, 25 Nov 2020 02:42:47 -0800 (PST) X-Google-Smtp-Source: ABdhPJyUGrg3Z/mgYmMO554Ib3VkxBLOxgqpexmntjxUZmhMjvKSyEz5EAjNezP4l4vmb5RgYydm X-Received: by 2002:a17:906:d96e:: with SMTP id rp14mr2588326ejb.214.1606300966913; Wed, 25 Nov 2020 02:42:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606300966; cv=none; d=google.com; s=arc-20160816; b=SA1eGiRP5snsPWa5Fgi81Kb/L60X5ZEXVp/tmOjBJkd7lI/fKaprfZuivtIyL/pmVr x+EuPLmK+WI/ZTQ48/CBH0Nhp90IgkXOlKxQsHCsufAyomGNAZH4zuOgh9mWPRYwMGvh vRCYrVk2rf4qX6rGyeumljlupvqbdgzDU2oDRp0I/GVhGAIsbGukjgUAUfIeEsu+wrAC Wp/tpZR0GKqKE9dHtsx/mg4mqi9tGPxQz4BfbHYsveZrQa9sCHtk+n1q/CI2UfCSGco4 M9f/l+m2Pm8FG0skfRIxDZ2SCgl8h1lNQ3Y2vf03KE0Bo1MJpgk2BGmQHyVoOJ5BQZiT EIsQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:ironport-sdr:ironport-sdr; bh=2ALivraGwn0fv0JTfIdn0DT+zsMAtwto5qE2w1BzLMQ=; b=FAWFQBljAsQYzpILmJ5zTUNGxvjh/ISdPa1fJSxcjesULc/4lF30WcxgLhNW4l6EV1 04KbnsJombqAB9NS4nXZTIsEKqnmlnbpg0DeRbRAK29nqj0WFCamZ+5890FfadTBQT8G NMIOXurha5LANTfVoncjnsJPjkttfPHWkY1mCxp7Y7CVWcE/mLxDIZ7yuDCYyaNFqWWS pxsmmMJHb3WN6/cyAfCp63BM7pSPzukzLTW6/rROApDAVMSfk9qlTLKgYWdJNUcO/11v yTHyz8n8ZR1u8VQ9nXYxISvGctRMnW4HThPGpqjPfqpqwCDZBHw6RLXBJ0OECI+L43eL rKsg== 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 v26si1026982eja.230.2020.11.25.02.42.23; Wed, 25 Nov 2020 02:42:46 -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 S1729198AbgKYKju (ORCPT + 99 others); Wed, 25 Nov 2020 05:39:50 -0500 Received: from mga14.intel.com ([192.55.52.115]:9862 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728295AbgKYKju (ORCPT ); Wed, 25 Nov 2020 05:39:50 -0500 IronPort-SDR: 3YRyKs4ncHNhCrrxhvsE+R/a/wjIrVy7hgtzFuAwbby6oOTUhp2OOrNvpbBp1fp/tZ5RkYGi5/ TecdPRGxPy8w== X-IronPort-AV: E=McAfee;i="6000,8403,9815"; a="171330276" X-IronPort-AV: E=Sophos;i="5.78,368,1599548400"; d="scan'208";a="171330276" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga001.jf.intel.com ([10.7.209.18]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 25 Nov 2020 02:39:48 -0800 IronPort-SDR: aWmS+tnZ1INTYp8FRjZN/ciFLj9eaA3Wx7G05j/0ZSOYinBf+Q+T4DVOB1eWpd2NEAzntRGYzU YvruRgOdlR0Q== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.78,368,1599548400"; d="scan'208";a="403230286" Received: from linux.intel.com ([10.54.29.200]) by orsmga001.jf.intel.com with ESMTP; 25 Nov 2020 02:39:48 -0800 Received: from [10.249.69.92] (mreddy3x-MOBL.gar.corp.intel.com [10.249.69.92]) by linux.intel.com (Postfix) with ESMTP id 69939580638; Wed, 25 Nov 2020 02:39:45 -0800 (PST) Subject: Re: [PATCH v9 1/2] dt-bindings: dma: Add bindings for Intel LGM SoC To: Vinod Koul Cc: dmaengine@vger.kernel.org, devicetree@vger.kernel.org, robh+dt@kernel.org, linux-kernel@vger.kernel.org, andriy.shevchenko@intel.com, chuanhua.lei@linux.intel.com, cheol.yong.kim@intel.com, qi-ming.wu@intel.com, malliamireddy009@gmail.com, peter.ujfalusi@ti.com References: <20201118155552.GV50232@vkoul-mobl> <44fba7c3-37a9-7168-3c19-eeb5068b7063@linux.intel.com> <20201121121917.GC8403@vkoul-mobl> <20201124172309.GU8403@vkoul-mobl> From: "Reddy, MallikarjunaX" Message-ID: <9fe5ddaf-a2b5-b788-9d82-ed5eab310b81@linux.intel.com> Date: Wed, 25 Nov 2020 18:39:44 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.5.0 MIME-Version: 1.0 In-Reply-To: <20201124172309.GU8403@vkoul-mobl> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Vinod, Thanks for your review comments, My comments inline. On 11/25/2020 1:23 AM, Vinod Koul wrote: > On 24-11-20, 00:30, Reddy, MallikarjunaX wrote: >> Hi Vinod, >> >> Thanks for your valuable review. My comments inline. >> >> On 11/21/2020 8:19 PM, Vinod Koul wrote: >>> On 20-11-20, 19:30, Reddy, MallikarjunaX wrote: >>>> Hi Vinod, >>>> Thanks for the review. My comments inline. >>>> >>>> On 11/18/2020 11:55 PM, Vinod Koul wrote: >>>>> On 12-11-20, 13:38, Amireddy Mallikarjuna reddy wrote: >>>>>> Add DT bindings YAML schema for DMA controller driver >>>>>> of Lightning Mountain (LGM) SoC. >>>>>> >>>>>> Signed-off-by: Amireddy Mallikarjuna reddy >>>>>> --- >>>>>> 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 >>>>>> >>>>>> v8: >>>>>> - rebased to 5.10-rc3 >>>>>> - Fixing the bot issues (wrong indentation) >>>>>> >>>>>> v9: >>>>>> - rebased to 5.10-rc3 >>>>>> - 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 >>>>>> --- >>>>>> .../devicetree/bindings/dma/intel,ldma.yaml | 130 +++++++++++++++++++++ >>>>>> 1 file changed, 130 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..c06281a10178 >>>>>> --- /dev/null >>>>>> +++ b/Documentation/devicetree/bindings/dma/intel,ldma.yaml >>>>>> @@ -0,0 +1,130 @@ >>>>>> +# 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 low speed DMA and high speed 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 >>>>> s/poling/polling >>>> Ok, Thanks. >>>>>> + 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. >>>>> Can you explain this, also sounds you could use _maxburst values..? >>>> when dma-byte-en = 0 (disabled) DMA write will be in terms of burst length, >>>> dma-byte-en = 1 (enabled) write will be in terms of Dwords. >>>> >>>> Byte enable = 0 (Disabled) means that DMA write will be based on the burst >>>> length, even if it only transmits one byte. >>>> Byte enable = 1(enabled) means that DMA write will be based on the number of >>>> Dwords, instead of the whole burst. >>> Sounds like a hw property or is this configurable to engine..? >> Yes its hw property. Not configurable to engine. >>>>>> + >>>>>> + intel,dma-drb: >>>>>> + type: boolean >>>>>> + description: >>>>>> + DMA descriptor read back to make sure data and desc synchronization. >>>>>> + >>>>>> + intel,dma-desc-in-sram: >>>>>> + type: boolean >>>>>> + description: >>>>>> + DMA descritpors in SRAM or not. Some old controllers descriptors >>>>>> + can be in DRAM or SRAM. The new ones are all in SRAM. >>>>> should that not be decided by driver..? Or is this a hw property? >>>> This is DMA controller capability. It can be decided from driver also. i >>>> will change accordingly. >>>>>> + >>>>>> + intel,dma-orrc: >>>>>> + $ref: /schemas/types.yaml#definitions/uint32 >>>>>> + description: >>>>>> + DMA outstanding read counter value determine the number of >>>>>> + ORR-Outstanding Read Request. The maximum value is 16. >>>>> How would this be used by folks..? >>>> A register bit will be used to enable/disable the ORR feature. >>>> >>>> Outstanding Read Capability introduce CMD FIFO to support up to 16 >>>> outstanding reads for different packet in same channel. >>>> >>>> For large packets up to 16 OR can be issued, the number of OR is >>>> configurable. >>> How will configure this and when..? >> This is DMA (ver > DMA_VER22) hw capability and is configured from device >> tree. >> >> If this property is not present or count is zero means orrc capability is >> disabled. >> If orrc count is 4 <= orr_cnt < 16 then write the enable bit and value to >> corresponding register. >> >> Ex: >>         if (d->orrc > 0 && d->orrc <= DMA_ORRC_MAX_CNT) >>                 val = DMA_ORRC_EN | FIELD_PREP(DMA_ORRC_ORRCNT, d->orrc); >> >>         ldma_update_bits(d, mask, val, DMA_ORRC); >> >> This hw capability supports dma instances ver > DMA_VER22. > Sounds like this can be coded in driver and used based on compatible? Yes, we can do that. I will update in the next patch. >