From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752138AbZH0DRO (ORCPT ); Wed, 26 Aug 2009 23:17:14 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752002AbZH0DRM (ORCPT ); Wed, 26 Aug 2009 23:17:12 -0400 Received: from mx1.redhat.com ([209.132.183.28]:18224 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751253AbZH0DRK (ORCPT ); Wed, 26 Aug 2009 23:17:10 -0400 Date: Wed, 26 Aug 2009 23:16:21 -0400 From: Amerigo Wang To: linux-kernel@vger.kernel.org Cc: Anton Vorontsov , tony.luck@intel.com, linux-ia64@vger.kernel.org, Neil Horman , "Eric W. Biederman" , kamezawa.hiroyu@jp.fujitsu.com, Andi Kleen , Michael Ellerman , "M. Mohan Kumar" , akpm@linux-foundation.org, bernhard.walle@gmx.de, Fenghua Yu , Ingo Molnar , Amerigo Wang Message-Id: <20090827031848.4534.40440.sendpatchset@localhost.localdomain> In-Reply-To: <20090827031800.4534.94868.sendpatchset@localhost.localdomain> References: <20090827031800.4534.94868.sendpatchset@localhost.localdomain> Subject: [Patch 4/8] ia64: implement crashkernel=auto Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since in patch 2/8 we already implement the generic part, this will add the rest part for ia64. Signed-off-by: WANG Cong Cc: Fenghua Yu Cc: Tony Luck --- Index: linux-2.6/arch/ia64/include/asm/kexec.h =================================================================== --- linux-2.6.orig/arch/ia64/include/asm/kexec.h +++ linux-2.6/arch/ia64/include/asm/kexec.h @@ -1,6 +1,7 @@ #ifndef _ASM_IA64_KEXEC_H #define _ASM_IA64_KEXEC_H +#include /* Maximum physical address we can use pages from */ #define KEXEC_SOURCE_MEMORY_LIMIT (-1UL) @@ -19,6 +20,49 @@ flush_icache_range(page_addr, page_addr + PAGE_SIZE); \ } while(0) +#ifdef CONFIG_KEXEC_AUTO_RESERVE +#define MBYTES(n) ((n)*1024*1024ULL) +#define GBYTES(n) ((n)*1024*1024*1024ULL) +/* + Memory size Reserved memory + =========== =============== + [4G, 12G) 256M + [12G, 128G) 512M + [128G, 256G) 768M + [256G, 378G) 1024M + [378G, 512G) 1536M + [512G, 768G) 2048M + [768G, ) 3072M + */ +static inline +unsigned long long arch_default_crash_size(unsigned long long total_size) +{ + unsigned long long ret; + + if (total_size >= GBYTES(4) && total_size < GBYTES(12)) + ret = MBYTES(256); + else if (total_size >= GBYTES(12) && total_size < GBYTES(128)) + ret = MBYTES(512); + else if (total_size >= GBYTES(128) && total_size < GBYTES(256)) + ret = MBYTES(768); + else if (total_size >= GBYTES(256) && total_size < GBYTES(378)) + ret = MBYTES(1024); + else if (total_size >= GBYTES(318) && total_size < GBYTES(512)) + ret = MBYTES(1536); + else if (total_size >= GBYTES(512) && total_size < GBYTES(768)) + ret = MBYTES(2048); + else + ret = MBYTES(3072); + if (!ia64_platform_is("sn2") && !ia64_platform_is("uv")) + if (ret > GBYTES(4)) + ret = ret / GBYTES(4) * MBYTES(256); + return ret; +} +#undef GBYTES +#undef MBYTES +#define arch_default_crash_size arch_default_crash_size +#endif + extern struct kimage *ia64_kimage; extern const unsigned int relocate_new_kernel_size; extern void relocate_new_kernel(unsigned long, unsigned long,