Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp375828pxb; Mon, 7 Feb 2022 13:35:21 -0800 (PST) X-Google-Smtp-Source: ABdhPJyaHq4R9jy5AUGib+Dl2XIkSd6Uy3kpTZlKsmiNO91mOVyeiPb+SD11Mm+0/Aai7mrXckvA X-Received: by 2002:a05:6402:2895:: with SMTP id eg21mr1407277edb.439.1644269721084; Mon, 07 Feb 2022 13:35:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644269721; cv=none; d=google.com; s=arc-20160816; b=pkVvSFyQ0gl0EQk6sZ5EjfMBDZJXLNQ+hz9H6DJAxeENjQQB3nb7wyPyzxo2j+wBsC h0Lr8q79GtLBddsy/a1jROYvHOA7TOqP0DbmE4qPA+Dzjnd3fBBGnIqqr6H/2zrH2P1F xIq3arcsP5F7EtHIB9JkR4GHz/UE9iw8gNI9XWjIoPGj5eO/9706WgCUow2MGOFO4kmm /8EKXQRq+asRMdXA3rxNictcbeQNEmSyphw4GJ6MHwy+YVbHJUzDzc2JVb/RDEYky3Du pt9P3QNdvctH3RUPPJ2oWgNHX4OdMdTxqTLAD5QkwACQ00pNPUSCMSiYfzjFPufk3YyK Vv3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=NsFZzRzWxi9SLwITfrc8E6h9ajUabmlo1GhXmJ+C3hc=; b=TaVMYgx9OVGDWQ3jOFX1IjEStnv1XeSMxazGuYa3EAM3iLagbfw7N+EENH5B59frjt fVijE8M2uO4rwFSHWJ/exBo8T8lxdAyYdtIhKKCej+3Wq/TqaiAvS2MRlLh2YJVHJsYn +PJrmoYpP8PAmpQA65axtVM5qM0/bi1ASvtDzO/+wtTryVac7khtOOGQsHqSkjXjiUKG 5/ct/7sGqb015lua3gSUKdztpI4SakFVQ4KHjHe1XexmF9hpHfiu1Qt36VNzsZKRXBXb msbyDLWg07I914SbcJX4oOBgYcwqu0OCqspX2EyymrfEjngPKfC0z+K1evmDC6hXSaoH LpVw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=WAlvS5EX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 13si6976303ejg.544.2022.02.07.13.34.55; Mon, 07 Feb 2022 13:35:21 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=WAlvS5EX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345799AbiBGGgl (ORCPT + 99 others); Mon, 7 Feb 2022 01:36:41 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60674 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236921AbiBGGbR (ORCPT ); Mon, 7 Feb 2022 01:31:17 -0500 Received: from mail-pf1-x433.google.com (mail-pf1-x433.google.com [IPv6:2607:f8b0:4864:20::433]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C2823C0401C4 for ; Sun, 6 Feb 2022 22:30:57 -0800 (PST) Received: by mail-pf1-x433.google.com with SMTP id 192so11310127pfz.3 for ; Sun, 06 Feb 2022 22:30:57 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=NsFZzRzWxi9SLwITfrc8E6h9ajUabmlo1GhXmJ+C3hc=; b=WAlvS5EXiVRFIZe8CQYOYmWuBeX252Ah939fQC4xFyJiOgiQOqKLCEZ9w/rsR6+gi6 9ofS/fBv7QwPpn/VyFviNxUjm4OSgt5WaUQ38ohiXY8yU3zjlUJ1Yvbtqkq/Q0hEdem+ vOL4LBrdoiDalFZWuSYY69OLG3uLZfb1ktFR1Bo8AZaDqbbY/rsgggVvLIGRaCKEw8tO M6ffn1560ArOL3Xpl5xg0EVvQnm6FsEePBN54U5qe7xAaGTB4ob9FbVdBbdf9fWl+Xe5 0rS+pkIIUcoKVFmz3iMt4cxeBgkdGefflHbs0Y4BJCec9H7Tu+D3zt+hkDIKrAumXmsr epUg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=NsFZzRzWxi9SLwITfrc8E6h9ajUabmlo1GhXmJ+C3hc=; b=PRF7ct7NG5lCPM+xysCnRRIbpO+oGvJbPg8UM2MhAp/P0UPeObZBUasXAaoScvCIk1 4XQKj8BMMNzy3AeV70irZnToSrS12dQIrtvebTVLGblhHBD90s+qPz7G4qcAzxn4sH8k xBaux4hJ69xfvB9ZA4EElH+lJc9JsoUbHPJd2FEjjYN8nfq2+ASLgzuMQ4eCtoFcPUPs Nwr1wgqFXK3R3daKWY/P/nscNrjqKkPM+yeyUEu/jhW8JLFYdRjeikJc5afVH/TOSJDk 4nAGGuiEBMnpeju1YLv1J9ODMI2Are/pEsPHQ8NpCJnHkHdA0kM09ccE80DvvctbxJXe 3pow== X-Gm-Message-State: AOAM531zyXz0cmySvvK2r/3k5z9vDd+77AxfjzbSrd78bNQ2czcZZrif R61xjk4Sx6onxPDraFWQL87ywA== X-Received: by 2002:aa7:84d5:: with SMTP id x21mr14270143pfn.72.1644215456964; Sun, 06 Feb 2022 22:30:56 -0800 (PST) Received: from hsinchu16.internal.sifive.com (59-124-168-89.hinet-ip.hinet.net. [59.124.168.89]) by smtp.gmail.com with ESMTPSA id i10sm5266634pjd.2.2022.02.06.22.30.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 06 Feb 2022 22:30:56 -0800 (PST) From: Zong Li To: robh+dt@kernel.org, paul.walmsley@sifive.com, palmer@dabbelt.com, aou@eecs.berkeley.edu, krzysztof.kozlowski@canonical.com, conor.dooley@microchip.com, geert@linux-m68k.org, bin.meng@windriver.com, green.wan@sifive.com, vkoul@kernel.org, dmaengine@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org Cc: Zong Li Subject: [PATCH v5 3/3] dmaengine: sf-pdma: Get number of channel by device tree Date: Mon, 7 Feb 2022 14:30:40 +0800 Message-Id: X-Mailer: git-send-email 2.31.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org It currently assumes that there are always four channels, it would cause the error if there is actually less than four channels. Change that by getting number of channel from device tree. For backwards-compatibility, it uses the default value (i.e. 4) when there is no 'dma-channels' information in dts. Signed-off-by: Zong Li --- drivers/dma/sf-pdma/sf-pdma.c | 21 ++++++++++++++------- drivers/dma/sf-pdma/sf-pdma.h | 8 ++------ 2 files changed, 16 insertions(+), 13 deletions(-) diff --git a/drivers/dma/sf-pdma/sf-pdma.c b/drivers/dma/sf-pdma/sf-pdma.c index f12606aeff87..2ae10b61dfa1 100644 --- a/drivers/dma/sf-pdma/sf-pdma.c +++ b/drivers/dma/sf-pdma/sf-pdma.c @@ -482,9 +482,7 @@ static void sf_pdma_setup_chans(struct sf_pdma *pdma) static int sf_pdma_probe(struct platform_device *pdev) { struct sf_pdma *pdma; - struct sf_pdma_chan *chan; struct resource *res; - int len, chans; int ret; const enum dma_slave_buswidth widths = DMA_SLAVE_BUSWIDTH_1_BYTE | DMA_SLAVE_BUSWIDTH_2_BYTES | @@ -492,13 +490,21 @@ static int sf_pdma_probe(struct platform_device *pdev) DMA_SLAVE_BUSWIDTH_16_BYTES | DMA_SLAVE_BUSWIDTH_32_BYTES | DMA_SLAVE_BUSWIDTH_64_BYTES; - chans = PDMA_NR_CH; - len = sizeof(*pdma) + sizeof(*chan) * chans; - pdma = devm_kzalloc(&pdev->dev, len, GFP_KERNEL); + pdma = devm_kzalloc(&pdev->dev, sizeof(*pdma), GFP_KERNEL); if (!pdma) return -ENOMEM; - pdma->n_chans = chans; + ret = of_property_read_u32(pdev->dev.of_node, "dma-channels", + &pdma->n_chans); + if (ret) { + dev_notice(&pdev->dev, "set number of channels to default value: 4\n"); + pdma->n_chans = PDMA_MAX_NR_CH; + } + + if (pdma->n_chans > PDMA_MAX_NR_CH) { + dev_err(&pdev->dev, "the number of channels exceeds the maximum\n"); + return -EINVAL; + } res = platform_get_resource(pdev, IORESOURCE_MEM, 0); pdma->membase = devm_ioremap_resource(&pdev->dev, res); @@ -556,7 +562,7 @@ static int sf_pdma_remove(struct platform_device *pdev) struct sf_pdma_chan *ch; int i; - for (i = 0; i < PDMA_NR_CH; i++) { + for (i = 0; i < pdma->n_chans; i++) { ch = &pdma->chans[i]; devm_free_irq(&pdev->dev, ch->txirq, ch); @@ -574,6 +580,7 @@ static int sf_pdma_remove(struct platform_device *pdev) static const struct of_device_id sf_pdma_dt_ids[] = { { .compatible = "sifive,fu540-c000-pdma" }, + { .compatible = "sifive,pdma0" }, {}, }; MODULE_DEVICE_TABLE(of, sf_pdma_dt_ids); diff --git a/drivers/dma/sf-pdma/sf-pdma.h b/drivers/dma/sf-pdma/sf-pdma.h index 0c20167b097d..8127d792f639 100644 --- a/drivers/dma/sf-pdma/sf-pdma.h +++ b/drivers/dma/sf-pdma/sf-pdma.h @@ -22,11 +22,7 @@ #include "../dmaengine.h" #include "../virt-dma.h" -#define PDMA_NR_CH 4 - -#if (PDMA_NR_CH != 4) -#error "Please define PDMA_NR_CH to 4" -#endif +#define PDMA_MAX_NR_CH 4 #define PDMA_BASE_ADDR 0x3000000 #define PDMA_CHAN_OFFSET 0x1000 @@ -118,7 +114,7 @@ struct sf_pdma { void __iomem *membase; void __iomem *mappedbase; u32 n_chans; - struct sf_pdma_chan chans[PDMA_NR_CH]; + struct sf_pdma_chan chans[PDMA_MAX_NR_CH]; }; #endif /* _SF_PDMA_H */ -- 2.31.1