Received: by 2002:a25:5b86:0:0:0:0:0 with SMTP id p128csp553230ybb; Thu, 28 Mar 2019 07:42:30 -0700 (PDT) X-Google-Smtp-Source: APXvYqxjyvH0ajY0gh0/P4GpoH0558ABcjSM4gTUHBIODFuJdGXuMEoGEWcz10seQDrQdx6wBoer X-Received: by 2002:a62:29c5:: with SMTP id p188mr40458778pfp.203.1553784150627; Thu, 28 Mar 2019 07:42:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553784150; cv=none; d=google.com; s=arc-20160816; b=DQOAYL4vwu+IYuCTcNLbtkjeYivCbLTySGwP4SLdImeBcaUXKC8r0+BtzqXLLO4T6a NFVTs5JYrRptv1g06K33kwX7zWW3MigSYossvgjl4oyEkGA23QC8hcUXrH3jM26ZmjMW 0Qcv8GMj/Sn34KjnHmAoRZKquX+Wba+0j3vswvQy7T3TSAfbBUwUO3Wa2cU/6NhZvDH1 +nvuKwsWg2+o5qkO+ZCR4pNibQXzDGVZEFnpyATQx3vEhSNJRKUGHZJLmJqJk1fZr2y3 7ffjyUxhGaeknU+/ncI6oGWK5rfY80XxyKcVoGDX76pKJpM2rlXph1Fm6QxAyGA0wIfP gquA== 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:dkim-signature; bh=su5hUDVGA5wTPt+GZUHCzxW06LCBzo43uhfJs0GTLis=; b=tRjoQq+s+vgbmFwNsb0mlH00iFaXyo3I/7zssh0rXOnVbLncIgwIwAKOcUz1hmCxrm qU+5pory8viMdHY5TXWT1YpYNJVLhj5zv5qfBRnOfZAp2LRPSzOVOR5/+aq7QdM0ekd4 fT9B3e3U7hUCewB6yeamT1iT5L6fLnWs4HFqQ6Toed+L1JRSEK93Gb5S4hH7lFn1c/3t SvcULPrZg3b89AcLUR1sMRyFGvHq2zSYlGglfGSYKcvxVfDVTwlPebdS//0GxUdgqPT5 fO42/TGavnytGeUjx9qMzpJuNJbaDjXYIzkA0WW92B6VSs6Ew26RzO+cdHJ7+RQVpkh2 D4PA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=OoQhSR+i; 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 q4si7557479pfh.157.2019.03.28.07.42.13; Thu, 28 Mar 2019 07:42:30 -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=@joelfernandes.org header.s=google header.b=OoQhSR+i; 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 S1726286AbfC1OkC (ORCPT + 99 others); Thu, 28 Mar 2019 10:40:02 -0400 Received: from mail-pg1-f194.google.com ([209.85.215.194]:42688 "EHLO mail-pg1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725849AbfC1OkB (ORCPT ); Thu, 28 Mar 2019 10:40:01 -0400 Received: by mail-pg1-f194.google.com with SMTP id p6so11708616pgh.9 for ; Thu, 28 Mar 2019 07:40:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=su5hUDVGA5wTPt+GZUHCzxW06LCBzo43uhfJs0GTLis=; b=OoQhSR+iKkIWNr/jpeg6QvhAN51oCNMtZeMAz9aSGP40ppc0YnS4WUELW3lhUwjUeZ ndcoFzMd5GGap1GCgZ8SwCddCu2saRDJ6ok2+/ZGJHRNgpkliRHHJfgnZ+ahNvrjs5KW 9WX+Vv5N3ASKe4fayeObXHa/jkv9B8JymoGL8= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=su5hUDVGA5wTPt+GZUHCzxW06LCBzo43uhfJs0GTLis=; b=lLOlNdwqY8bVY0BE/yIAprcnUMOQiYClduZkDza9fXGsBFCelZXzVUs47wBuRhNHCM 1ducWsIRAMRaUnXGZDYWkY6tzlvIqCKSHl6dG1vHAHs8UMJlPS0sK/M/Jp4TntxXGFH9 hhfPdUX1JqcPx5O+CFTqqW+oDCLkfq7GO8cAMVU0P8W+F4an3lpBERzjpWr0IjHekkn+ vRFF5nUrkoa1C0529+CO/MpiqUgJ6Sym4HiGE6qzQJ4ELG52GBajLgVXhhSCXqBx8snj 2cBfMAwK5zHbsINPKVu5qgBu/8yHVP/RVcJTrFg3+j9lCSKYm2MzNvF5trC/u+tb/AmB MMbw== X-Gm-Message-State: APjAAAVwVO/upor/mnPzccbNTR2GfQ3nn4EH9Es5g52KjV+jLyikV1+D MHjAnihD9ftiBtbMjirc1CTxJA== X-Received: by 2002:a65:6383:: with SMTP id h3mr39458734pgv.11.1553784000843; Thu, 28 Mar 2019 07:40:00 -0700 (PDT) Received: from localhost ([2620:15c:6:12:9c46:e0da:efbf:69cc]) by smtp.gmail.com with ESMTPSA id u13sm49809367pfa.169.2019.03.28.07.39.59 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 28 Mar 2019 07:40:00 -0700 (PDT) Date: Thu, 28 Mar 2019 10:39:58 -0400 From: Joel Fernandes To: Oleg Nesterov Cc: Jann Horn , Kees Cook , "Eric W. Biederman" , LKML , Android Kernel Team , Kernel Hardening , Andrew Morton , Matthew Wilcox , Michal Hocko , "Reshetova, Elena" Subject: Re: [PATCH] Convert struct pid count to refcount_t Message-ID: <20190328143958.GB261521@google.com> References: <20190327145331.215360-1-joel@joelfernandes.org> <20190328023432.GA93275@google.com> <20190328142619.GA19441@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190328142619.GA19441@redhat.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Mar 28, 2019 at 03:26:19PM +0100, Oleg Nesterov wrote: > On 03/27, Joel Fernandes wrote: > > > > Also, based on Kees comment, I think it appears to me that get_pid and > > put_pid can race in this way in the original code right? > > > > get_pid put_pid > > > > atomic_dec_and_test returns 1 > > atomic_inc > > kfree > > > > deref pid /* boom */ > > ------------------------------------------------- > > > > I think get_pid needs to call atomic_inc_not_zero() > > No. > > get_pid() should only be used if you already have a reference or you do > something like > > rcu_read_lock(); > pid = find_vpid(); > get_pid(); > rcu_read_lock(); > > in this case we rely on call_rcu(delayed_put_pid) which drops the initial > reference. > > If put_pid() sees pid->count == 1, then a) nobody else has a reference and > b) nobody else can find this pid on rcu-protected lists, so it is safe to > free it. I agree. Check my reply to Jann, I already replied to him about this. thanks!