Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp4745371ybp; Mon, 14 Oct 2019 09:21:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqy+/eW6AmTcec2cNsTB//0+f8C22DOvM0uMQfawnCFvdkQOUB1mr9JhEpTBanMvFZQ0RkKw X-Received: by 2002:a17:906:3582:: with SMTP id o2mr7307770ejb.54.1571070107696; Mon, 14 Oct 2019 09:21:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571070107; cv=none; d=google.com; s=arc-20160816; b=R/bIhz6IWgc8XLHJlX56VEeV2v0G2OTubarDISNgW5koIGKG5I219Q0OyYGY7tpxvz Zg586plvZKhlmwlwcrjxHt6yx8mcPrv0LBxQxTnMm3lL4MstuEWJFabEN7/IGE4tS06a BdBiwKcAZRV5xNr28ZWVB/VD3NgeelPUYtGmkaf91T7nzUcfhEXaYXkOgyidAqKKiXve DxIUV3G3OZqckUisrh1Lj3rratmaIHMo49PmxXsfnYlZN+gMSopPs7Q0Qoi+ieD4Fism 9llJdW3ic/QzdBiL1/kyaorxsM7mutzx8TLRMuD0CrrCs//hGBebCG6XDr1Qlmlo15FX HcXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=hUnyvpuP6/HkBMSiwtb5MS7vmorhboIr5Cucxcuf8O4=; b=EUyzC92fkddXWmjQlvHTxSV0FFN6H3GcIHa7tSK7mpUzUDgKZ/80PKPtNn9LTNn8Rd w+3hiDYND+udJOCZconH5VqLP351bo2Lion2uNdcL54AyBmpIpnyOUeVdEyyXMkcPl2m lrxEzFVGRJjOtga1RwYHUehh78ja80IVZr3UDbfbOXA2X/1DGS1Gxxb8n8IQEPQsQg0x VkuXab1p53p7+INIjnYEepN0S9zW7HKdga8UWTKgiGMxrpFfL2yqlwgLo6As4tJoeid9 vlC15Y9xXm9wzfKUbQW+23KK1WaHz2QyNoxVqeywZAjrtls8b0uWEjTElWTh6Ixy8TmX +b8A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=tf3Get4q; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h13si13228728edh.242.2019.10.14.09.21.24; Mon, 14 Oct 2019 09:21:47 -0700 (PDT) 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; dkim=pass header.i=@google.com header.s=20161025 header.b=tf3Get4q; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387644AbfJNPjQ (ORCPT + 99 others); Mon, 14 Oct 2019 11:39:16 -0400 Received: from mail-oi1-f195.google.com ([209.85.167.195]:33370 "EHLO mail-oi1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730005AbfJNPjP (ORCPT ); Mon, 14 Oct 2019 11:39:15 -0400 Received: by mail-oi1-f195.google.com with SMTP id a15so14133510oic.0 for ; Mon, 14 Oct 2019 08:39:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=hUnyvpuP6/HkBMSiwtb5MS7vmorhboIr5Cucxcuf8O4=; b=tf3Get4qoIzO39iWyOCRegFp1wY/dzAobHeBdf2VA+8pw3oS7q1F2IvIw6nkg3OFX8 F52Y2qTRW1vOzUC69B3PjcYdqNMNkS8ARtcRvIhTZhp0Y9EvPL3iiCtc3KuWJUMDZBbr 4KjUbkltVWZcLU3sPz2wnmO7B8UNdUOXLyK3DcO+64luJBp44YYRzG3XBXo+PPoIvusg aMefEtXMJnH1iBF71IodEUiM/Q1k0gqyau8N9LGuq7lcmSrtL8I1gGq0Pn5RjwpM3+hS i1FPYiz/Ahj0pNmlgA1mBNABGuSVs+2gCKHOWqwIa871YMYgf/FRN55VJS4lUKxCsi5B 0WZQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=hUnyvpuP6/HkBMSiwtb5MS7vmorhboIr5Cucxcuf8O4=; b=VXFTE7beO9c0IMuHRSkHTCmsZKmpVQgm3bRIR04tZQ858vEo0x+BZptGgN+gkgsflB FioPSocOTFOzdFkrjf/u+fnpPJ7Cos03GTTHXu2CueQGJYWPpE4IvESS5pTsyb4MoDbH 9kqnPqWSnKE6QlRXTRWHHdzTmSGJFk8BaW6kJFVmbyINq7XbjA/88XamWuv0qQDUqvm/ 3IOHIG1rki38s/c724YldwezS1jazODoFjx023PYar1Dcbt9KkHUAPzuK7jzvNtbTYSg /TrUVulUoKCp5Df8mcPPeQ3iS6HAoxAT1E1cqC44Nbwd4lvCRsdvX4cnPOEZGZN/T85u wsWA== X-Gm-Message-State: APjAAAWAsPIvpRCwEYJrGux3r+cZqD3OrrUNNoJO5aYuQ93+1lTQ4LPx u93wpFwDIXx3G7wmhBC9j/SLVGrRAUeyZR8EQ891eA== X-Received: by 2002:aca:da41:: with SMTP id r62mr24035154oig.47.1571067553182; Mon, 14 Oct 2019 08:39:13 -0700 (PDT) MIME-Version: 1.0 References: <20191012191602.45649-1-dancol@google.com> <20191012191602.45649-2-dancol@google.com> In-Reply-To: <20191012191602.45649-2-dancol@google.com> From: Jann Horn Date: Mon, 14 Oct 2019 17:38:45 +0200 Message-ID: Subject: Re: [PATCH 1/7] Add a new flags-accepting interface for anonymous inodes To: Daniel Colascione Cc: Linux API , kernel list , Lokesh Gidra , Nick Kralevich , nosh@google.com, Tim Murray Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Oct 12, 2019 at 9:16 PM Daniel Colascione wrote: > Add functions forwarding from the old names to the new ones so we > don't need to change any callers. This patch does more than the commit message says; it also refactors the body of the function. (I would've moved that refactoring over into patch 2, but I guess this works, too.) [...] > -struct file *anon_inode_getfile(const char *name, > - const struct file_operations *fops, > - void *priv, int flags) > +struct file *anon_inode_getfile2(const char *name, > + const struct file_operations *fops, > + void *priv, int flags, int anon_inode_flags) (AFAIK, normal kernel style is to slap a "__" prefix in front of the function name instead of appending a digit, but I guess it doesn't really matter.) > { > + struct inode *inode; > struct file *file; > > - if (IS_ERR(anon_inode_inode)) > - return ERR_PTR(-ENODEV); > - > - if (fops->owner && !try_module_get(fops->owner)) > - return ERR_PTR(-ENOENT); > + if (anon_inode_flags) > + return ERR_PTR(-EINVAL); > > + inode = anon_inode_inode; > + if (IS_ERR(inode)) > + return ERR_PTR(-ENODEV); > /* > - * We know the anon_inode inode count is always greater than zero, > - * so ihold() is safe. > + * We know the anon_inode inode count is always > + * greater than zero, so ihold() is safe. > */ This looks like maybe you started editing the comment, then un-did the change, but left the modified line wrapping in your patch? Please avoid that - code changes with no real reason make "git blame" output more annoying and create trouble when porting patches between kernel versions. [...] > EXPORT_SYMBOL_GPL(anon_inode_getfile); > +EXPORT_SYMBOL_GPL(anon_inode_getfile2); [...] > EXPORT_SYMBOL_GPL(anon_inode_getfd); > +EXPORT_SYMBOL_GPL(anon_inode_getfd2); Since anon_inode_getfd() is now a static inline function in include/linux/anon_inodes.h, exporting it doesn't make sense anymore. Same for anon_inode_getfile(). [...] > +#define ANON_INODE_SECURE 1 That #define belongs in a later patch, right?