Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753811AbaBOTih (ORCPT ); Sat, 15 Feb 2014 14:38:37 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:53128 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753519AbaBOTif (ORCPT ); Sat, 15 Feb 2014 14:38:35 -0500 Date: Sat, 15 Feb 2014 11:39:56 -0800 From: Greg Kroah-Hartman To: Uwe =?iso-8859-1?Q?Kleine-K=F6nig?= Cc: Yann Droneaud , linux-kernel@vger.kernel.org, Dmitry Torokhov Subject: Re: [PATCHv4] driver core/platform: don't leak memory allocated for dma_mask Message-ID: <20140215193956.GA30595@kroah.com> References: <20140114081944.GO29475@pengutronix.de> <1389693453.1585.26.camel@localhost.localdomain> <20140114103648.GT29475@pengutronix.de> <20140114180204.GD27791@kroah.com> <1390771138-28348-1-git-send-email-ydroneaud@opteya.com> <1390817152-30898-1-git-send-email-ydroneaud@opteya.com> <20140207232005.GA23477@kroah.com> <20140208150958.GK17045@pengutronix.de> <1391932042.11170.20.camel@localhost.localdomain> <20140209093032.GM17045@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20140209093032.GM17045@pengutronix.de> User-Agent: Mutt/1.5.22 (2013-10-16) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Feb 09, 2014 at 10:30:32AM +0100, Uwe Kleine-K?nig wrote: > Hello Yann, > > On Sun, Feb 09, 2014 at 08:47:22AM +0100, Yann Droneaud wrote: > > Hi, > > > > Le samedi 08 f?vrier 2014 ? 16:09 +0100, Uwe Kleine-K?nig a ?crit : > > > On Fri, Feb 07, 2014 at 03:20:05PM -0800, Greg Kroah-Hartman wrote: > > > > On Mon, Jan 27, 2014 at 11:05:52AM +0100, Yann Droneaud wrote: > > > > > Since commit 01dcc60a7cb8, platform_device_register_full() is > > > > > available to allocate and register a platform device. > > > > > > > > > > If a dma_mask is provided as part of platform_device_info, > > > > > platform_device_register_full() allocate memory for a u64 using > > > > > kmalloc(). > > > > > > > > > > A comment in the code state that "[t]his memory isn't freed when the > > > > > device is put". > > > > > > > > > > It's never a good thing to leak memory, but there's only very few > > > > > users of platform_device_info's dma_mask, and those are mostly > > > > > "static" devices that are not going to be plugged/unplugged often. > > > > > > > > > > So memory leak is not really an issue, but allocating 8 bytes through > > > > > kmalloc() seems overkill. > > > > > > > > > > And it's a pity to have to allocate 8 bytes for the dma_mask while up > > > > > to 7 bytes are wasted at the end of struct platform_object in the form > > > > > of padding after name field: unfortunately this padding is not used > > > > > when allocating the memory to hold the name. > > > > > > > > > > To address theses issues, this patch adds dma_mask to platform_object > > > > > struct so that it is always allocated for all struct platform_device > > > > > allocated through platform_device_alloc() or platform_device_register_full(). > > > > > And since it's within struct platform_object, dma_mask won't be leaked > > > > > anymore when struct platform_device got released. Storage for dma_mask > > > > > is added almost for free by removing the padding at the end of struct > > > > > platform_object. > > > > > How does the padding of name change? The only thing that I see changing > > > for .name is that it's a char[] now instead of a char[1]. As it was > > > used as a flexible array already before the padding (which only applies > > > to a stand alone struct platform_object) doesn't matter. > > > I guess that is a tool problem that still some padding changes are > > > reported? > > > > > > > When name is defined as char name[1] at the end of the structure, the > > compiler is required to add padding after it (since the structure is not > > "packed" through some compiler extension). > > This padding is added in order to have a size multiple of the highest > > required alignement for types insided the structure. This is required so > > that each item of an array of "struct platform_object" are aligned. > > > > Changing name[1] to name[0] or name[] free the compiler from adding > > storage space for name and thus remove the need for padding after it. > Ah, I see, even though .name was used as a flexible array there was too > much allocated because sizeof(struct platform_object) includes the 7 > bytes of padding. > > Maybe it makes sense to split the patch into a) s/name[1]/name[]/ and b) > add dma_mask? Up to you, you can have my Ack also for the single patch. > > Acked-by: Uwe Kleine-K?nig Breaking it up would be good, if for no other reason than people got confused with it as-is. thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/