# HG changeset patch
# User Keir Fraser <keir.fraser@xxxxxxxxxx>
# Date 1200580904 0
# Node ID 8f6640070a863aa30bfb242ad20e9a043ebe44b8
# Parent 1101ca828ad92210038ed5cde0d18a71af90c5e9
minios: make stack size configurable
Signed-off-by: Samuel Thibault <samuel.thibault@xxxxxxxxxxxxx>
Signed-off-by: Grzegorz Milos <gm281@xxxxxxxxx>
---
extras/mini-os/arch/ia64/sched.c | 6 +++---
extras/mini-os/arch/x86/sched.c | 8 ++++----
extras/mini-os/arch/x86/setup.c | 4 ++--
extras/mini-os/arch/x86/x86_32.S | 5 +++--
extras/mini-os/arch/x86/x86_64.S | 5 +++--
extras/mini-os/include/ia64/arch_mm.h | 3 +++
extras/mini-os/include/x86/arch_mm.h | 18 ++++++++++++++++++
extras/mini-os/include/x86/arch_sched.h | 3 ++-
extras/mini-os/sched.c | 2 +-
9 files changed, 39 insertions(+), 15 deletions(-)
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/arch/ia64/sched.c
--- a/extras/mini-os/arch/ia64/sched.c Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/arch/ia64/sched.c Thu Jan 17 14:41:44 2008 +0000
@@ -40,11 +40,11 @@ arch_create_thread(char *name, void (*fu
struct thread* _thread;
_thread = (struct thread*)_xmalloc(sizeof(struct thread), 16);
- /* Allocate 2 pages for stack, stack will be 2pages aligned */
- _thread->stack = (char *)alloc_pages(1);
+ /* Allocate pages for stack, stack will be aligned */
+ _thread->stack = (char *)alloc_pages(STACK_SIZE_PAGE_ORDER);
_thread->name = name;
memset((void*)&(_thread->regs), 0, sizeof(_thread->regs));
- _thread->regs.sp = ((uint64_t)_thread->stack) + 2 * PAGE_SIZE - 16;
+ _thread->regs.sp = ((uint64_t)_thread->stack) + STACK_SIZE - 16;
_thread->regs.bsp = ((uint64_t)_thread->stack) + 0x10;
_thread->regs.rp = FDESC_FUNC(thread_starter);
_thread->regs.pfs = 0x82;
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/arch/x86/sched.c
--- a/extras/mini-os/arch/x86/sched.c Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/arch/x86/sched.c Thu Jan 17 14:41:44 2008 +0000
@@ -57,7 +57,7 @@
void dump_stack(struct thread *thread)
{
- unsigned long *bottom = (unsigned long *)(thread->stack + 2*4*1024);
+ unsigned long *bottom = (unsigned long *)(thread->stack + STACK_SIZE);
unsigned long *pointer = (unsigned long *)thread->sp;
int count;
if(thread == current)
@@ -98,13 +98,13 @@ struct thread* arch_create_thread(char *
struct thread *thread;
thread = xmalloc(struct thread);
- /* Allocate 2 pages for stack, stack will be 2pages aligned */
- thread->stack = (char *)alloc_pages(1);
+ /* We can't use lazy allocation here since the trap handler runs on the
stack */
+ thread->stack = (char *)alloc_pages(STACK_SIZE_PAGE_ORDER);
thread->name = name;
printk("Thread \"%s\": pointer: 0x%lx, stack: 0x%lx\n", name, thread,
thread->stack);
- thread->sp = (unsigned long)thread->stack + 4096 * 2;
+ thread->sp = (unsigned long)thread->stack + STACK_SIZE;
/* Save pointer to the thread on the stack, used by current macro */
*((unsigned long *)thread->stack) = (unsigned long)thread;
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/arch/x86/setup.c
--- a/extras/mini-os/arch/x86/setup.c Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/arch/x86/setup.c Thu Jan 17 14:41:44 2008 +0000
@@ -45,7 +45,7 @@ union start_info_union start_info_union;
* Just allocate the kernel stack here. SS:ESP is set up to point here
* in head.S.
*/
-char stack[2*8192];
+char stack[2*STACK_SIZE];
extern char shared_info[PAGE_SIZE];
@@ -102,7 +102,7 @@ void
void
arch_print_info(void)
{
- printk(" stack: %p-%p\n", stack, stack + 2*8192);
+ printk(" stack: %p-%p\n", stack, stack + sizeof(stack));
}
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/arch/x86/x86_32.S
--- a/extras/mini-os/arch/x86/x86_32.S Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/arch/x86/x86_32.S Thu Jan 17 14:41:44 2008 +0000
@@ -1,4 +1,5 @@
#include <os.h>
+#include <arch_mm.h>
#include <xen/arch-x86_32.h>
.section __xen_guest
@@ -21,12 +22,12 @@ _start:
_start:
cld
lss stack_start,%esp
- andl $(~(8192-1)), %esp
+ andl $(~(STACK_SIZE-1)), %esp
push %esi
call start_kernel
stack_start:
- .long stack+(2*8192), __KERNEL_SS
+ .long stack+(2*STACK_SIZE), __KERNEL_SS
/* Unpleasant -- the PTE that maps this page is actually overwritten */
/* to map the real shared-info page! :-) */
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/arch/x86/x86_64.S
--- a/extras/mini-os/arch/x86/x86_64.S Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/arch/x86/x86_64.S Thu Jan 17 14:41:44 2008 +0000
@@ -1,4 +1,5 @@
#include <os.h>
+#include <arch_mm.h>
#include <xen/features.h>
.section __xen_guest
@@ -18,12 +19,12 @@ _start:
_start:
cld
movq stack_start(%rip),%rsp
- andq $(~(8192-1)), %rsp
+ andq $(~(STACK_SIZE-1)), %rsp
movq %rsi,%rdi
call start_kernel
stack_start:
- .quad stack+(2*8192)
+ .quad stack+(2*STACK_SIZE)
/* Unpleasant -- the PTE that maps this page is actually overwritten */
/* to map the real shared-info page! :-) */
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/include/ia64/arch_mm.h
--- a/extras/mini-os/include/ia64/arch_mm.h Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/include/ia64/arch_mm.h Thu Jan 17 14:41:44 2008 +0000
@@ -33,4 +33,7 @@
#define virt_to_mfn(x) virt_to_pfn(x)
+#define STACK_SIZE_PAGE_ORDER 1
+#define STACK_SIZE (PAGE_SIZE * (1 << STACK_SIZE_PAGE_ORDER))
+
#endif /* __ARCH_MM_H__ */
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/include/x86/arch_mm.h
--- a/extras/mini-os/include/x86/arch_mm.h Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/include/x86/arch_mm.h Thu Jan 17 14:41:44 2008 +0000
@@ -25,12 +25,15 @@
#ifndef _ARCH_MM_H_
#define _ARCH_MM_H_
+#ifndef __ASSEMBLY__
+#include <xen/xen.h>
#if defined(__i386__)
#include <xen/arch-x86_32.h>
#elif defined(__x86_64__)
#include <xen/arch-x86_64.h>
#else
#error "Unsupported architecture"
+#endif
#endif
#define L1_FRAME 1
@@ -53,7 +56,9 @@
#define NOT_L1_FRAMES 1
#define PRIpte "08lx"
+#ifndef __ASSEMBLY__
typedef unsigned long pgentry_t;
+#endif
#else /* defined(CONFIG_X86_PAE) */
@@ -76,7 +81,9 @@ typedef unsigned long pgentry_t;
*/
#define NOT_L1_FRAMES 3
#define PRIpte "016llx"
+#ifndef __ASSEMBLY__
typedef uint64_t pgentry_t;
+#endif
#endif /* !defined(CONFIG_X86_PAE) */
@@ -102,7 +109,9 @@ typedef uint64_t pgentry_t;
#define NOT_L1_FRAMES 3
#define PRIpte "016lx"
+#ifndef __ASSEMBLY__
typedef unsigned long pgentry_t;
+#endif
#endif
@@ -146,10 +155,14 @@ typedef unsigned long pgentry_t;
#define L4_PROT (_PAGE_PRESENT|_PAGE_RW|_PAGE_ACCESSED|_PAGE_DIRTY|_PAGE_USER)
#endif /* __i386__ || __x86_64__ */
+#ifdef __ASSEMBLY__
+#define PAGE_SIZE (1 << L1_PAGETABLE_SHIFT)
+#else
#ifndef CONFIG_X86_PAE
#define PAGE_SIZE (1UL << L1_PAGETABLE_SHIFT)
#else
#define PAGE_SIZE (1ULL << L1_PAGETABLE_SHIFT)
+#endif
#endif
#define PAGE_SHIFT L1_PAGETABLE_SHIFT
#define PAGE_MASK (~(PAGE_SIZE-1))
@@ -162,6 +175,10 @@ typedef unsigned long pgentry_t;
/* to align the pointer to the (next) page boundary */
#define PAGE_ALIGN(addr) (((addr)+PAGE_SIZE-1)&PAGE_MASK)
+#define STACK_SIZE_PAGE_ORDER 1
+#define STACK_SIZE (PAGE_SIZE * (1 << STACK_SIZE_PAGE_ORDER))
+
+#ifndef __ASSEMBLY__
/* Definitions for machine and pseudophysical addresses. */
#ifdef CONFIG_X86_PAE
typedef unsigned long long paddr_t;
@@ -188,6 +205,7 @@ static __inline__ paddr_t machine_to_phy
phys = (phys << PAGE_SHIFT) | (machine & ~PAGE_MASK);
return phys;
}
+#endif
#define VIRT_START ((unsigned long)&_text)
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/include/x86/arch_sched.h
--- a/extras/mini-os/include/x86/arch_sched.h Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/include/x86/arch_sched.h Thu Jan 17 14:41:44 2008 +0000
@@ -2,6 +2,7 @@
#ifndef __ARCH_SCHED_H__
#define __ARCH_SCHED_H__
+#include <arch_mm.h>
static inline struct thread* get_current(void)
{
@@ -11,7 +12,7 @@ static inline struct thread* get_current
#else
register unsigned long sp asm("rsp");
#endif
- current = (void *)(sp & ~8191UL);
+ current = (void *)(sp & ~(STACK_SIZE-1));
return *current;
}
diff -r 1101ca828ad9 -r 8f6640070a86 extras/mini-os/sched.c
--- a/extras/mini-os/sched.c Thu Jan 17 14:41:12 2008 +0000
+++ b/extras/mini-os/sched.c Thu Jan 17 14:41:44 2008 +0000
@@ -139,7 +139,7 @@ void schedule(void)
if(thread != prev)
{
list_del(&thread->thread_list);
- free_pages(thread->stack, 1);
+ free_pages(thread->stack, STACK_SIZE_PAGE_ORDER);
xfree(thread);
}
}
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
|