Index: kernel/arch/ia32/Makefile.inc
===================================================================
--- kernel/arch/ia32/Makefile.inc	(revision 2f5769097aeb16476c39a32de0fe53503cf28a83)
+++ kernel/arch/ia32/Makefile.inc	(revision deca67b8f66138a6a55b92cb5e6baa32bb733f52)
@@ -100,5 +100,4 @@
 	arch/$(KARCH)/src/drivers/vesa.c \
 	arch/$(KARCH)/src/boot/boot.S \
-	arch/$(KARCH)/src/boot/cboot.c \
 	arch/$(KARCH)/src/boot/memmap.c \
 	arch/$(KARCH)/src/fpu_context.c \
Index: kernel/arch/ia32/include/arch.h
===================================================================
--- kernel/arch/ia32/include/arch.h	(revision 2f5769097aeb16476c39a32de0fe53503cf28a83)
+++ kernel/arch/ia32/include/arch.h	(revision deca67b8f66138a6a55b92cb5e6baa32bb733f52)
@@ -27,5 +27,5 @@
  */
 
-/** @addtogroup ia32	
+/** @addtogroup ia32
  * @{
  */
@@ -36,4 +36,8 @@
 #define KERN_ia32_ARCH_H_
 
+#include <arch/boot/multiboot.h>
+
+extern void arch_pre_main(uint32_t signature, const mb_info_t *mi);
+
 #endif
 
Index: kernel/arch/ia32/include/boot/boot.h
===================================================================
--- kernel/arch/ia32/include/boot/boot.h	(revision 2f5769097aeb16476c39a32de0fe53503cf28a83)
+++ kernel/arch/ia32/include/boot/boot.h	(revision deca67b8f66138a6a55b92cb5e6baa32bb733f52)
@@ -27,5 +27,5 @@
  */
 
-/** @addtogroup ia32	
+/** @addtogroup ia32
  * @{
  */
@@ -36,12 +36,22 @@
 #define KERN_ia32_BOOT_H_
 
-#define BOOT_OFFSET		0x108000
-#define AP_BOOT_OFFSET		0x8000
-#define BOOT_STACK_SIZE	0x400
+#define BOOT_OFFSET      0x108000
+#define AP_BOOT_OFFSET   0x8000
+#define BOOT_STACK_SIZE  0x400
 
-#define MULTIBOOT_HEADER_MAGIC	0x1BADB002
-#define MULTIBOOT_HEADER_FLAGS	0x00010003
+#define MULTIBOOT_HEADER_MAGIC  0x1BADB002
+#define MULTIBOOT_HEADER_FLAGS  0x00010003
 
-#define MULTIBOOT_LOADER_MAGIC	0x2BADB002
+#define MULTIBOOT_LOADER_MAGIC  0x2BADB002
+
+#ifndef __ASM__
+
+#ifdef CONFIG_SMP
+
+extern int _hardcoded_unmapped_size;
+
+#endif /* CONFIG_SMP */
+
+#endif /* __ASM__ */
 
 #endif
