Received: by 2002:a05:6a10:87d6:0:0:0:0 with SMTP id g22csp826082pxr; Mon, 11 Apr 2022 08:09:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx9OIv+7n0x+yZ6Sogdho4G4I32tgXegTFMSD9dTKSq9xABFXCnH8qxw/WKwpRaTHgMp/dY X-Received: by 2002:a17:907:9506:b0:6da:b4cd:515b with SMTP id ew6-20020a170907950600b006dab4cd515bmr30303954ejc.602.1649689767804; Mon, 11 Apr 2022 08:09:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649689767; cv=none; d=google.com; s=arc-20160816; b=n/w1F8x2+0ad6gSz31rj3OhZo1ACRNhbv9Xb6poZKyMlaSP2BoswcLgasAT3tf75cH hkPWMR48mu2BrWFtVjO3XCmZ3gUH19nZfHVqNEtDArYQG/ax+acDouNq+vPiI1WorjwL kde+8fl4cy8wL9j33YCVa8Qczk/2DXvz06CDc31xKhQ5dtL3r8YsXnOjdKEgfIeUVlQk 6C/um9lYL1tD64xEcZj/8eFg/PBf2mmKsRiCAsCa0Bm6bacFEt3zHRQC8mRDLCENmGrS jKRr/paWVMmq2KNrBIbOlaECmp4kiEh8AA25NRL7/HY79T4jWfvJIk8SjakmTB29Wd41 im/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=G71AWZXZjObETDGtSa0xz5SCMG5G0a6fIUnz6vxv3MQ=; b=01KvyiJdv96wHe4qv5wQSmQ7GEhDKsq9OB/h+WNbvW+dIVnw3gHKJ9nJH0H9rvOAVv jUR6Sjnq9R+EnwIkA+xn32cKlmMPRUT1/RQqriQkZxOsporOCR7lpC5y93d4981ye0bt rQyL4gryPVpGTNA9LXLRFdrncAZflBHD6SUolTC9QTBWJgCVh9sCGVMFsQPMWTosb8rx mo6AfoBtK4qhw/4umqxdLTbROFnq+MF9CNST0S3sMYplkkEXGio5hsu9Yhc9OfRPIS92 ixe/vaCFOHgQ2/vwJ+UUY5pOhNG18ATe0tKepjSh6BxeAACYCu4lCu7n3OzlfJ9TECTB gshQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=hGnkuSZc; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b23-20020a17090636d700b006e735df107asi6437750ejc.993.2022.04.11.08.08.59; Mon, 11 Apr 2022 08:09:27 -0700 (PDT) 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=@collabora.com header.s=mail header.b=hGnkuSZc; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S245515AbiDKHiF (ORCPT + 99 others); Mon, 11 Apr 2022 03:38:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59852 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235994AbiDKHiD (ORCPT ); Mon, 11 Apr 2022 03:38:03 -0400 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [46.235.227.227]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 592063D4BF; Mon, 11 Apr 2022 00:35:50 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: dmitry.osipenko) with ESMTPSA id D08861F43081 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1649662548; bh=U8vg0Q5OeV/cifLCFPNn/Ip6ep2b+r7K2V7Yx7UT+d4=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=hGnkuSZcNLkiqBOEU/BhFhrmiDBMpCfCCQhNceN5acMI3eIAYgzXFWiPjdtduBvYL 6N3sjAFVVtgGnfRHN8310jYJdSPG8EcOEoqEBV74HLQxuhBxcYmFpPbByHy/s/MGqd Ru/W/EpqRpp9akU3MjDTa46X7yhKdFp+BOPQe/xCjUtzz/NiCAOlv6xqFOsVLSSRZE reQXEZ422BA+u0dRKEleh6+TaUe4shX9ujNTHZnB24KNof/EYvSP7qbdcswnde4NKI Tg6lALWFhZf3xdfD0htoV0ejZaP2En8xxoUBWGFW8pTzOAFwTUiZrypiB9eT70/vxJ jBzVeE1IRQWDQ== Message-ID: <185f72b6-e6a1-3062-5f36-864973d12ec5@collabora.com> Date: Mon, 11 Apr 2022 10:35:45 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 Subject: Re: [Patch v6 1/4] memory: tegra: Add memory controller channels support Content-Language: en-US To: Ashish Mhetre , Dmitry Osipenko , krzysztof.kozlowski@linaro.org, thierry.reding@gmail.com, jonathanh@nvidia.com, robh+dt@kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, krzysztof.kozlowski+dt@linaro.org Cc: vdumpa@nvidia.com, Snikam@nvidia.com References: <20220406052459.10438-1-amhetre@nvidia.com> <20220406052459.10438-2-amhetre@nvidia.com> <3bbbffff-6aa3-7068-6f0c-4372d53daf94@gmail.com> <0ce65e42-6567-9fd5-d959-3bc5aa0457eb@collabora.com> <16d5c86b-cb04-5f57-7923-724850ce2633@nvidia.com> From: Dmitry Osipenko In-Reply-To: <16d5c86b-cb04-5f57-7923-724850ce2633@nvidia.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-5.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,SPF_HELO_PASS, SPF_PASS,T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY autolearn=ham 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 On 4/11/22 10:28, Ashish Mhetre wrote: > > > On 4/11/2022 12:03 PM, Dmitry Osipenko wrote: >> External email: Use caution opening links or attachments >> >> >> On 4/11/22 09:05, Ashish Mhetre wrote: >>> >>> >>> On 4/10/2022 7:48 PM, Dmitry Osipenko wrote: >>>> External email: Use caution opening links or attachments >>>> >>>> >>>> 06.04.2022 08:24, Ashish Mhetre пишет: >>>>> +     num_dt_channels = >>>>> of_property_count_elems_of_size(pdev->dev.of_node, "reg", >>>>> +                                                       reg_cells * >>>>> sizeof(u32)); >>>>> +     /* >>>>> +      * On tegra186 onwards, memory controller support multiple >>>>> channels. >>>>> +      * Apart from regular memory controller channels, there is one >>>>> broadcast >>>>> +      * channel and one for stream-id registers. >>>>> +      */ >>>>> +     if (num_dt_channels < mc->soc->num_channels + 2) { >>>>> +             dev_warn(&pdev->dev, "MC channels are missing, please >>>>> update memory controller DT node with MC channels\n"); >>>>> +             return 0; >>>>> +     } >>>>> + >>>>> +     mc->bcast_ch_regs = devm_platform_ioremap_resource_byname(pdev, >>>>> "mc-broadcast"); >>>>> +     if (IS_ERR(mc->bcast_ch_regs)) >>>>> +             return PTR_ERR(mc->bcast_ch_regs); >>>> >>>> Looks to me that you don't need to use >>>> of_property_count_elems_of_size() >>>> and could only check the "mc-broadcast" presence to decide whether this >>>> is an older DT. >>>> >>> Now that we are using reg-names in new DT, yes it'd be fine to just >>> check mc-broadcast to decide it's a new or old DT. >>> >>>> mc->bcast_ch_regs = devm_platform_ioremap_resource_byname(pdev, >>>> "broadcast"); >>>> if (IS_ERR(mc->bcast_ch_regs)) { >>>>           dev_warn(&pdev->dev, "Broadcast channel is missing, please >>>> update your >>>> device-tree\n"); >>>>           return PTR_ERR(mc->bcast_ch_regs); >>>> } >>> >>> return 0; >>> >>> to avoid DT ABI break, right? >> >> Yes, it should be "return 0". > > But if we "return 0" from here, then what about the case when ioremap() > actually fails with new DT i.e. when broadcast reg is present in DT? > In that case error should be returned and probe should be failed, right? You should check for the -ENOENT.