From patchwork Thu Feb 27 21:17:48 2014 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Santosh Shilimkar X-Patchwork-Id: 25477 Return-Path: X-Original-To: linaro@patches.linaro.org Delivered-To: linaro@patches.linaro.org Received: from mail-ve0-f197.google.com (mail-ve0-f197.google.com [209.85.128.197]) by ip-10-151-82-157.ec2.internal (Postfix) with ESMTPS id 3FA2B20447 for ; Thu, 27 Feb 2014 21:18:47 +0000 (UTC) Received: by mail-ve0-f197.google.com with SMTP id pa12sf1153074veb.4 for ; Thu, 27 Feb 2014 13:18:47 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:delivered-to:from:to:cc:subject:date:message-id :in-reply-to:references:mime-version:sender:precedence:list-id :x-original-sender:x-original-authentication-results:mailing-list :list-post:list-help:list-archive:list-unsubscribe:content-type; bh=B5LWWDsJrEar8JXe8vcoKfDH+okV+Ik7duGvLbAZMko=; b=Icd7v84TJonpIukh2/TTGYG5UjDfkihdl3ZqBD9Ed6et8Nj0wJITRIiTiLnfe07Dpi 8Mrp1GXvWXhQ0W9HL3Hg1nuamaKICv9UkJrZH47exol53PVe782IrVzUa3roBX3Zi4p1 W3sDgeranMN/lfcwlSyYhfQ880hqFFs80RLDva09xVH9EOP8NntKGnrI5FXkBRQKphZX Aq/wg8uTVk18IrYeG2p0qHWSerJfyLNQE1Tip2Qpzq0p77/cKeOwH0eER1D6/SX/3Jkz sHuMVIVNJnTmptXt4RSg5HP+Mlcez5H7dBXl8+uXEqKPYiD7kSODvpG1vpYuNxBAbXWr l+aQ== X-Gm-Message-State: ALoCoQl2zR+/Mgov2rlNLi7hKBuAIWk22jlna/viUqvUMZ7V81SLEMp3D74+gwXUy6gA//Fxq84b X-Received: by 10.224.163.71 with SMTP id z7mr6204793qax.5.1393535926945; Thu, 27 Feb 2014 13:18:46 -0800 (PST) X-BeenThere: patchwork-forward@linaro.org Received: by 10.140.88.203 with SMTP id t69ls888044qgd.87.gmail; Thu, 27 Feb 2014 13:18:46 -0800 (PST) X-Received: by 10.58.172.132 with SMTP id bc4mr2030085vec.45.1393535926831; Thu, 27 Feb 2014 13:18:46 -0800 (PST) Received: from mail-ve0-f179.google.com (mail-ve0-f179.google.com [209.85.128.179]) by mx.google.com with ESMTPS id f7si1652644vcz.57.2014.02.27.13.18.46 for (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Thu, 27 Feb 2014 13:18:46 -0800 (PST) Received-SPF: neutral (google.com: 209.85.128.179 is neither permitted nor denied by best guess record for domain of patch+caf_=patchwork-forward=linaro.org@linaro.org) client-ip=209.85.128.179; Received: by mail-ve0-f179.google.com with SMTP id db12so548150veb.38 for ; Thu, 27 Feb 2014 13:18:46 -0800 (PST) X-Received: by 10.52.37.161 with SMTP id z1mr4026845vdj.29.1393535926713; Thu, 27 Feb 2014 13:18:46 -0800 (PST) X-Forwarded-To: patchwork-forward@linaro.org X-Forwarded-For: patch@linaro.org patchwork-forward@linaro.org Delivered-To: patch@linaro.org Received: by 10.220.130.193 with SMTP id u1csp6148vcs; Thu, 27 Feb 2014 13:18:46 -0800 (PST) X-Received: by 10.66.163.2 with SMTP id ye2mr17339617pab.110.1393535925825; Thu, 27 Feb 2014 13:18:45 -0800 (PST) Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id bi5si5843182pbb.319.2014.02.27.13.18.45; Thu, 27 Feb 2014 13:18:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751516AbaB0VSo (ORCPT + 9 others); Thu, 27 Feb 2014 16:18:44 -0500 Received: from comal.ext.ti.com ([198.47.26.152]:41947 "EHLO comal.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751007AbaB0VSo (ORCPT ); Thu, 27 Feb 2014 16:18:44 -0500 Received: from dlelxv90.itg.ti.com ([172.17.2.17]) by comal.ext.ti.com (8.13.7/8.13.7) with ESMTP id s1RLIDQA018366; Thu, 27 Feb 2014 15:18:13 -0600 Received: from DFLE72.ent.ti.com (dfle72.ent.ti.com [128.247.5.109]) by dlelxv90.itg.ti.com (8.14.3/8.13.8) with ESMTP id s1RLIDJb010259; Thu, 27 Feb 2014 15:18:13 -0600 Received: from dflp32.itg.ti.com (10.64.6.15) by DFLE72.ent.ti.com (128.247.5.109) with Microsoft SMTP Server id 14.3.174.1; Thu, 27 Feb 2014 15:18:13 -0600 Received: from ula0393909.am.dhcp.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by dflp32.itg.ti.com (8.14.3/8.13.8) with ESMTP id s1RLHrfg023451; Thu, 27 Feb 2014 15:18:12 -0600 From: Santosh Shilimkar To: CC: , , , , , , Grygorii Strashko , Russell King , Olof Johansson , Santosh Shilimkar Subject: [PATCH v2 3/7] dma: of: introduce of_dma_get_range() helper Date: Thu, 27 Feb 2014 16:17:48 -0500 Message-ID: <1393535872-20915-4-git-send-email-santosh.shilimkar@ti.com> X-Mailer: git-send-email 1.7.9.5 In-Reply-To: <1393535872-20915-1-git-send-email-santosh.shilimkar@ti.com> References: <1393535872-20915-1-git-send-email-santosh.shilimkar@ti.com> MIME-Version: 1.0 Sender: devicetree-owner@vger.kernel.org Precedence: list List-ID: X-Mailing-List: devicetree@vger.kernel.org X-Removed-Original-Auth: Dkim didn't pass. X-Original-Sender: santosh.shilimkar@ti.com X-Original-Authentication-Results: mx.google.com; spf=neutral (google.com: 209.85.128.179 is neither permitted nor denied by best guess record for domain of patch+caf_=patchwork-forward=linaro.org@linaro.org) smtp.mail=patch+caf_=patchwork-forward=linaro.org@linaro.org Mailing-list: list patchwork-forward@linaro.org; contact patchwork-forward+owners@linaro.org X-Google-Group-Id: 836684582541 List-Post: , List-Help: , List-Archive: List-Unsubscribe: , From: Grygorii Strashko The of_dma_get_range() allows to find "dma-range" property for the specified device and parse it. dma-ranges format: DMA addr (dma_addr) : naddr cells CPU addr (phys_addr_t) : pna cells size : nsize cells Cc: Russell King Cc: Arnd Bergmann Cc: Olof Johansson Cc: Grant Likely Cc: Rob Herring Signed-off-by: Grygorii Strashko Signed-off-by: Santosh Shilimkar --- drivers/dma/of-dma.c | 86 ++++++++++++++++++++++++++++++++++++++++++++++++ include/linux/of_dma.h | 8 +++++ 2 files changed, 94 insertions(+) diff --git a/drivers/dma/of-dma.c b/drivers/dma/of-dma.c index e8fe9dc..9b51768 100644 --- a/drivers/dma/of-dma.c +++ b/drivers/dma/of-dma.c @@ -17,6 +17,7 @@ #include #include #include +#include static LIST_HEAD(of_dma_list); static DEFINE_MUTEX(of_dma_lock); @@ -218,3 +219,88 @@ struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec, &dma_spec->args[0]); } EXPORT_SYMBOL_GPL(of_dma_simple_xlate); + +/** + * of_dma_get_range - Get DMA range info + * @np: device node to get DMA range info + * @dma_addr: pointer to store initial DMA address of DMA range + * @paddr: pointer to store initial CPU address of DMA range + * @size: pointer to store size of DMA range + * + * Look in bottom up direction for the first "dma-range" property + * and parse it. + * dma-ranges format: + * DMA addr (dma_addr) : naddr cells + * CPU addr (phys_addr_t) : pna cells + * size : nsize cells + * + * It returns -ENODEV if "dma-ranges" property was not found + * for this device in DT. + */ +extern int of_dma_get_range(struct device_node *np, dma_addr_t *dma_addr, + phys_addr_t *paddr, phys_addr_t *size) +{ + struct device_node *node = np; + const u32 *ranges = NULL; + int len, naddr, nsize, pna; + int ret = 0; + + if (!node) + return -EINVAL; + + while (1) { + naddr = of_n_addr_cells(node); + nsize = of_n_size_cells(node); + node = of_get_next_parent(node); + if (!node) + break; + + ranges = of_get_property(node, "dma-ranges", &len); + + /* Ignore empty ranges, they imply no translation required */ + if (ranges && len > 0) + break; + + /* + * At least empty ranges has to be defined for parent node if + * DMA is supported + */ + if (!ranges) + break; + } + + if (!ranges) { + pr_debug("%s: no dma-ranges found for node(%s)\n", + __func__, np->full_name); + ret = -ENODEV; + goto out; + } + + len /= sizeof(u32); + + pna = of_n_addr_cells(node); + + /* dma-ranges format: + * DMA addr : naddr cells + * CPU addr : pna cells + * size : nsize cells + */ + *dma_addr = of_read_number(ranges, naddr); + *paddr = of_translate_dma_address(np, ranges); + if (*paddr == OF_BAD_ADDR) { + pr_err("%s: translation of DMA address(%#08x) to CPU address failed node(%s)\n", + __func__, *dma_addr, np->full_name); + ret = -EINVAL; + } + + *size = of_read_number(ranges + naddr + pna, nsize); + + pr_debug("dma_addr(%08x) cpu_addr(%pa) size(%pa)\n", + *dma_addr, paddr, size); + +out: + of_node_put(node); + + return ret; +} +EXPORT_SYMBOL_GPL(of_dma_get_range); diff --git a/include/linux/of_dma.h b/include/linux/of_dma.h index ae36298..f04171a 100644 --- a/include/linux/of_dma.h +++ b/include/linux/of_dma.h @@ -41,6 +41,9 @@ extern struct dma_chan *of_dma_request_slave_channel(struct device_node *np, const char *name); extern struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec, struct of_dma *ofdma); + +extern int of_dma_get_range(struct device_node *np, dma_addr_t *dma_addr, + phys_addr_t *paddr, phys_addr_t *size); #else static inline int of_dma_controller_register(struct device_node *np, struct dma_chan *(*of_dma_xlate) @@ -66,6 +69,11 @@ static inline struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_s return NULL; } +static inline int of_dma_get_range(struct device_node *np, dma_addr_t *dma_addr, + phys_addr_t *paddr, phys_addr_t *size); +{ + return -ENODEV; +} #endif #endif /* __LINUX_OF_DMA_H */