Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754225Ab0HZPru (ORCPT ); Thu, 26 Aug 2010 11:47:50 -0400 Received: from mail.vyatta.com ([76.74.103.46]:47949 "EHLO mail.vyatta.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752309Ab0HZPrs (ORCPT ); Thu, 26 Aug 2010 11:47:48 -0400 Date: Thu, 26 Aug 2010 08:47:46 -0700 From: Stephen Hemminger To: Masayuki Ohtake Cc: LKML , ML netdev , Greg Rose , Maxime Bizon , Kristoffer Glembo , Ralf Baechle , John Linn , Randy Dunlap , "David S. Miller" , MeeGo , "Wang, Qi" , "Wang, Yong Y" , Andrew , Intel OTC , "Foster, Margie" , Toshiharu Okada , Tomoya Morinaga , Takahiro Shimizu Subject: Re: [PATCH] Gigabit Ethernet driver of Topcliff PCH Message-ID: <20100826084746.4fd266f7@nehalam> In-Reply-To: <4C763A67.5040107@dsn.okisemi.com> References: <4C763A67.5040107@dsn.okisemi.com> Organization: Vyatta X-Mailer: Claws Mail 3.7.5 (GTK+ 2.20.1; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1525 Lines: 50 On Thu, 26 Aug 2010 18:56:55 +0900 Masayuki Ohtake wrote: > +/** > + * pch_gbe_alloc_queues - Allocate memory for all rings > + * @adapter: Board private structure to initialize > + * Returns > + * 0: Successfully > + * Negative value: Failed > + */ > +static int pch_gbe_alloc_queues(struct pch_gbe_adapter *adapter) > +{ > + int size; > + > + PCH_GBE_DEBUG("%s\n", __func__); > + > + > + size = (int)sizeof(struct pch_gbe_tx_ring); > + adapter->tx_ring = kmalloc(size, GFP_KERNEL); > + if (!adapter->tx_ring) > + return -ENOMEM; > + memset(adapter->tx_ring, 0, size); > + > + size = (int)sizeof(struct pch_gbe_rx_ring); > + adapter->rx_ring = kmalloc(size, GFP_KERNEL); > + if (!adapter->rx_ring) { > + kfree(adapter->tx_ring); > + return -ENOMEM; > + } > + memset(adapter->rx_ring, 0, size); > + > + size = (int)sizeof(struct net_device); > + adapter->polling_netdev = kmalloc(size, GFP_KERNEL); > + if (!adapter->polling_netdev) { > + kfree(adapter->tx_ring); > + kfree(adapter->rx_ring); > + return -ENOMEM; This is not allowed, you can not just allocate up a network device structure out of kmalloc space. Not sure what you are doing with the polling_netdev? Is it left over from when net_device and NAPI were more closely bound? -- -- 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/