Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp36738ybc; Fri, 15 Nov 2019 16:39:38 -0800 (PST) X-Google-Smtp-Source: APXvYqw1niIZtg4uXQS/UXglGcLwnyc9tequM35weib8hmrsJ6wOxwT5n13X0EgzISrHfM/c97cr X-Received: by 2002:a7b:c7d3:: with SMTP id z19mr18549279wmk.98.1573864778351; Fri, 15 Nov 2019 16:39:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573864778; cv=none; d=google.com; s=arc-20160816; b=vt7EcOzAX6IpeISeahLkg4HlMWDGtHHz0S0sEWOu8L32FSTrn7Z0tjA09j8QZhIl+M NzsUb0rcZKj/z0LmPykoZtHWWV1HULX++yid0txu6okxLPtVKOgLPBsVawqsB3G0Q5lu nc9eRuTtFwrH2STHO2OR6OYtVgj7UxBqlmkQPduE9TR7F0hWKHkQ09ZowLbq+KvHeZVq UMzToWNgyUDqnRSvHwyK2uVuOLPY0P5eDHC32itx+CtwLjjW6iBYEk4XE5XTXBjsRGUq awdmGXfdG8kAeyLHZB2IcTly30vAR5bn2cOmyme/nWgRupM2ROtn+pkuo+G35Tj2KgeR GHbA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=L5L5vmh25KVgcDygJVO2Lc0GTQ2fGqDcL8it1b2ztWY=; b=ERpbXcCJ3yprdvJC5ZIDJ5znMwv9y1Rrh3xlgSUyg4rVeUaRQJFw32GQyB+NHzrOe4 j2VJqjPjpJEn/vr7SbCaqPgPkd/TH4pkXb4up28ZQjjh/nxGdFWVwxAX45guqjiHG+6Z dFG4xe8JeI9KgaYIT26mDr4rv4ZSA4rKKeWH6HIksKADdKaKtz7jT63kPgLMXMT2NHWn 6DJfMSYFkmWxFnyv+zC5HnPRc8rf7Qisf74wmQWyy1msvLP9mByHDWTAk5OgZJcKj2K4 ty/ZAwfIdaAyBf6GEevK1ozgk7Y/86jan33QRPRnYfB4yqO/nyNlS3Q1L8EIqz9roX3E nK4g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o3si9153348edi.374.2019.11.15.16.39.13; Fri, 15 Nov 2019 16:39:38 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727485AbfKPAiK (ORCPT + 99 others); Fri, 15 Nov 2019 19:38:10 -0500 Received: from zeniv.linux.org.uk ([195.92.253.2]:43390 "EHLO ZenIV.linux.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727151AbfKPAiJ (ORCPT ); Fri, 15 Nov 2019 19:38:09 -0500 Received: from viro by ZenIV.linux.org.uk with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1iVm5G-00041D-QH; Sat, 16 Nov 2019 00:37:02 +0000 Date: Sat, 16 Nov 2019 00:37:02 +0000 From: Al Viro To: Aleksa Sarai Cc: Jeff Layton , "J. Bruce Fields" , Arnd Bergmann , David Howells , Shuah Khan , Shuah Khan , Ingo Molnar , Peter Zijlstra , Alexei Starovoitov , Daniel Borkmann , Martin KaFai Lau , Song Liu , Yonghong Song , Andrii Nakryiko , Eric Biederman , Andy Lutomirski , Andrew Morton , Kees Cook , Jann Horn , Tycho Andersen , David Drysdale , Chanho Min , Oleg Nesterov , Rasmus Villemoes , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Christian Brauner , Aleksa Sarai , Linus Torvalds , dev@opencontainers.org, containers@lists.linux-foundation.org, bpf@vger.kernel.org, netdev@vger.kernel.org, linux-alpha@vger.kernel.org, linux-api@vger.kernel.org, libc-alpha@sourceware.org, linux-arch@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-fsdevel@vger.kernel.org, linux-ia64@vger.kernel.org, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-m68k@lists.linux-m68k.org, linux-mips@vger.kernel.org, linux-parisc@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-s390@vger.kernel.org, linux-sh@vger.kernel.org, linux-xtensa@linux-xtensa.org, sparclinux@vger.kernel.org Subject: Re: [PATCH v16 02/12] namei: allow nd_jump_link() to produce errors Message-ID: <20191116003702.GX26530@ZenIV.linux.org.uk> References: <20191116002802.6663-1-cyphar@cyphar.com> <20191116002802.6663-3-cyphar@cyphar.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20191116002802.6663-3-cyphar@cyphar.com> User-Agent: Mutt/1.12.1 (2019-06-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Nov 16, 2019 at 11:27:52AM +1100, Aleksa Sarai wrote: > + error = nd_jump_link(&path); > + if (error) > + path_put(&path); > + error = nd_jump_link(&ns_path); > + if (error) > + path_put(&ns_path); > + error = nd_jump_link(&path); > + if (error) > + path_put(&path); 3 calls. Exact same boilerplate in each to handle a failure case. Which spells "wrong calling conventions"; it's absolutely clear that we want that path_put() inside nd_jump_link(). The rule should be this: reference that used to be held in *path is consumed in any case. On success it goes into nd->path, on error it's just dropped, but in any case, the caller has the same refcounting environment to deal with. If you need the same boilerplate cleanup on failure again and again, the calling conventions are wrong and need to be fixed. And I'm not sure that int is the right return type here, to be honest. void * might be better - return ERR_PTR() or NULL, so that the value could be used as return value of ->get_link() that calls that thing.