extern void prepare_namespace()
void prepare_namespace(void) { int is_floppy = MAJOR(ROOT_DEV) == FLOPPY_MAJOR; #ifdef CONFIG_ALL_PPC extern void arch_discover_root(void); arch_discover_root(); #endif /* CONFIG_ALL_PPC */ #ifdef CONFIG_BLK_DEV_INITRD if (!initrd_start) mount_initrd = 0; real_root_dev = ROOT_DEV; #endif sys_mkdir("/dev", 0700); sys_mkdir("/root", 0700); sys_mknod("/dev/console", S_IFCHR|0600, MKDEV(TTYAUX_MAJOR, 1)); #ifdef CONFIG_DEVFS_FS sys_mount("devfs", "/dev", "devfs", 0, NULL); do_devfs = 1; #endif create_dev("/dev/root", ROOT_DEV, NULL); if (mount_initrd) { if (initrd_load() && ROOT_DEV != MKDEV(RAMDISK_MAJOR, 0)) { handle_initrd(); goto out; } } else if (is_floppy && rd_doload && rd_load_disk(0)) ROOT_DEV = MKDEV(RAMDISK_MAJOR, 0); mount_root(); out: sys_umount("/dev", 0); sys_mount(".", "/", NULL, MS_MOVE, NULL); sys_chroot("."); mount_devfs_fs (); }
static int init(void * unused)
static int init(void * unused) { lock_kernel(); do_basic_setup(); prepare_namespace(); free_initmem(); #ifdef CONFIG_MOSIX init_mosix(); #endif /* CONFIG_MOSIX */ unlock_kernel(); if (open("/dev/console", O_RDWR, 0) < 0) printk("Warning: unable to open an initial console.\n"); (void) dup(0); (void) dup(0); if (execute_command) execve(execute_command,argv_init,envp_init); execve("/sbin/init",argv_init,envp_init); execve("/etc/init",argv_init,envp_init); execve("/bin/init",argv_init,envp_init); execve("/bin/sh",argv_init,envp_init); panic("No init found. Try passing init= option to kernel."); }
init_mosix()
void init_mosix(void) { extern int x86_udelay_tsc; cpuspeed = ((int64_t)loops_per_jiffy) * STD_SPD / STD_LOOPS; /* velocidad del nodo */
La constante de openMosix STD_SPD debe su nombre a standard speed y se define en ./include/hpc/defs.h como 15000.
if(!x86_udelay_tsc) cpuspeed *= 2;
La constante x86_udelay_tsc se define en ./lib/delay.c como el entero de valor 0 -cero-. Como puede leerse, si el delay entre dos lecturas al registro TSC es cero, se dobla el valor de velocidad tomado para el nodo donde se inicialice el servicio openMosix.
El TimeStamp Counter (TSC) es un valor que se toma de un registro que poseen todos los nuevos procesadores. Este registro se incrementa cada ciclo de reloj. Leyendo 2 veces el registro y dividiendo la diferencia de ciclos obtenida entre el intervalo de tiempo transcurrido, se obtiene la frecuencia de reloj del procesador.
info_init();Esta función está implementada en ./hpc/info.c. Define los valores para:
proc_update_costs();
#ifdef CONFIG_MOSIX_FS init_mfs(); /* si el kernel soporta MFS, se inicia */ #endif /* CONFIG_MOSIX_FS */ #ifdef CONFIG_MOSIX_DFSA dfsa_init(); /* si el kernel soporta DFSA, se inicia */ #endif /* CONFIG_MOSIX_DFSA */ kernel_thread(mosix_mig_daemon, NULL, 0); /* se inicia el daemon de migracion */ /* como hebra del kenel */ info_startup();
Esta función también está implementada en ./hpc/info.c . Toma una ventana de información del cluster -i.e. varios nodos, pueden no ser todos- y evalá su ponderación.
mosix_load_init(); /* actualiza la carga instantanea del nodo */ mosinfo_update_gateways(); /* actualiza costes de envios entre nodos */ kernel_thread(mosix_info_daemon, NULL, 0); /* daemon de informacion del sistema */ kernel_thread(mosix_mem_daemon, NULL, 0); /* daemon para la memoria */ }