Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3460511pxv; Mon, 19 Jul 2021 00:08:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw7sRLtax2gzpDIg4bJ1wCTekW60HfE2pXbkTVMBAlwTECbX3G17p5r8GpdWlWur+J+H8t9 X-Received: by 2002:a05:6402:1d4d:: with SMTP id dz13mr32764266edb.67.1626678495346; Mon, 19 Jul 2021 00:08:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626678495; cv=none; d=google.com; s=arc-20160816; b=Dti1cfKXSP7tv2omOHBMCABMgJJZo+oXb8xHDv4M6x99SC3rM1Y2Z2fe2Wf3tBtrBx 6SEF2RPnpSZEK2cr1/5WgLv+Ggj299srn6O0VFyfuKsE7Zv/fW1QLTz8duXEIiS3Qn3A PDMBQKW2Ig7w6afgWkGMGHoCUHlsR6ApFgIt/1GuY4LhnV93EFRbmJW1gfIbe3QamCOX H+K1bYtZS4EkOI9++wjtWVdT6qJc671ijp6d549mLbLlg7mVWbiZlmj86lOOUTIikByB ccbwcXEq4uUylrMqXtfAwWsqVIslPFfYhkhMoSkEaoRpIRM/b/fMVSQmMsoio27jXub5 6vTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=QOcmTtUBp1SwsgY2TlSnpCfPfylmTKRxaGAq/NLKxic=; b=xM3MtusrGFMyoPfXsDML2o8AqI/jMWcQ42sCHNjqubb6PPurmVVRSeAuQAk+rBlU5A kUSPq20WyEpJPTcwWABHyZwMr7/HL2E22rE6l8nCXmqXAlyvAcJiPu/snrQQDHYBF7XB w2+pCnFSd2ZRF3hgnXHx1Ge19seADInaXOuGkrz1EOYh8QRH+U1Gw/WUXcO3xaMCVVxy pPw3dg4fQ1IVYKb0f6YGy9pER4U/XhLt1FaJlVofpSzpKmS54/gdkLVen6UORsNSAhVB CXU7kRCsjkGVIwRw5n5b+iGhHyNZJfbxreYU1PpI6ped9L3LFaLTxEDNlXMLlZcBqK+h AWKA== 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=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h20si19588195ejt.70.2021.07.19.00.07.52; Mon, 19 Jul 2021 00:08:15 -0700 (PDT) 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=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234753AbhGSHJq (ORCPT + 99 others); Mon, 19 Jul 2021 03:09:46 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:60836 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234441AbhGSHJo (ORCPT ); Mon, 19 Jul 2021 03:09:44 -0400 Received: from [IPv6:2a02:810a:880:f54:121:b44d:bc4b:65bc] (unknown [IPv6:2a02:810a:880:f54:121:b44d:bc4b:65bc]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: dafna) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id E4B571F422EC; Mon, 19 Jul 2021 08:06:43 +0100 (BST) Subject: Re: [PATCH v2, 01/14] media: mtk-vcodec: Get numbers of register bases from DT To: Yunfei Dong , Alexandre Courbot , Hans Verkuil , Tzung-Bi Shih , Tiffany Lin , Andrew-CT Chen , Mauro Carvalho Chehab , Rob Herring , Matthias Brugger , Tomasz Figa Cc: Hsin-Yi Wang , Fritz Koenig , Irui Wang , linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, srv_heupstream@mediatek.com, linux-mediatek@lists.infradead.org, Project_Global_Chrome_Upstream_Group@mediatek.com, Collabora Kernel ML , Enric Balletbo i Serra References: <20210717081233.7809-1-yunfei.dong@mediatek.com> <20210717081233.7809-2-yunfei.dong@mediatek.com> From: Dafna Hirschfeld Message-ID: <77ec9eec-0b93-102c-4e6e-a1a491d0ae7a@collabora.com> Date: Mon, 19 Jul 2021 09:06:41 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: <20210717081233.7809-2-yunfei.dong@mediatek.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 17.07.21 10:12, Yunfei Dong wrote: > Different platform may has different numbers of register bases. Gets the > numbers of register bases from DT (sizeof(u32) * 4 bytes for each). > > Signed-off-by: Yunfei Dong > --- > v2: no changes > --- > .../platform/mtk-vcodec/mtk_vcodec_dec_drv.c | 38 ++++++++++++++----- > 1 file changed, 29 insertions(+), 9 deletions(-) > > diff --git a/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c b/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c > index 55ae198dbcf9..d3f34cd04759 100644 > --- a/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c > +++ b/drivers/media/platform/mtk-vcodec/mtk_vcodec_dec_drv.c > @@ -78,6 +78,31 @@ static irqreturn_t mtk_vcodec_dec_irq_handler(int irq, void *priv) > return IRQ_HANDLED; > } > > +static int mtk_vcodec_get_reg_bases(struct mtk_vcodec_dev *dev) > +{ > + struct platform_device *pdev = dev->plat_dev; > + int reg_num, i, ret = 0; > + > + /* Sizeof(u32) * 4 bytes for each register base. */ > + reg_num = of_property_count_elems_of_size(pdev->dev.of_node, "reg", > + sizeof(u32) * 4); 'reg_num' can also be negative if the 'of_..' function fails. So this case should also be checked > + if (!reg_num || reg_num > NUM_MAX_VDEC_REG_BASE) { > + dev_err(&pdev->dev, "Invalid register property size: %d\n", reg_num); > + return -EINVAL; > + } > + > + for (i = 0; i < reg_num; i++) { > + dev->reg_base[i] = devm_platform_ioremap_resource(pdev, i); > + if (IS_ERR((__force void *)dev->reg_base[i])) { > + ret = PTR_ERR((__force void *)dev->reg_base[i]); > + break; you can replace this two lines with "return PTR_ERR((__force void *)dev->reg_base[i]);" thanks, Dafna > + } > + mtk_v4l2_debug(2, "reg[%d] base=%p", i, dev->reg_base[i]); > + } > + > + return ret; > +} > + > static int fops_vcodec_open(struct file *file) > { > struct mtk_vcodec_dev *dev = video_drvdata(file); > @@ -206,7 +231,7 @@ static int mtk_vcodec_probe(struct platform_device *pdev) > struct resource *res; > phandle rproc_phandle; > enum mtk_vcodec_fw_type fw_type; > - int i, ret; > + int ret; > > dev = devm_kzalloc(&pdev->dev, sizeof(*dev), GFP_KERNEL); > if (!dev) > @@ -238,14 +263,9 @@ static int mtk_vcodec_probe(struct platform_device *pdev) > goto err_dec_pm; > } > > - for (i = 0; i < NUM_MAX_VDEC_REG_BASE; i++) { > - dev->reg_base[i] = devm_platform_ioremap_resource(pdev, i); > - if (IS_ERR((__force void *)dev->reg_base[i])) { > - ret = PTR_ERR((__force void *)dev->reg_base[i]); > - goto err_res; > - } > - mtk_v4l2_debug(2, "reg[%d] base=%p", i, dev->reg_base[i]); > - } > + ret = mtk_vcodec_get_reg_bases(dev); > + if (ret) > + goto err_res; > > res = platform_get_resource(pdev, IORESOURCE_IRQ, 0); > if (res == NULL) { >