Index: rnel/arch/ia32/include/boot/cboot.h
===================================================================
--- kernel/arch/ia32/include/boot/cboot.h	(revision 2f5769097aeb16476c39a32de0fe53503cf28a83)
+++ 	(revision )
@@ -1,91 +1,0 @@
-/*
- * Copyright (c) 2005 Martin Decky
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * - Redistributions of source code must retain the above copyright
- *   notice, this list of conditions and the following disclaimer.
- * - Redistributions in binary form must reproduce the above copyright
- *   notice, this list of conditions and the following disclaimer in the
- *   documentation and/or other materials provided with the distribution.
- * - The name of the author may not be used to endorse or promote products
- *   derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-/** @addtogroup ia32	
- * @{
- */
-/** @file
- */
-
-#ifndef KERN_ia32_CBOOT_H__
-#define KERN_ia32_CBOOT_H_
-
-#include <arch/types.h>
-#include <arch/boot/memmap.h>
-
-/** Multiboot mod structure */
-typedef struct {
-	uintptr_t start;
-	uintptr_t end;
-	char *string;
-	uint32_t reserved;
-} __attribute__ ((packed)) mb_mod_t;
-
-/** Multiboot mmap structure */
-typedef struct {
-	uint32_t size;
-	e820memmap_t mm_info;
-} __attribute__ ((packed)) mb_mmap_t;
-
-/** Multiboot information structure */
-typedef struct {
-	uint32_t flags;
-	uintptr_t mem_lower;
-	uintptr_t mem_upper;
-
-	uint32_t boot_device;
-	char *cmdline;
-
-	uint32_t mods_count;
-	mb_mod_t *mods_addr;
-
-	uint32_t syms[4];
-
-	uint32_t mmap_length;
-	mb_mmap_t *mmap_addr;
-
-	/* ... */
-} __attribute__ ((packed)) mb_info_t;
-
-enum mb_info_flags {
-	MBINFO_FLAGS_MEM	= 0x01,
-	MBINFO_FLAGS_BOOT	= 0x02,
-	MBINFO_FLAGS_CMDLINE	= 0x04,
-	MBINFO_FLAGS_MODS	= 0x08,
-	MBINFO_FLAGS_SYMS1	= 0x10,
-	MBINFO_FLAGS_SYMS2	= 0x20,
-	MBINFO_FLAGS_MMAP	= 0x40
-	/* ... */
-};
-
-extern void ia32_cboot(uint32_t signature, const mb_info_t *mi);
-
-#endif
-
-/** @}
- */
Index: kernel/arch/ia32/include/boot/multiboot.h
===================================================================
--- kernel/arch/ia32/include/boot/multiboot.h	(revision deca67b8f66138a6a55b92cb5e6baa32bb733f52)
+++ kernel/arch/ia32/include/boot/multiboot.h	(revision deca67b8f66138a6a55b92cb5e6baa32bb733f52)
@@ -0,0 +1,90 @@
+/*
+ * Copyright (c) 2005 Martin Decky
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * - Redistributions of source code must retain the above copyright
+ *   notice, this list of conditions and the following disclaimer.
+ * - Redistributions in binary form must reproduce the above copyright
+ *   notice, this list of conditions and the following disclaimer in the
+ *   documentation and/or other materials provided with the distribution.
+ * - The name of the author may not be used to endorse or promote products
+ *   derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/** @addtogroup ia32
+ * @{
+ */
+/** @file
+ */
+
+#ifndef KERN_ia32_MULTIBOOT_H__
+#define KERN_ia32_MULTIBOOT_H_
+
+#include <arch/types.h>
+#include <arch/boot/memmap.h>
+
+/** Multiboot mod structure */
+typedef struct {
+	uintptr_t start;
+	uintptr_t end;
+	char *string;
+	uint32_t reserved;
+} __attribute__ ((packed)) mb_mod_t;
+
+/** Multiboot mmap structure */
+typedef struct {
+	uint32_t size;
+	e820memmap_t mm_info;
+} __attribute__ ((packed)) mb_mmap_t;
+
+/** Multiboot information structure */
+typedef struct {
+	uint32_t flags;
+	uintptr_t mem_lower;
+	uintptr_t mem_upper;
+	
+	uint32_t boot_device;
+	char *cmdline;
+	
+	uint32_t mods_count;
+	mb_mod_t *mods_addr;
+	
+	uint32_t syms[4];
+	
+	uint32_t mmap_length;
+	mb_mmap_t *mmap_addr;
+	
+	/* ... */
+} __attribute__ ((packed)) mb_info_t;
+
+enum mb_info_flags {
+	MBINFO_FLAGS_MEM     = 0x01,
+	MBINFO_FLAGS_BOOT    = 0x02,
+	MBINFO_FLAGS_CMDLINE = 0x04,
+	MBINFO_FLAGS_MODS    = 0x08,
+	MBINFO_FLAGS_SYMS1   = 0x10,
+	MBINFO_FLAGS_SYMS2   = 0x20,
+	MBINFO_FLAGS_MMAP    = 0x40
+	
+	/* ... */
+};
+
+#endif
+
+/** @}
+ */
Index: kernel/arch/ia32/src/boot/boot.S
===================================================================
--- kernel/arch/ia32/src/boot/boot.S	(revision 2f5769097aeb16476c39a32de0fe53503cf28a83)
+++ kernel/arch/ia32/src/boot/boot.S	(revision deca67b8f66138a6a55b92cb5e6baa32bb733f52)
@@ -105,11 +105,13 @@
 	call map_kernel							# map kernel and turn paging on
 
-	# ia32_cboot(grub_eax, grub_ebx)
+	# arch_pre_main(grub_eax, grub_ebx)
 	pushl grub_ebx
 	pushl grub_eax
-	call ia32_cboot		# Does not return.
-
+	call arch_pre_main
+	
+	call main_bsp
+	
 	# Not reached.
