Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp3247306ybl; Fri, 20 Dec 2019 06:17:51 -0800 (PST) X-Google-Smtp-Source: APXvYqymcBqjYA98gNpXGqVB8NMpjT6rpqO+ecrXi8orQY0LfwvuGczLZqPx5ZrnddaxDNcfWRJX X-Received: by 2002:a05:6808:1c5:: with SMTP id x5mr4007411oic.57.1576851471744; Fri, 20 Dec 2019 06:17:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576851471; cv=none; d=google.com; s=arc-20160816; b=XOYNlGwXjpRrYv7lpB2uKIF7lLkn7PRS8IfA2EYlkEjezjiG8ZOpQrVo2d5QWrL0I6 nQwJKQ/l9ITy2t+4YUjoOrvguYg3d9L9G+liFYmQ2YFv3LS+fNGJ7dLwTqZommRu2Xe8 SpmcYMGfCT2zPO3mioMFDsJm0rkEN+PGRKjotGkJye9G+gciRZeR1PJZABLTXn9E/X8n 1OUy1QCaZ69B8iDVlIeKuCKuu5LilWviF+mPgv6D0sMDNLAOXJft03N0nkiUJdSOHkje z5XBbhLh9X25IftVIbGN3WuodqEfPEdm7Z3VGOtFXiEk+EWmD5Z7DBhaeglDHapweLZy XPBA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=R5soITF6tCn6qSTrF1Drbhq2XSnPSqwZu66BtudwB3w=; b=TEF2/b10w7tqSC/R+9AX3aamqCqKUJrc0110YeKc/eprpBq2fO0NNOtc7AzqdYtVe7 so5CYbsnx+sDzPmL98VArjO7Mfmt135A2287mjF19XSJs5LZA4d9oFwyhWU+0eDKZUY+ q9E9epL0Rw4Vtt/Lltu4pOfAtsxVhBG4tOua1jReeq9SiLSqTc1cYk5/IGas19Xdybtj TuNSkDVpBg20O9URJMMxxS/zutUcdZT/zDDhBKqykL6cP7JWAR8u0kDymPHXFMCYkeSU BSnyId8eEUCAZVP/pBRSjiVcK1YxYp8F6ruxqwW6HuVmIsXd5cAppK8OZ3iiGiEAyyPx bcSA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=rUYD7y0x; 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 o8si5295274oti.47.2019.12.20.06.17.36; Fri, 20 Dec 2019 06:17:51 -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; dkim=pass header.i=@kernel.org header.s=default header.b=rUYD7y0x; 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 S1727400AbfLTOQI (ORCPT + 99 others); Fri, 20 Dec 2019 09:16:08 -0500 Received: from mail.kernel.org ([198.145.29.99]:58522 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727344AbfLTOQI (ORCPT ); Fri, 20 Dec 2019 09:16:08 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 1C23021D7D; Fri, 20 Dec 2019 14:16:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1576851367; bh=ozdmvQULKSXokLNWdk7mYphvTDazwayXgBTn7Ekeph4=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=rUYD7y0xQ0rgIYMrq8VaVZBlDMYXr2sK+cPuFusKHMyLPgsIlq/Ce/UpiwToV+sLN MiLXt8kUQfbwiwfhBBPQWfBw5Pp4ECdqFwvV4NuUZWGUF9+cQCmvCdKijw873h5uPO Kdt2zLejmQFIX21VRVEHX7Hmbw8zbkVd3WihSxvg= Date: Fri, 20 Dec 2019 15:16:05 +0100 From: Greg Kroah-Hartman To: Peter Zijlstra Cc: Marc Gonzalez , Rafael Wysocki , LKML , Linux ARM , Robin Murphy , Dmitry Torokhov , Alexey Brodkin , Will Deacon , Russell King , Bjorn Andersson , Tejun Heo , Mark Brown Subject: Re: [RFC PATCH v1] devres: align devres.data strictly only for devm_kmalloc() Message-ID: <20191220141605.GA2292734@kroah.com> References: <74ae22cd-08c1-d846-3e1d-cbc38db87442@free.fr> <20191220140655.GN2827@hirez.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20191220140655.GN2827@hirez.programming.kicks-ass.net> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Dec 20, 2019 at 03:06:55PM +0100, Peter Zijlstra wrote: > On Fri, Dec 20, 2019 at 11:19:27AM +0100, Marc Gonzalez wrote: > > Would anyone else have any suggestions, comments, insights, recommendations, > > improvements, guidance, or wisdom? :-) > > Flip devres upside down! > > **WARNING, wear protective glasses when reading the below** > > > struct devres { > struct devres_node node; > void *data; > }; > > /* > * We place struct devres at the tail of the memory allocation > * such that data retains the ARCH_KMALLOC_MINALIGN alignment. > * struct devres itself is just 4 pointers and should therefore > * only require trivial alignment. > */ > static inline struct devres *data2devres(void *data) > { > return (struct devres *)(data + ksize(data) - sizeof(struct devres)); > } > > void *alloc_dr(...) > { > struct devres *dr; > void *data; > > data = kmalloc(size + sizeof(struct devres), GFP_KERNEL); > dr = data2devres(data); > WARN_ON((unsigned long)dr & __alignof(*dr)-1); > INIT_LIST_HEAD(&dr->node.entry); > dr->node.release = release; > dr->data = data; > > return dr; > } > > void devres_free(void *data) > { > if (data) { > struct devres *dr = data2devres(data); > BUG_ON(!list_empty(dr->node.entry)); > kfree(data); > } > } > > static int release_nodes(...) > { > ... > list_for_each_entry_safe_reverse(dr, ...) { > ... > kfree(dr->data); > } > } > Ok, that's my queue to walk away from the keyboard and start drinking, I think the holiday season has now officially started. ugh. crazy. but brilliant :) greg k-h