Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758805Ab0BYB7S (ORCPT ); Wed, 24 Feb 2010 20:59:18 -0500 Received: from hera.kernel.org ([140.211.167.34]:45755 "EHLO hera.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758759Ab0BYB7Q (ORCPT ); Wed, 24 Feb 2010 20:59:16 -0500 Message-ID: <4B85DB79.4010708@kernel.org> Date: Thu, 25 Feb 2010 11:07:53 +0900 From: Tejun Heo User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1.5) Gecko/20091130 SUSE/3.0.0-1.1.1 Thunderbird/3.0 MIME-Version: 1.0 To: Yinghai Lu CC: Peter Zijlstra , Ingo Molnar , Christoph Lameter , "H. Peter Anvin" , Stephen Rothwell , Thomas Gleixner , Andrew Morton , Linus Torvalds , Jesse Barnes , linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org, Pekka Enberg Subject: Re: [PATCH 16/35] x86: make 64 bit use early_res instead of bootmem before slab References: <1265793639-15071-1-git-send-email-yinghai@kernel.org> <1265793639-15071-17-git-send-email-yinghai@kernel.org> <20100215010833.15f9e09a.sfr@canb.auug.org.au> <4B7B4378.1070206@kernel.org> <1267052387.12790.10.camel@laptop> <4B85B65E.503@kernel.org> <4B85B724.9050304@kernel.org> In-Reply-To: <4B85B724.9050304@kernel.org> X-Enigmail-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.2.3 (hera.kernel.org [127.0.0.1]); Thu, 25 Feb 2010 01:57:54 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1583 Lines: 39 Hello, Yinghai. On 02/25/2010 08:32 AM, Yinghai Lu wrote: >>> Kernel panic - not syncing: free_early on not reserved area: 2f80000-2f9ffff! >>> Pid: 0, comm: swapper Not tainted 2.6.33-rc8-tip-00918-gb34d361 #159 >>> Call Trace: >>> [] panic+0x84/0x147 >>> [] free_early+0x64/0x6d >>> [] free_bootmem+0xc/0xe >>> [] pcpu_fc_free+0x1d/0x1f >>> [] pcpu_embed_first_chunk+0x13a/0x27f >>> [] ? pcpu_fc_alloc+0x0/0xac >>> [] ? pcpu_fc_free+0x0/0x1f >>> [] setup_per_cpu_areas+0x82/0x239 >>> [] start_kernel+0x1b8/0x43b >>> [] x86_64_start_reservations+0xa7/0xab >>> [] x86_64_start_kernel+0xf8/0x107 >>> >> >> we can not handle partial free, and current only user for that is pcpu_setup... > > any plan to pcpu_setup to use slab allocation instead of bootmem? > that code is only one user that do partial bootmem free. The problem is that the pcpu_embed_first_chunk() allocator depends on having a large contiguous slab of memory to overlay the percpu variables and then giving back the unused parts (due to layout and cpu_possible_mask not being contiguous). There's no way to do partial alloc/free anymore? Thanks. -- tejun -- 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/