SISTEMAS OPERATIVOS II
Tercer curso Ingeniería Informática. Curso 2010-2011
Práctica 2: Procesos en Unix: Entorno
Continuar la codificación de un intérprete de comandos (shell) en UNIX. Nótese que los comandos
aquí descritos deben interpretarse de la siguiente manera
- Los argumentos entre corchetes [] son opcionales.
- Los argumentos separados por | indican que debe ir uno u otro, pero no ambos
simultaneamente.
- El intérprete de comandos debe aceptar y entender la sintaxis aquí propuesta, pero no tiene
que forzarla. (por ejemplo, si hay varios argumentos deben aceptarse en el orden especificado,
pero puede resultar mas cómodo de programar asumiendo que pueden ir en cualquier orden)
Además deben tenerse en cuenta las siguientes indicaciones
- En ningún caso debe producir un error de ejecución (segmentation, bus error ...).
La práctica que produzca un error en tiempo de ejecución no será puntuada. Excepcionalmente
se admitirá un error en tiempo de ejecución en algunos comandos: en estos casos se indicará explicitamente (***)
- No debe dilapidar memoria (ejemplo: variable que se asigna cada vez que se llama a una función y no se
libera). NO SE REFIERE A DECLARAR LOS ARRAYS DE TAMAÑO PEQUEÑO
- Cuando el shell no pueda ejecutar una acción por algún motivo, debe indicarlo con un
mensaje como el que se obtiene con sys_errlist[errno] o con perror() (por ejemplo,
si no puede cambiar de directorio debe indicar por qué).
- Las direcciones de memoria deben mostrase en hexadecimal.
- La información que se nuestra en pantalla no debe incluir en ningun caso líneas en blanco
(ni líneas de '*' ni de '=',...).
- El shell leerá de su entrada estándar y escribirá en su salida estándar, de manera que
podría ser ejecutado un archivo de comandos invocando al shell con su entrada estándar
redireccionada a dicho archivo.
El shell debe llevar una lista de directorios (análoga al PATH del bash) donde busca los ejecutables, de manera que cuando
se indica un orden al shell la ejecutará si
- la orden es un comando interno del shell (p.e. autores, getpid ...)
- la orden representa la trayectoria completa a un ejecutable, comenzando por "/", "./" o "../"
- la orden es el nombre de un ejecutable que está en uno de los directorios de la lista antes citada.
La implementación de dicha lista es libre pero NO DEBE implementarse como una variable de entorno. El comando del shell search
muestra y/o manipula dicha lista. Los directorios, salvo el raiz ("/") se especificarán sin la barra al final (/usr/bin y no
/usr/bin/)
En está práctica, además, el shell llevará una lista de todos los procesos en segundo plano que se lanzan desde él; el comando jobs muestra y/o manipula dicha lista.
Comandos a implementar en esta práctica
- search
- [-del|-find|-reset|-importpath] [arg]
- search Muestra la lista de directorios
- search [arg] Añade el directorio arg a la lista de directorios. Si no se especifica arg muestra la lista de directorios
- search -del [arg] Elimina el directorio arg de la lista de directorios. Si no se especifica arg muestra la lista de directorios
- search -find [arg] Nuestra la trayectoria completa al fichero arg si este está en uno de los directorios de la lista. Si no se especifica(análogo al which del sistema
arg muestra la lista de directorios
- search -reset Vacia la lista de directorios
- search -importpath Añade los directorios de la variable de entorno PATH a la lista de deirctorios del shell
- environ
- [-show|-set|-main|-environ] [arg1...] Muestra o modifica el entorno del shell
- environ -show VAR1 VAR2 .... Muestra los valores de las variables de entorno VAR1, VAR2 .... Para cada variable muestra:
- accediendo mediante el tercer argumento de main: Su valor como cadena, su valor
como puntero (la dirección de memoria donde se almacena la cadena) y la dirección de memoria donde se almacena el puntero
- accediendo mediante environ: Su valor como cadena, su valor
como puntero (la dirección de memoria donde se almacena la cadena) y la dirección de memoria donde se almacena el puntero
- accediendo mediante la función de librería getenv: Su valor como cadena
y su valor como puntero.
-> environ -show TERM HOME
mediante arg main 0xbf9a6810--> TERM=xterm (0xbf9a69f2)
mediante environ 0xbf9a6810--> TERM=xterm (0xbf9a69f2)
mediante getenv -->xterm (0xbf9a69f7)
mediante arg main 0xbf9a6864--> HOME=/home/antonio (0xbf9a6ec8)
mediante environ 0xbf9a6864--> HOME=/home/antonio (0xbf9a6ec8)
mediante getenv -->/home/antonio (0xbf9a6ecd)
->
- environ -set [main|environ|putenv] var=nuevovalor ...Cambia el valor de la variable de
entorno var a nuevovalor. main indica acceso mediante el tercer argumento de main, environ mediante
environ y putenv mediante la función de librería putenv. Si la variable var no existe
no la creará, a no ser que se especifique putenv. En este caso putenv creará la variable automaticamente
si no existe
->environ -set putenv TERM=xterm
- environ -main Muestra TODO el entorno del proceso. Se accede mediante el tercer argumento de main
- environ -environ Muestra TODO el entorno del proceso. Se accede mediante environ.
Para cada variable de entorno mostrará
Además mostrará los valores (como puntero) del tercer argumento de main y environ y las direcciónes donde se almacenan
->environ -environ
........
0xbfaa6388->environ[3]=(0xbfaa7716) TERM=xterm
0xbfaa638c->environ[4]=(0xbfaa7721) SHELL=/bin/bash
........
0xbfaa6404->environ[34]=(0xbfaa7fde) _=./entorno.out
0x8049854->environ=0xbfaa637c
0xbfaa62f8->env=0xbfaa637c
- exec
- [LISTAVARIABLES] prog arg1 ... Ejecuta, sin crear proceso (es decir REEMPLAZANDO el código del shell)
el programa prog con sus argumentos. prog representa un ejecutable externo y para poder ser encontrado debe especificarse una
trayectoria completa hasta él (comenzando por "/", "./" o "../") o residir en uno de los directorios del searchlist. Debe usarse la llamada execv. Si se especifica LISTAVARIABLES, la ejecución será mediante execve y el entorno se especifica en LISTAVARIABLES. LISTAVARIABLES puede contener nombres de variables de entorno (el valor se obtiene de environ) o cadenas de la forma NOMBRE=VALOR (se suministra ya la variable con su valor, y la variable no tiene que existir previamente). Si LISTAVARIABLES es "NULLENV" la ejecución será mediante execve y con un entorno vacío (ver ejemplos)
- [LISTAVARIABLES]
- prog arg1 ... & El shell crea un proceso que ejecuta en primer plano
el programa prog con sus argumentos. prog representa un ejecutable externo y para poder ser encontrado debe especificarse una
trayectoria completa hasta él (comenzando por "/", "./" o "../") o residir en uno de los directorios del searchlist. Debe usarse la llamada execv. Si se especifica LISTAVARIABLES, la ejecución será mediante execve y el entorno se especifica en LISTAVARIABLES. LISTAVARIABLES puede contener nombres de variables de entorno (el valor se obtiene de environ) o cadenas de la forma NOMBRE=VALOR (se suministra ya la variable con su valor, y la variable no tiene que existir previamente). Si LISTAVARIABLES es "NULLENV" la ejecución será mediante execve y con un entorno vacío. NO DEBE ESCRIBIRSE "prog" PARA EJECUTAR ALGO. "prog" REPRESENTA EL NOMBRE DEL EJECUTABLE El símbolo & indica que la ejecución es en segundo plano
Ejemplos
*) search /bin
*) search /usr/bin
*) search .
*) /usr/bin/xclock &
*) TERM HOME DISPLAY USER xterm -e bash &
*) exec NULLENV ./a.out
- jobs
- [-del] [all|term|sig|stop|act] Muestra (o manipula) la lista de procesos en
segundo plano del shell.
- jobs [all|term|sig|stop|act] Muestra la lista de procesos en segundo plano. Para cada proceso debe mostrar (en una sola línea) su pid, su prioridad,
la linea de comando que ejecuta, el instante de inicio y su
estado (activo, terminado normalmente, parado o terminado por señal) indicado, en su caso, el valor devuelto o la señal causante de su
terminación o parada. Si no se indican argumentos suficientes (p.e. procesos sin argumentos) se
listarán todos.
- jobs all Muestra todos los procesos
- jobs term Muestra los procesos terminados normalmente
- jobs sig Muestra los procesos terminados por señal
- jobs stop Muestra los prcesos parados
- jobs act Muestra los procesos activos
- procesos -del Elimina de la lista de procesos en segundo plano los procesos que se le especifican.
(Es un comando de manipulación de la lista de procesos en segundo plano, no tiene que terminar los procesos). Si no se indican argumentos suficientes
(p.e. procesos -del sin argumentos) se listarán todos.
- jobs -del all Vacia la lista
- jobs -del term Elimina de la lista los procesos terminados normalmente
- jobs -del sig Elimina de la lista los procesos terminados por señal
- jobs -del stop Elimina de la lista los prcesos parados
- jobs -del act Elimina de la lista los procesos activos
Información detallada de las llamadas al sistema y las funciones de la librería debe
obternerse con man (waitpid, exec, execve, putenv, getenv, ...)
FORMA DE ENTREGA
Va a ser utilizado el servicio de recogida de prácticas suministrado por el Centro de Cálculo de esta Facultad y parte del proceso
de corrección de las prácticas va a ser automtico (compilación, listado de practicas entregadas etc) por lo cual deben entregarse exactamente como se indica a continuación:
FECHA DE ENTREGA VIERNES 8 ABRIL DE 2011