Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp4337188pxk; Tue, 29 Sep 2020 23:35:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxM2E0cRQPz/mlXQZL4Vo98G6fnalXf5OCQmuuSDMjcmPblNf9qw2C2bMe7R0xYl23J3+wT X-Received: by 2002:a50:c8cd:: with SMTP id k13mr1078418edh.387.1601447718770; Tue, 29 Sep 2020 23:35:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601447718; cv=none; d=google.com; s=arc-20160816; b=Pt7hIa+kcVH0HYmeHRooUH7EoQsMo2bBxGyQYHU/xITkmMJI9urJjfguM4m1M3AtPT UIhUyu4Wu9pev6c1A6unWfUhxP+AQASKvEvlDb3pr41XtJiWGbufgTv46QHzoDmUAMwq RW/hmGC7/Xkl7G2/HwFIRt29jc5oR4FHApFn2vYBxyAvnVprLZEBGllO5+3R/yHiKZiO BPKZbyeerrwRosOqX0CT2GR3yusKyQ8AThvNsNLljcthNXQBPvO0/xqfFxZ0a5BX6jAg Sk4NHzNoNQe18UsMGn9KOCiqxEMfln3lY0lgEzp+AktjkqHE2FTuSw+xCGVqv0706dFb rhQA== 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:dkim-signature; bh=cTva/fInjcmUyKGUHD5UOEzgklOiXw7AjHa/QF4Vx2o=; b=Em1NBpnS8dhVXaS5cErU2XRIJQDZ8F6D7Y8Idx+8NWPzpLWRPwNvm9HZ18kuW9MUO7 UtktaBr965NBCNxYzxFHBOeNXLZx3TLzdf41GL5pRY36oooCm1Wd5ttTXU/JiIJY2Spp XO7KBrINfzM82ezI+k3uiwc0hmmWaXf+PDP3ZIbW1xFO5Ow41w0MZcwIVjc2EjkOpkLb N4Z78hmTtXqBq0eLKUKVFf9SWFuzinYdSr0LrEFLuybtTmY/kL1anXHIrXkOuEFij7lk 3zsPNQWXXz3lq2mbX8HZpEONxhzVEHXSUcdOOW1En4HnXJVlBg4DAIvEhxWHJTIRXVk0 Wakg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=CCNo5Ppl; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id sa19si543589ejb.506.2020.09.29.23.34.55; Tue, 29 Sep 2020 23:35:18 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=CCNo5Ppl; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725779AbgI3Gdk (ORCPT + 99 others); Wed, 30 Sep 2020 02:33:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44380 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725320AbgI3Gdk (ORCPT ); Wed, 30 Sep 2020 02:33:40 -0400 Received: from mail-lf1-x142.google.com (mail-lf1-x142.google.com [IPv6:2a00:1450:4864:20::142]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BDCF2C061755; Tue, 29 Sep 2020 23:33:39 -0700 (PDT) Received: by mail-lf1-x142.google.com with SMTP id u8so774975lff.1; Tue, 29 Sep 2020 23:33:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=cTva/fInjcmUyKGUHD5UOEzgklOiXw7AjHa/QF4Vx2o=; b=CCNo5PplUtPPi6hvkBl6F9bub4USTbO5JvgHVgT1X5BVj3LGff7Dfx0zVE36yF6jsk EevUSHH76pmO9GHACimTSPiepjdECfbF+FSph4NY4SsWItrN3mMq/E3ISASD8YqB7mes bfBPJoYq9jnKrJ5topoPVjTcVDFvIn67JgvNKBsTDjWwoZtqrNIZBS4dkr7f2hKvgT1l Vh3eX2twDk6BoYYdJO2bf2CR96XuspruFSnno5A5Rw0pgL710/ULvgtl6EqlwHFMSotf 7Kf87PN001Cys7rpolS5q6notSIu4yz/07tReFBJsWdZ/vyRpfaLJj4IImLV6sKnB3tp 3nlg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=cTva/fInjcmUyKGUHD5UOEzgklOiXw7AjHa/QF4Vx2o=; b=RyaR496f1qmG2789PW4wcI587CmWApVfzlpikp+A63L4OuL1wNtMOGN1bZn4ve1gAa TAiDJNOWEsK+DgKmbfLXgT3dLKZQKCYrKRkWxllCHEw/hh4jmXtIdXl3LWR+lDm7Zda4 WMj34OVK2pdp9kXN48IUW+U1FXaBrFS8DNn5JR6Ths2JOh8PTv3qmqg/+OJWF9M8XvpW tLwwHeGp8VMp4KL0c3Qi7xIp5LtVOtKWJpRTHQs9pVnkdQ0hSMQ3J5FMJheQuRETs5hT vV1q0q6iM+UN6IYAMHJnGL6koqIsMhIO+StUH8k/+k9rELJgP8szrqWWVVKjaxfiHzN2 b/AA== X-Gm-Message-State: AOAM533j/b6Lf32yTvoKmPwe5iC+3CRiiHVE9rjvqTEdp+80/mFCIO+B +wv6dgzzeNI/Yi8xTRQQXGIgTYcCtRI= X-Received: by 2002:ac2:5dd4:: with SMTP id x20mr304525lfq.593.1601447618031; Tue, 29 Sep 2020 23:33:38 -0700 (PDT) Received: from [192.168.2.145] (109-252-170-211.dynamic.spd-mgts.ru. [109.252.170.211]) by smtp.googlemail.com with ESMTPSA id m13sm73838lfl.269.2020.09.29.23.33.37 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 29 Sep 2020 23:33:37 -0700 (PDT) Subject: Re: [PATCH v2 2/3] iommu/tegra-smmu: Rework .probe_device and .attach_dev To: Nicolin Chen Cc: thierry.reding@gmail.com, joro@8bytes.org, krzk@kernel.org, vdumpa@nvidia.com, jonathanh@nvidia.com, linux-tegra@vger.kernel.org, iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org References: <20200930003013.31289-1-nicoleotsuka@gmail.com> <20200930003013.31289-3-nicoleotsuka@gmail.com> <75514da5-e63a-9e51-8376-abbd12c324d1@gmail.com> <20200930054900.GG31821@Asurada-Nvidia> <20200930061351.GA16460@Asurada-Nvidia> From: Dmitry Osipenko Message-ID: <9a1ec0bf-3020-2045-229c-a350c9c9fc2e@gmail.com> Date: Wed, 30 Sep 2020 09:33:36 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <20200930061351.GA16460@Asurada-Nvidia> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 30.09.2020 09:13, Nicolin Chen пишет: > On Wed, Sep 30, 2020 at 09:10:38AM +0300, Dmitry Osipenko wrote: >> 30.09.2020 08:49, Nicolin Chen пишет: >>> On Wed, Sep 30, 2020 at 08:11:52AM +0300, Dmitry Osipenko wrote: >>>> 30.09.2020 03:30, Nicolin Chen пишет: >>>>> + /* An invalid mc pointer means mc and smmu drivers are not ready */ >>>>> + if (IS_ERR_OR_NULL(mc)) >>>> >>>> tegra_get_memory_controller() doesn't return NULL. >>> >>> Well, I don't want to assume that it'd do that forever, and the >>> NULL check of IS_ERR_OR_NULL is marked "unlikely" so it doesn't >>> hurt to have. >>> >> >> I don't see any reasons why it won't do that forever. >> >> Secondly, public function can't be changed randomly without updating all >> the callers. >> >> Hence there is no need to handle cases that can't ever happen and it >> hurts readability of the code + original error code is missed. > > I don't quite understand why an extra "_OR_NULL" would hurt > readability....but I'd take a step back and use IS_ERR(). > The tegra_get_memory_controller() doesn't return NULL, hence the NULL-check is misleading. If I was reading that code for the first time and notice such a thing, then instantly I'd have a much lower credibility to the whole code.