Subsecciones

6.9 ./init/*

6.9.1 main.c

Este fichero es el que inicia en cualquier sistema linux el proceso con pid 1, el proceso init. Se definen las primeras variables de arranque y seguidamente se invoca a tres funciones importantes.
  1. extern void prepare_namespace() . Prepara el namespace, es decir, decide qué y donde montar, cargar los ramdisks, etc. Su implementación puede encontrarse en /init/do_mounts.c y no sufre modificaciones por el parche de openMosix.

  2. static int init(void * unused) . Ejecuta los primeros procesos del sistema. Esto incluye también a la función init_mosix() cuya implementación se encuentra en ./hpc/init.c .

  3. init_mosix() . Véanse comentarios en la implementación.



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 */
}

miKeL a.k.a.mc2 2004-09-06