toaruos/kernel/main.c

141 lines
4.4 KiB
C
Raw Normal View History

2011-12-11 03:45:04 +04:00
/* vim: tabstop=4 shiftwidth=4 noexpandtab
2012-03-11 01:03:59 +04:00
*
* The ToAruOS kernel is released under the terms of the
* University of Illinois / NCSA License.
2011-11-29 23:06:17 +04:00
*
2013-01-05 08:42:18 +04:00
* Copyright (c) 2011-2013 Kevin Lange. All rights reserved.
2011-01-29 01:45:27 +03:00
*
2011-10-13 08:24:19 +04:00
* Dedicated to the memory of
* Dennis Ritchie
* 1941-2011
*
2011-01-29 01:45:27 +03:00
* Developed by: ToAruOS Kernel Development Team
* http://github.com/klange/osdev
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to
* deal with the Software without restriction, including without limitation the
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimers.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimers in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the names of the ToAruOS Kernel Development Team, Kevin Lange,
* nor the names of its contributors may be used to endorse
* or promote products derived from this Software without specific prior
* written permission.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* WITH THE SOFTWARE.
*/
2011-01-16 04:01:19 +03:00
#include <system.h>
2011-02-20 04:27:46 +03:00
#include <boot.h>
#include <ext2.h>
#include <fs.h>
2011-12-15 03:47:30 +04:00
#include <logging.h>
#include <process.h>
2012-02-06 00:16:59 +04:00
#include <shm.h>
#include <args.h>
2011-01-16 04:01:19 +03:00
/*
2013-12-16 09:33:46 +04:00
* multiboot i386 (pc) kernel entry point
*/
2012-01-29 22:46:34 +04:00
int main(struct multiboot *mboot, uint32_t mboot_mag, uintptr_t esp) {
initial_esp = esp;
2013-03-18 11:52:12 +04:00
extern char * cmdline;
2011-02-08 08:51:11 +03:00
if (mboot_mag == MULTIBOOT_EAX_MAGIC) {
2012-01-29 22:46:34 +04:00
/* Multiboot (GRUB, native QEMU, PXE) */
2012-12-08 06:33:07 +04:00
debug_print(NOTICE, "Relocating Multiboot structures...");
2011-04-07 02:06:07 +04:00
mboot_ptr = mboot;
char cmdline_[1024];
2012-12-03 11:28:29 +04:00
if (mboot_ptr->vbe_mode_info) {
lfb_vid_memory = (uint8_t *)((vbe_info_t *)(mboot_ptr->vbe_mode_info))->physbase;
}
size_t len = strlen((char *)mboot_ptr->cmdline);
memmove(cmdline_, (char *)mboot_ptr->cmdline, len + 1);
/* Relocate the command line */
cmdline = (char *)kmalloc(len + 1);
memcpy(cmdline, cmdline_, len + 1);
2011-02-08 08:51:11 +03:00
}
2011-01-29 01:45:27 +03:00
/* Initialize core modules */
2013-12-16 09:33:46 +04:00
gdt_install(); /* Global descriptor table */
idt_install(); /* IDT */
isrs_install(); /* Interrupt service requests */
irq_install(); /* Hardware interrupt requests */
/* Memory management */
2013-12-16 09:33:46 +04:00
paging_install(mboot_ptr->mem_upper + mboot_ptr->mem_lower);
heap_install(); /* Kernel heap */
if (cmdline) {
args_parse(cmdline);
}
2013-03-15 11:20:55 +04:00
vfs_install();
2011-01-29 01:45:27 +03:00
/* Hardware drivers */
2013-12-16 09:33:46 +04:00
timer_install(); /* PIC driver */
tasking_install(); /* Multi-tasking */
fpu_install(); /* FPU/SSE magic */
syscalls_install(); /* Install the system calls */
shm_install(); /* Install shared memory */
keyboard_install(); /* Keyboard interrupt handler */
mouse_install(); /* Mouse driver */
keyboard_reset_ps2();
2013-03-15 11:20:55 +04:00
serial_mount_devices();
vfs_mount("/dev/null", null_device_create());
2013-04-01 00:01:05 +04:00
vfs_mount("/dev/zero", zero_device_create());
2013-03-15 11:20:55 +04:00
vfs_mount("/dev/hello", hello_device_create());
2013-03-23 09:38:10 +04:00
vfs_mount("/dev/random", random_device_create());
vfs_mount("/tmp", tmpfs_create());
vfs_mount("/home/local", tmpfs_create());
2013-03-15 11:20:55 +04:00
2013-03-18 11:52:12 +04:00
vfs_mount("/proc", procfs_create());
2013-03-15 11:20:55 +04:00
debug_print_vfs_tree();
legacy_parse_args();
if (!fs_root) {
2012-12-05 08:09:06 +04:00
debug_print(CRITICAL, "There is no file system mounted.");
debug_print(CRITICAL, "You have done something wrong;");
debug_print(CRITICAL, "Did you forget to mount a hard disk?");
while (1) {
}
}
/* Start shell instead */
debug_shell_start();
2012-01-30 22:10:53 +04:00
/* Prepare to run /bin/init */
char * argv[] = {
2012-01-30 22:10:53 +04:00
"/bin/init",
boot_arg,
boot_arg_extra,
NULL
};
int argc = 0;
while (argv[argc]) {
argc++;
}
2012-01-30 22:10:53 +04:00
system(argv[0], argc, argv); /* Run init */
2011-04-09 02:53:52 +04:00
2011-01-16 04:01:19 +03:00
return 0;
}
2011-12-11 03:45:04 +04:00