-
+	
 	cli
 	hlt
Index: rnel/arch/ia32/src/boot/cboot.c
===================================================================
--- kernel/arch/ia32/src/boot/cboot.c	(revision 2f5769097aeb16476c39a32de0fe53503cf28a83)
+++ 	(revision )
@@ -1,158 +1,0 @@
-/*
- * Copyright (c) 2009 Jiri Svoboda
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * - Redistributions of source code must retain the above copyright
- *   notice, this list of conditions and the following disclaimer.
- * - Redistributions in binary form must reproduce the above copyright
- *   notice, this list of conditions and the following disclaimer in the
- *   documentation and/or other materials provided with the distribution.
- * - The name of the author may not be used to endorse or promote products
- *   derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-/** @addtogroup ia32
- * @{
- */
-/** @file
- */
-
-#include <main/main.h>
-#include <arch/boot/boot.h>
-#include <arch/boot/cboot.h>
-#include <arch/boot/memmap.h>
-#include <config.h>
-#include <memstr.h>
-#include <string.h>
-#include <macros.h>
-
-/* This is a symbol so the type is only dummy. Obtain the value using &. */
-extern int _hardcoded_unmapped_size;
-
-/** Extract command name from the multiboot module command line.
- *
- * @param buf      Destination buffer (will always null-terminate).
- * @param n        Size of destination buffer.
- * @param cmd_line Input string (the command line).
- *
- */
-static void extract_command(char *buf, size_t n, const char *cmd_line)
-{
-	const char *start, *end, *cp;
-	size_t max_len;
-	
-	/* Find the first space. */
-	end = strchr(cmd_line, ' ');
-	if (end == NULL)
-		end = cmd_line + strlen(cmd_line);
-	
-	/*
-	 * Find last occurence of '/' before 'end'. If found, place start at
-	 * next character. Otherwise, place start at beginning of buffer.
-	 */
-	cp = end;
-	start = buf;
-	while (cp != start) {
-		if (*cp == '/') {
-			start = cp + 1;
-			break;
-		}
-		--cp;
-	}
-	
-	/* Copy the command and null-terminate the string. */
-	max_len = min(n - 1, (size_t) (end - start));
-	strncpy(buf, start, max_len + 1);
-	buf[max_len] = '\0';
-}
-
-/** C part of ia32 boot sequence.
- *
- * @param signature Should contain the multiboot signature.
- * @param mi        Pointer to the multiboot information structure.
- */
-void ia32_cboot(uint32_t signature, const mb_info_t *mi)
-{
-	uint32_t flags;
-	mb_mod_t *mods;
-	uint32_t i;
-	
-	if (signature == MULTIBOOT_LOADER_MAGIC)
-		flags = mi->flags;
-	else {
-		/* No multiboot info available. */
-		flags = 0;
-	}
-	
-	/* Copy module information. */
-	
-	if ((flags & MBINFO_FLAGS_MODS) != 0) {
-		init.cnt = mi->mods_count;
-		mods = mi->mods_addr;
-		
-		for (i = 0; i < init.cnt; i++) {
-			init.tasks[i].addr = mods[i].start + 0x80000000;
-			init.tasks[i].size = mods[i].end - mods[i].start;
-			
-			/* Copy command line, if available. */
-			if (mods[i].string) {
-				extract_command(init.tasks[i].name,
-				    CONFIG_TASK_NAME_BUFLEN,
-				    mods[i].string);
-			} else
-				init.tasks[i].name[0] = '\0';
-		}
-	} else
-		init.cnt = 0;
-	
-	/* Copy memory map. */
-	
-	int32_t mmap_length;
-	mb_mmap_t *mme;
-	uint32_t size;
-	
-	if ((flags & MBINFO_FLAGS_MMAP) != 0) {
-		mmap_length = mi->mmap_length;
-		mme = mi->mmap_addr;
-		e820counter = 0;
-		
-		i = 0;
-		while (mmap_length > 0) {
-			e820table[i++] = mme->mm_info;
-			
-			/* Compute address of next structure. */
-			size = sizeof(mme->size) + mme->size;
-			mme = ((void *) mme) + size;
-			mmap_length -= size;
-		}
-		
-		e820counter = i;
-	} else
-		e820counter = 0;
-	
-#ifdef CONFIG_SMP
-	/* Copy AP bootstrap routines below 1 MB. */
-	memcpy((void *) AP_BOOT_OFFSET, (void *) BOOT_OFFSET,
-	    (size_t) &_hardcoded_unmapped_size);
-#endif
-	
-	main_bsp();
-}
-
-/** @}
- */
Index: kernel/arch/ia32/src/ia32.c
===================================================================
--- kernel/arch/ia32/src/ia32.c	(revision 2f5769097aeb16476c39a32de0fe53503cf28a83)
+++ kernel/arch/ia32/src/ia32.c	(revision deca67b8f66138a6a55b92cb5e6baa32bb733f52)
@@ -1,4 +1,6 @@
 /*
  * Copyright (c) 2001-2004 Jakub Jermar
+ * Copyright (c) 2009 Jiri Svoboda
+ * Copyright (c) 2009 Martin Decky
  * All rights reserved.
  *
@@ -64,8 +66,119 @@
 #include <ddi/device.h>
 #include <sysinfo/sysinfo.h>
+#include <arch/boot/boot.h>
+#include <string.h>
+#include <macros.h>
 
 #ifdef CONFIG_SMP
 #include <arch/smp/apic.h>
 #endif
+
+/** Extract command name from the multiboot module command line.
+ *
+ * @param buf      Destination buffer (will always null-terminate).
+ * @param n        Size of destination buffer.
+ * @param cmd_line Input string (the command line).
+ *
+ */
+static void extract_command(char *buf, size_t n, const char *cmd_line)
+{
+	const char *start, *end, *cp;
+	size_t max_len;
+	
+	/* Find the first space. */
+	end = strchr(cmd_line, ' ');
+	if (end == NULL)
+		end = cmd_line + strlen(cmd_line);
+	
+	/*
+	 * Find last occurence of '/' before 'end'. If found, place start at
+	 * next character. Otherwise, place start at beginning of buffer.
+	 */
+	cp = end;
+	start = buf;
+	while (cp != start) {
+		if (*cp == '/') {
+			start = cp + 1;
+			break;
+		}
+		--cp;
+	}
+	
+	/* Copy the command and null-terminate the string. */
+	max_len = min(n - 1, (size_t) (end - start));
+	strncpy(buf, start, max_len + 1);
+	buf[max_len] = '\0';
+}
+
+/** C part of ia32 boot sequence.
+ *
+ * @param signature Should contain the multiboot signature.
+ * @param mi        Pointer to the multiboot information structure.
+ */
+void arch_pre_main(uint32_t signature, const mb_info_t *mi)
+{
+	uint32_t flags;
+	mb_mod_t *mods;
+	uint32_t i;
+	
+	if (signature == MULTIBOOT_LOADER_MAGIC)
+		flags = mi->flags;
+	else {
+		/* No multiboot info available. */
+		flags = 0;
+	}
+	
+	/* Copy module information. */
+	
+	if ((flags & MBINFO_FLAGS_MODS) != 0) {
+		init.cnt = mi->mods_count;
+		mods = mi->mods_addr;
+		
+		for (i = 0; i < init.cnt; i++) {
+			init.tasks[i].addr = mods[i].start + 0x80000000;
+			init.tasks[i].size = mods[i].end - mods[i].start;
+			
+			/* Copy command line, if available. */
+			if (mods[i].string) {
+				extract_command(init.tasks[i].name,
+				    CONFIG_TASK_NAME_BUFLEN,
+				    mods[i].string);
+			} else
+				init.tasks[i].name[0] = '\0';
+		}
+	} else
+		init.cnt = 0;
+	
+	/* Copy memory map. */
+	
+	int32_t mmap_length;
+	mb_mmap_t *mme;
+	uint32_t size;
+	
+	if ((flags & MBINFO_FLAGS_MMAP) != 0) {
+		mmap_length = mi->mmap_length;
+		mme = mi->mmap_addr;
+		e820counter = 0;
+		
+		i = 0;
+		while (mmap_length > 0) {
+			e820table[i++] = mme->mm_info;
+			
+			/* Compute address of next structure. */
+			size = sizeof(mme->size) + mme->size;
+			mme = ((void *) mme) + size;
+			mmap_length -= size;
+		}
+		
+		e820counter = i;
+	} else
+		e820counter = 0;
+	
+#ifdef CONFIG_SMP
+	/* Copy AP bootstrap routines below 1 MB. */
+	memcpy((void *) AP_BOOT_OFFSET, (void *) BOOT_OFFSET,
+	    (size_t) &_hardcoded_unmapped_size);
+#endif
+}
 
 void arch_pre_mm_init(void)
