Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1647588pxk; Fri, 18 Sep 2020 20:03:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzneUdgj1XIvQNwBdxjfc2g4/esMhRMOOt69sFMcD6O7zizbBE9eKHxnWv1UVvbDGLIvx8w X-Received: by 2002:a17:906:3e0c:: with SMTP id k12mr38637005eji.189.1600484638681; Fri, 18 Sep 2020 20:03:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600484638; cv=none; d=google.com; s=arc-20160816; b=Vbzgc3e72A+/PPrX2k+zAgmoihQhoqnv7L9FOdhiR2uxKbsS87eCEfVbcDAjQBch+u 5JTb5avMmDXeAvP70c36VsHOC+0ij/CPzuw7pAPqjNdAQihzPKbwAc/5PjcXPTPl2czr oEOmuDakuNF6zZ+Il1FXpBlyrsBSC6kNGL08QsCFbJPgdQQJHrgwZ8iOid7myrv1Kt2v tfk/zC057UH806r0qEo3EG/JHSO5nHH3peHGJXhpTP3BqZycnqMvFp9Z700rpVdt/dzV eSdVQ5UoBW722azaL8DJEkjBYCHHwtXiizX2K/OWoyF0C12iTWLJKOmJ59+082vbMiZP yKpg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=hHLRJYRyLvyIi3qhTA2v07I6meTEq9wQRnMdQHFqLUM=; b=t7J1qE6bBnT1IUYFIFvLNlJ6fFCDmB6tQn+T48DUaoCa3WTIP2Vz3w9dJ8b2aFL/Gs guYjj0qrwHZmf5xckzfjQ94bAeevpBOnl6kM0wEPYSn4rDVEpEULjk3xQ7ZBiPhTnwbq Yp2zSfGdAmPrbtPstNH9IyjXw7OSS0WPHrjYnXoLwMVAxuBQuVeiQwULch4/y1Id/deX pvDs17K4LoeYMjGX01u5ShMO61HGaB25LhTietdmh+zbm6i53kUur0McUf0NpCLLBiOp X74zU2/UDu0K5NuhtkyXZTJ/jqur6ISt5/3ZWr/6DIOhl/eXsEbP9KJ4KUWwfzVpewRL gSXQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=kPwKmBGU; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y3si3724565edr.538.2020.09.18.20.03.34; Fri, 18 Sep 2020 20:03:58 -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=@infradead.org header.s=casper.20170209 header.b=kPwKmBGU; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726119AbgISDCU (ORCPT + 99 others); Fri, 18 Sep 2020 23:02:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58914 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726009AbgISDCT (ORCPT ); Fri, 18 Sep 2020 23:02:19 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BFF38C0613CE for ; Fri, 18 Sep 2020 20:02:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=hHLRJYRyLvyIi3qhTA2v07I6meTEq9wQRnMdQHFqLUM=; b=kPwKmBGUzyvgAdyJ4zKTtLjMea JkkzqYMRkvWLb0eqBagDLnkeZq4HYmxYTbLLW2qE1Vxnm8+q/k6IekMqcPamr4rEaRWF3YOOK/UIW V22xtjGPQcPCFdsyg59TZ+ys2iNm/jwB40twlnbcIFEdKnrN0+BkpBwr+ASzivw/gujxexEf/yd2g TDAD5cIoCV3bn0mtiGNpHaIq8mVZLZmSdxtPXLIrxqinxQ5YCNe6AhaI7f69SCLbRVpaOrGu1MzvB eMfOcjFDMF3kCXcAFYsSCRiXbj9QGVDSynI6g+dxiqechWaAaCd/pyshj/7rR7cjEZ50TZ3UOnCkc P15UpPiA==; Received: from willy by casper.infradead.org with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1kJT8e-0001nD-6H; Sat, 19 Sep 2020 03:02:12 +0000 Date: Sat, 19 Sep 2020 04:02:12 +0100 From: Matthew Wilcox To: Arvind Sankar Cc: Linus Torvalds , "Gustavo A. R. Silva" , Dennis Zhou , Tejun Heo , Christoph Lameter , Linux-MM , Linux Kernel Mailing List , Kees Cook Subject: Re: [GIT PULL] percpu fix for v5.9-rc6 Message-ID: <20200919030212.GK32101@casper.infradead.org> References: <20200918200252.GH32101@casper.infradead.org> <20200918202909.GA2946008@rani.riverdale.lan> <20200918210050.GA2953017@rani.riverdale.lan> <20200918223957.GA2964553@rani.riverdale.lan> <20200919025336.GA3008405@rani.riverdale.lan> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200919025336.GA3008405@rani.riverdale.lan> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Sep 18, 2020 at 10:53:36PM -0400, Arvind Sankar wrote: > I think you can't do this in standard C. It's a GCC extension. > > A structure containing a flexible array member, or a union > containing such a structure (possibly recursively), may not be a > member of a structure or an element of an array. (However, these > uses are permitted by GCC as extensions.) I actually have a patch in the works which wants to do this. struct pagevec { - unsigned char nr; - bool percpu_pvec_drained; - struct page *pages[PAGEVEC_SIZE]; + union { + struct { + unsigned char sz; + unsigned char nr; + bool percpu_pvec_drained; + struct page *pages[]; + }; + void *__p[PAGEVEC_SIZE + 1]; + }; }; I don't think ANSI C permits this, but it's useful to be able to declare a pagevec on the stack and be guaranteed to get enough memory to hold a useful sized array of pointers (as well as be able to dynamically allocate a larger pagevec for the cases which want such a thing). We could certainly split pagevec into a variable length array version and have a struct stack_pagevec which had the extra padding, but that involves changing a lot more code.