Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp3404405ybn; Fri, 27 Sep 2019 06:00:58 -0700 (PDT) X-Google-Smtp-Source: APXvYqxH6AGeUaeHcUoKG715xbvaMj4TotTbsjhaRhq9eBkX0gCgTTO9n9KnhCdrEiR7srTzQjve X-Received: by 2002:a50:cf0d:: with SMTP id c13mr2525660edk.125.1569589258551; Fri, 27 Sep 2019 06:00:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569589258; cv=none; d=google.com; s=arc-20160816; b=lutBWpt594/YKhnOjWiGOHFDHFqgWG2QoEa949STzBw5Eec3Gj1DXtqvoKo+jbgqlX ZHKA0I7aFlyyS2SgDiBjjYe5r13mLVkE65bE8+0X8Un1IyvFW4oxfsiqY9nt5VIHY4Gn 9iv+fPIq69oTzRuX7tMrsbTgrSQtrfSlE2Z6UyylAn0s9FuaamKYEgLn83xpB4fIhAWo 2McFn5V/9mL1d3q+Iz90+aKL8pXgkDgNHdoXQ9yT0ufQBVDjch0Y/wn+k+LjXVngqD2j rAM18Qly5AW8FgccnMXDxwcVJjfSVxmwx02tu+NhOvsc7WuBWIv7RQ1QIFEsugbEyNP9 kYWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date; bh=ISYRUfvrXHDffrYtE1Ot7aFc9jlDMUythIX4yrRq3/A=; b=EwARGTgDGJzi6aWCw2J6k/n0UA9SMvuJP4QkrVAtCoIe/kBpKN48VNZ7r1vdSgLMbw D/FMumBNmSQl4pD2/YvKe/GDTkZ+yfSzWrX1qRO8HTteqWQmCgwnDGGuddbOs2wR48zX YZENGd6rtdvgTEV7QXnrTs5cnkRQnqJtin6GlVPBT5wGPVYcpxxbJw1OFz7a56kAyW7K q+cKsqg/mDvyTSE5bimFkA1zOGTTop4Qp6FddzrolbbjmBtXTOaqq3YpzD1RuwSh+L0v TTuZfZwG5UCykugijDetC/rVX4DatnSMuoUbdU6cV++ipRVLOpDs5rSxsXJCguBHSh1K UqUg== 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 om23si2659546ejb.194.2019.09.27.06.00.33; Fri, 27 Sep 2019 06:00:58 -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; 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 S1727334AbfI0M5f (ORCPT + 99 others); Fri, 27 Sep 2019 08:57:35 -0400 Received: from mail2-relais-roc.national.inria.fr ([192.134.164.83]:56924 "EHLO mail2-relais-roc.national.inria.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726295AbfI0M5f (ORCPT ); Fri, 27 Sep 2019 08:57:35 -0400 X-IronPort-AV: E=Sophos;i="5.64,555,1559512800"; d="scan'208";a="403686033" Received: from unknown (HELO hadrien) ([12.206.46.59]) by mail2-relais-roc.national.inria.fr with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 27 Sep 2019 14:57:30 +0200 Date: Fri, 27 Sep 2019 05:57:28 -0700 (PDT) From: Julia Lawall X-X-Sender: julia@hadrien To: Joe Perches cc: Andrew Morton , Linus Torvalds , linux-kernel@vger.kernel.org, Jonathan Corbet , Stephen Kitt , Kees Cook , Nitin Gote , jannh@google.com, kernel-hardening@lists.openwall.com, Rasmus Villemoes Subject: Re: [PATCH V2 1/2] string: Add stracpy and stracpy_pad mechanisms In-Reply-To: <56dc4de7e0db153cb10954ac251cb6c27c33da4a.camel@perches.com> Message-ID: References: <20190925145011.c80c89b56fcee3060cf87773@linux-foundation.org> <56dc4de7e0db153cb10954ac251cb6c27c33da4a.camel@perches.com> User-Agent: Alpine 2.21 (DEB 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 26 Sep 2019, Joe Perches wrote: > On Wed, 2019-09-25 at 14:50 -0700, Andrew Morton wrote: > > On Tue, 23 Jul 2019 06:51:36 -0700 Joe Perches wrote: > > > > > Several uses of strlcpy and strscpy have had defects because the > > > last argument of each function is misused or typoed. > > > > > > Add macro mechanisms to avoid this defect. > > > > > > stracpy (copy a string to a string array) must have a string > > > array as the first argument (dest) and uses sizeof(dest) as the > > > count of bytes to copy. > > > > > > These mechanisms verify that the dest argument is an array of > > > char or other compatible types like u8 or s8 or equivalent. > > > > > > A BUILD_BUG is emitted when the type of dest is not compatible. > > > > > > > I'm still reluctant to merge this because we don't have code in -next > > which *uses* it. You did have a patch for that against v1, I believe? > > Please dust it off and send it along? > > https://lore.kernel.org/lkml/CAHk-=wgqQKoAnhmhGE-2PBFt7oQs9LLAATKbYa573UO=DPBE0Q@mail.gmail.com/ > > I gave up, especially after the snark from Linus > where he wrote I don't understand this stuff. > > He's just too full of himself here merely using > argument from authority. > > Creating and using a function like copy_string with > both source and destination lengths specified is > is also potentially a large source of defects where > the stracpy macro atop strscpy does not have a > defect path other than the src not being a string > at all. > > I think the analysis of defects in string function > in the kernel is overly difficult today given the > number of possible uses of pointer and length in > strcpy/strncpy/strlcpy/stracpy. > > I think also that there is some sense in what he > wrote against the "word salad" use of strcpy, > but using stracpy as a macro when possible instead > of strscpy also makes the analysis of defects rather > simpler. > > The trivial script cocci I posted works well for the > simple cases. > > https://lore.kernel.org/cocci/66fcdbf607d7d0bea41edb39e5579d63b62b7d84.camel@perches.com/ > > The more complicated cocci script Julia posted is > still not quite correct as it required intermediate > compilation for verification of specified lengths. The problem seems to be detecting whether the string can reach user level and knowing whether padding is needed. There are many cases where the copied string is a constant and can easily be checked to fit into the destination. But without further investigation that I am not able to do at the moment, it's not clear how to address the user level issue. julia > > https://lkml.org/lkml/2019/7/25/1406 > > Tell me again if you still want it and maybe the > couple conversions that mm/ would get. > > via: > > $ spatch --all-includes --in-place -sp-file str.cpy.cocci mm > $ git diff --stat -p mm > -- > mm/dmapool.c | 2 +- > mm/zswap.c | 2 +- > 2 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/mm/dmapool.c b/mm/dmapool.c > index fe5d33060415..b3a4feb423f8 100644 > --- a/mm/dmapool.c > +++ b/mm/dmapool.c > @@ -158,7 +158,7 @@ struct dma_pool *dma_pool_create(const char *name, struct device *dev, > if (!retval) > return retval; > > - strlcpy(retval->name, name, sizeof(retval->name)); > + stracpy(retval->name, name); > > retval->dev = dev; > > diff --git a/mm/zswap.c b/mm/zswap.c > index 08b6cefae5d8..c6cd38de185a 100644 > --- a/mm/zswap.c > +++ b/mm/zswap.c > @@ -533,7 +533,7 @@ static struct zswap_pool *zswap_pool_create(char *type, char *compressor) > } > pr_debug("using %s zpool\n", zpool_get_type(pool->zpool)); > > - strlcpy(pool->tfm_name, compressor, sizeof(pool->tfm_name)); > + stracpy(pool->tfm_name, compressor); > pool->tfm = alloc_percpu(struct crypto_comp *); > if (!pool->tfm) { > pr_err("percpu alloc failed\n"); > > > >