Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp411023imm; Thu, 16 Aug 2018 23:33:00 -0700 (PDT) X-Google-Smtp-Source: AA+uWPzEyaGosuRB9poJce4OFJIN6M9uFs8dQeRx8DU4r+ktaRFqK78Rh7z+0TMYEx5qISMEZvR2 X-Received: by 2002:a62:e813:: with SMTP id c19-v6mr35123930pfi.124.1534487580689; Thu, 16 Aug 2018 23:33:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534487580; cv=none; d=google.com; s=arc-20160816; b=jpiexDmRVpBi7mOJ6TuRJY5JO5F0R+6iBAjbxuvLAGFd0ou+w92vAFzzn4SpcpxLAJ DzGBpWFJe2mCj+Vhajlo2XQLMmUzP47JvkHtdbUxzU1UACLrn4L+Fk0LFsxj7yT1zfNm ODtKeCTm6ugvcmj1mgVAuvn7SxzMXnjNXDXu9qzbHCO6BqLsupflBDbzQBRGxEwKHl/n SdJIJGuf52hZpRBxm43vzKjUYzuCaZ0hS3tBhHFKaemRnY/NERbih6k56gtfZKuzrhTD SJDoyN5PwnhYx+EPXlB7o2tGT0K1uSCzF4e7TLRvCe1hYxthn4PUqDV/6vJAO4uDKNoH bxEg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=sJUbmdckXItmiBnGbHxkiTDaJ4arn5GBBWsHag9wefE=; b=S63jSETD/o9xwKedgqKvjssmSKH9Iztfh4nf0LvasRoQt+QH42alRNQSFYKKeMN2tb 9APouHnWnq8zPF+it4VW5nqbA14OLbMCofhJ5HQr8npOImLN4583gTONiqfqea4KsxdL NzY0jMdlT+2BMm8gxSw0Ua/hGEEs0xcldbwbjEH8AQOOONdH2qDne9PCz4kXUn1oM+RE R2GTiE6jOmsHif/J/o00T86RNWY71Ya01EpWDcRpxaVcHTEuhqHKl8CKM4/eNjHoYt3H 9x1TzELYk8cVKzvOGLruK7WAbaSZw9TF7riOHgKonhsaznx27uNFGkjxws7My7DoQJfl NW6A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q4-v6si1416228pll.156.2018.08.16.23.32.30; Thu, 16 Aug 2018 23:33:00 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726319AbeHQJco (ORCPT + 99 others); Fri, 17 Aug 2018 05:32:44 -0400 Received: from lelv0142.ext.ti.com ([198.47.23.249]:58610 "EHLO lelv0142.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726134AbeHQJcn (ORCPT ); Fri, 17 Aug 2018 05:32:43 -0400 Received: from dflxv15.itg.ti.com ([128.247.5.124]) by lelv0142.ext.ti.com (8.15.2/8.15.2) with ESMTP id w7H6UEur079195; Fri, 17 Aug 2018 01:30:14 -0500 Received: from DLEE102.ent.ti.com (dlee102.ent.ti.com [157.170.170.32]) by dflxv15.itg.ti.com (8.14.3/8.13.8) with ESMTP id w7H6UEaD031508; Fri, 17 Aug 2018 01:30:14 -0500 Received: from DLEE108.ent.ti.com (157.170.170.38) by DLEE102.ent.ti.com (157.170.170.32) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Fri, 17 Aug 2018 01:30:14 -0500 Received: from dflp32.itg.ti.com (10.64.6.15) by DLEE108.ent.ti.com (157.170.170.38) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1466.3 via Frontend Transport; Fri, 17 Aug 2018 01:30:14 -0500 Received: from [192.168.2.6] (ileax41-snat.itg.ti.com [10.172.224.153]) by dflp32.itg.ti.com (8.14.3/8.13.8) with ESMTP id w7H6UCWv022890; Fri, 17 Aug 2018 01:30:12 -0500 Subject: Re: [RFC] dmaengine: Add metadata_ops for dma_async_tx_descriptor To: Radhey Shyam Pandey , "dan.j.williams@intel.com" , "vkoul@kernel.org" CC: "dmaengine@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "lars@metafoo.de" References: <20180815105704.26498-1-peter.ujfalusi@ti.com> From: Peter Ujfalusi Message-ID: <38aa48ba-5cf9-da12-bef8-b75e22f8b822@ti.com> Date: Fri, 17 Aug 2018 09:30:30 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Radhey, On 2018-08-16 16:29, Radhey Shyam Pandey wrote: >> +/** >> + * enum dma_desc_metadata_mode - per descriptor metadata mode types >> supported >> + * @DESC_METADATA_CLIENT - the metadata buffer is allocated/provided by >> the >> + * client driver and it is attached (via the dmaengine_desc_attach_metadata() >> + * helper) to the descriptor. >> + * @DESC_METADATA_EMBEDDED - the metadata buffer is >> allocated/managed by the DMA > Just a thought - We can rename it to DESC_METADATA_ENGINE? > i.e metadata allocation place - > dma client/engine. Sounds good. > >> + * driver. The client driver can ask for the pointer, maximum size and the >> + * currently used size of the metadata and can directly updata or read it. > /s/updata/update > >> + * dmaengine_desc_get_metadata_ptr() and >> dmaengine_desc_set_metadata_len() is >> + * provided as helper functions. > It will be helpful if we add description for both DESC_METADATA_EMBEDDED > modes i.e DMA_DEV_TO_MEM and MEM_TO_DEV types. I think in DEV_TO_MEM > we don't need to set_metadata_len(). Length will provided by DMA engine. I agree, it is better to extend the explanation on the two modes. ... >> +static inline int _desc_check_and_set_metadata_mode( >> + struct dma_async_tx_descriptor *desc, enum >> dma_desc_metadata_mode mode) >> +{ >> + /* Make sure that the metadata mode is not mixed */ >> + if (!desc->desc_metadata_mode) { > Minor nit - we can refactor this code to have failure path early. I don't think it would help readability, to move the failure case first: if (desc->desc_metadata_mode && (desc->desc_metadata_mode != mode)) { return -EINVAL; } else if (!desc->desc_metadata_mode) { if (dmaengine_is_metadata_mode_supported(desc->chan, mode)) desc->desc_metadata_mode = mode; else return -ENOTSUPP; } return 0; > >> + if (dmaengine_is_metadata_mode_supported(desc->chan, >> mode)) >> + desc->desc_metadata_mode = mode; >> + else >> + return -ENOTSUPP; >> + } else if (desc->desc_metadata_mode != mode) { >> + return -EINVAL; >> + } >> + >> + return 0; >> +} - Péter Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki