[11/14] vcompound: Fallbacks for order 1 stack allocations on IA64 and x86

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: <linux-mm@...>
Cc: <linux-kernel@...>
Date: Friday, March 21, 2008 - 2:17 am

This allows fallback for order 1 stack allocations. In the fallback
scenario the stacks will be virtually mapped.

Signed-off-by: Christoph Lameter <clameter@sgi.com>
---
 include/asm-ia64/thread_info.h   |    5 +++--
 include/asm-x86/thread_info_32.h |    6 +++---
 include/asm-x86/thread_info_64.h |    4 ++--
 3 files changed, 8 insertions(+), 7 deletions(-)

Index: linux-2.6.25-rc5-mm1/include/asm-ia64/thread_info.h
===================================================================
--- linux-2.6.25-rc5-mm1.orig/include/asm-ia64/thread_info.h	2008-03-20 20:03:47.165885870 -0700
+++ linux-2.6.25-rc5-mm1/include/asm-ia64/thread_info.h	2008-03-20 20:04:51.302135777 -0700
@@ -82,8 +82,9 @@ struct thread_info {
 #define end_of_stack(p) (unsigned long *)((void *)(p) + IA64_RBS_OFFSET)
 
 #define __HAVE_ARCH_TASK_STRUCT_ALLOCATOR
-#define alloc_task_struct()	((struct task_struct *)__get_free_pages(GFP_KERNEL | __GFP_COMP, KERNEL_STACK_SIZE_ORDER))
-#define free_task_struct(tsk)	free_pages((unsigned long) (tsk), KERNEL_STACK_SIZE_ORDER)
+#define alloc_task_struct()	((struct task_struct *)__alloc_vcompound( \
+			GFP_KERNEL, KERNEL_STACK_SIZE_ORDER))
+#define free_task_struct(tsk)	__free_vcompound(tsk)
 
 #define tsk_set_notify_resume(tsk) \
 	set_ti_thread_flag(task_thread_info(tsk), TIF_NOTIFY_RESUME)
Index: linux-2.6.25-rc5-mm1/include/asm-x86/thread_info_32.h
===================================================================
--- linux-2.6.25-rc5-mm1.orig/include/asm-x86/thread_info_32.h	2008-03-20 20:03:47.173885951 -0700
+++ linux-2.6.25-rc5-mm1/include/asm-x86/thread_info_32.h	2008-03-20 20:04:51.306136067 -0700
@@ -96,13 +96,13 @@ static inline struct thread_info *curren
 /* thread information allocation */
 #ifdef CONFIG_DEBUG_STACK_USAGE
 #define alloc_thread_info(tsk) ((struct thread_info *) \
-	__get_free_pages(GFP_KERNEL| __GFP_ZERO, get_order(THREAD_SIZE)))
+	__alloc_vcompound(GFP_KERNEL| __GFP_ZERO, get_order(THREAD_SIZE)))
 #else
 #define alloc_thread_info(tsk) ((struct thread_info *) \
-	__get_free_pages(GFP_KERNEL, get_order(THREAD_SIZE)))
+	__alloc_vcompound(GFP_KERNEL, get_order(THREAD_SIZE)))
 #endif
 
-#define free_thread_info(info)	free_pages((unsigned long)(info), get_order(THREAD_SIZE))
+#define free_thread_info(info)	__free_vcompound(info)
 
 #else /* !__ASSEMBLY__ */
 
Index: linux-2.6.25-rc5-mm1/include/asm-x86/thread_info_64.h
===================================================================
--- linux-2.6.25-rc5-mm1.orig/include/asm-x86/thread_info_64.h	2008-03-20 20:03:47.189886138 -0700
+++ linux-2.6.25-rc5-mm1/include/asm-x86/thread_info_64.h	2008-03-20 20:04:51.306136067 -0700
@@ -83,9 +83,9 @@ static inline struct thread_info *stack_
 #endif
 
 #define alloc_thread_info(tsk) \
-	((struct thread_info *) __get_free_pages(THREAD_FLAGS, THREAD_ORDER))
+	((struct thread_info *) __alloc_vcompound(THREAD_FLAGS, THREAD_ORDER))
 
-#define free_thread_info(ti) free_pages((unsigned long) (ti), THREAD_ORDER)
+#define free_thread_info(ti) __free_vcompound(ti)
 
 #else /* !__ASSEMBLY__ */
 

-- 
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[11/14] vcompound: Fallbacks for order 1 stack allocations o..., Christoph Lameter, (Fri Mar 21, 2:17 am)
Re: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Mon Mar 24, 3:53 pm)
Re: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Tue Mar 25, 1:55 pm)
Re: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Fri Mar 21, 1:40 pm)
Re: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Mon Mar 24, 2:27 pm)
larger default page sizes..., David Miller, (Mon Mar 24, 4:37 pm)
Re: larger default page sizes..., Christoph Lameter, (Mon Mar 24, 5:05 pm)
Re: larger default page sizes..., David Miller, (Mon Mar 24, 5:43 pm)
Re: larger default page sizes..., Christoph Lameter, (Tue Mar 25, 1:48 pm)
Re: larger default page sizes..., David Miller, (Tue Mar 25, 7:22 pm)
Re: larger default page sizes..., Peter Chubb, (Tue Mar 25, 7:41 pm)
Re: larger default page sizes..., David Mosberger-Tang, (Tue Mar 25, 8:34 pm)
Re: larger default page sizes..., Peter Chubb, (Tue Mar 25, 8:57 pm)
Re: larger default page sizes..., John Marvin, (Wed Mar 26, 12:16 am)
Re: larger default page sizes..., David Miller, (Wed Mar 26, 12:36 am)
Re: larger default page sizes..., David Miller, (Tue Mar 25, 8:39 pm)
Re: larger default page sizes..., David Miller, (Tue Mar 25, 7:49 pm)
Re: larger default page sizes..., Peter Chubb, (Tue Mar 25, 8:25 pm)
Re: larger default page sizes..., David Miller, (Tue Mar 25, 8:31 pm)
RE: larger default page sizes..., Luck, Tony, (Mon Mar 24, 5:25 pm)
Re: larger default page sizes..., David Miller, (Mon Mar 24, 5:46 pm)
Re: larger default page sizes..., Paul Mackerras, (Mon Mar 24, 11:29 pm)
Re: larger default page sizes..., Andi Kleen, (Tue Mar 25, 8:05 am)
Re: larger default page sizes..., Paul Mackerras, (Wed Mar 26, 1:24 am)
Re: larger default page sizes..., Christoph Lameter, (Wed Mar 26, 1:56 pm)
Re: larger default page sizes..., Paul Mackerras, (Wed Mar 26, 11:00 pm)
Re: larger default page sizes..., David Miller, (Wed Mar 26, 7:21 pm)
Re: larger default page sizes..., Linus Torvalds, (Wed Mar 26, 11:59 am)
Re: larger default page sizes..., Paul Mackerras, (Wed Mar 26, 9:08 pm)
Re: larger default page sizes..., Paul Mackerras, (Tue Mar 25, 5:27 pm)
Re: larger default page sizes..., David Miller, (Tue Mar 25, 12:15 am)
Re: larger default page sizes..., Paul Mackerras, (Tue Mar 25, 7:50 am)
Re: larger default page sizes..., David Miller, (Tue Mar 25, 7:32 pm)
RE: larger default page sizes..., Luck, Tony, (Tue Mar 25, 7:49 pm)
Re: larger default page sizes..., Nish Aravamudan, (Wed Mar 26, 11:54 am)
RE: larger default page sizes..., Luck, Tony, (Wed Mar 26, 1:05 pm)
Re: larger default page sizes..., Mel Gorman, (Wed Mar 26, 2:54 pm)
Re: larger default page sizes..., David Miller, (Tue Mar 25, 8:16 pm)
Re: larger default page sizes..., Dave Hansen, (Tue Mar 25, 2:27 pm)
RE: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Tue Mar 25, 1:42 pm)
RE: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Tue Mar 25, 3:25 pm)
Re: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Fri Mar 21, 1:33 pm)
Re: [11/14] vcompound: Fallbacks for order 1 stack allocatio..., Christoph Lameter, (Fri Mar 21, 3:04 pm)