Descargar la presentación
La descarga está en progreso. Por favor, espere
Publicada porManuela Zúñiga Rey Modificado hace 8 años
1
Introducción a los sistemas de tiempo real Informática III El tiempo es un tirano...
2
Informática IIIIng. Nora BletPág. 2 Objetivos Introducir conceptos básicos relativos a los sistemas de tiempo real (STR) Examinar sus características Analizar técnicas y herramientas para el diseño de los STR
3
Informática IIIIng. Nora BletPág. 3 Referencias Alan Burns, Andy J. Wellings "Sistemas de Tiempo Real y Lenguajes de Programación", Addison-Wesley (3º edición) cap. 1 y 2 Transparencias de Juan Antonio de la Puente http://polaris.dit.upm.es/~jpuente/ y … http://polaris.dit.upm.es/~jpuente/
4
Informática IIIIng. Nora BletPág. 4 Definición de Sistema de tiempo real Sistema informático que debe responder a estímulos generados por su entorno físico (incluido el paso del tiempo físico) en un plazo de tiempo finito y especificado
5
Informática IIIIng. Nora BletPág. 5 Definición de Sistema de tiempo real Interacciona repetidamente con su entorno físico: Realizando acciones de control sobre él Reaccionando a sus cambios La corrección de los mismos depende no sólo del resultado lógico de la computación (corrección lógica), sino también del tiempo en el que se producen los resultados (corrección temporal). (Stankovic, 1988)
6
Informática IIIIng. Nora BletPág. 6 Definición de Sistemas de tiempo real El tiempo en el que se ejecutan las acciones es significativo Sistema de Tiempo Real e1e1 r1r1 e2e2 e3e3 enen r2r2 r3r3 rnrn t e1e1 r1r1 e2e2 e3e3 r2r2 r3r3 e1e1 r1r1 eventosrespuestas
7
Informática IIIIng. Nora BletPág. 7 Tiempo real vs. rapidez En un análisis, que permanece válido aún hoy día, a 22 años, Stankovic lamenta el error de confundir tiempo real con rapidez El STR debe ser suficientemente rápido para cumplir los requerimientos pero, que un sistema sea rápido no implica que sea un STR La rapidez del STR la fijan la naturaleza de los estímulos del entorno, con los cuales tiene que tratar (propio de cada sistema) La clave es la previsibilidad!
8
Informática IIIIng. Nora BletPág. 8 Tiempo real vs. rapidez
9
Informática IIIIng. Nora BletPág. 9 Evolución de la informática
10
Informática IIIIng. Nora BletPág. 10 Sistemas embebidos
11
Informática IIIIng. Nora BletPág. 11 Sistemas embebidos Muchos STR forman parte de un sistema de ingeniería más amplio, tal como es el caso de muchos sistemas de uso común en la industria, transporte, comunicaciones, medicina, el hogar, etc.: Aviones Trenes Autos Teléfonos móviles Televisores, etc.
12
Informática IIIIng. Nora BletPág. 12 Sistemas embebidos Realizan funciones de control de otros sistemas Adaptado de Kopetz (1997)
13
Informática IIIIng. Nora BletPág. 13 Características Los recursos están limitados Procesador, memoria, pantalla, etc. Los dispositivos de entrada y salida son especiales para cada sistema No hay teclado ni pantalla normales El computador debe reaccionar a tiempo ante los cambios en el sistema que controla Una acción retrasada puede ser inútil o peligrosa Ejemplo: imágenes de TV, sistema de frenado ABS El desarrollo de software para sistemas embebidos tiene requisitos especiales
14
Informática IIIIng. Nora BletPág. 14 Tareas de tiempo real
15
Informática IIIIng. Nora BletPág. 15 Tareas de tiempo real Las actividades de un STR se llaman tareas Son activadas por estímulos del entorno (incluido el paso del tiempo). Una tarea es una secuencia de instrucciones que se ejecuta en forma concurrente y compartiendo recursos con otras tareas Se las implementa mediante threads, procesos, etc.
16
Informática IIIIng. Nora BletPág. 16 Tareas de tiempo real Tienen distintos tipos de propiedades Funcionales: ¿Qué hacen? Temporales: ¿Cuándo lo hacen? Fiabilidad, seguridad, etc. El comportamiento temporal de las tareas se especifica mediante sus atributos temporales ¿Cuándo se ejecutan?: Esquema de activación ¿Qué plazo tienen para ejecutar cada acción?
17
Informática IIIIng. Nora BletPág. 17 Tareas de tiempo real
18
Informática IIIIng. Nora BletPág. 18 Ejecución de una tarea de tiempo real
19
Informática IIIIng. Nora BletPág. 19 Atributos temporales Plazo de respuesta Absoluto: tiempo límite para terminar Relativo: intervalo desde la activación Se trata de garantizar que la ejecución de cada tarea termine dentro del plazo
20
Informática IIIIng. Nora BletPág. 20 Atributos temporales
21
Informática IIIIng. Nora BletPág. 21 Atributos temporales Activación Periódica: a intervalos regulares, con período T Aperiódica: cada vez que ocurre un suceso determinado Esporádica: separación mínima entre activaciones T Estocástica, irregular o a rachas
22
Informática IIIIng. Nora BletPág. 22 Tipos de requisitos temporales ¿Qué pasa sino se cumplen? Tiempo real estricto (hard real-time) Todas las acciones deben terminar dentro del plazo especificado. Ejemplo: control de frenado Tiempo real flexible (soft real-time) Se pueden perder plazos de vez en cuando El valor de la respuesta decrece con el tiempo Ejemplo: adquisición de datos Tiempo real firme (firm real-time) Se pueden perder plazos ocasionalmente Una respuesta tardía no tiene valor Ejemplo: Sistema multimedia
23
Informática IIIIng. Nora BletPág. 23 Tipos de requisitos temporales
24
Informática IIIIng. Nora BletPág. 24 Ejemplos de Sistemas en tiempo real
25
Informática IIIIng. Nora BletPág. 25 Ejemplos de Sistemas en tiempo real
26
Informática IIIIng. Nora BletPág. 26 Ejemplos de Sistemas en tiempo real
27
Informática IIIIng. Nora BletPág. 27 Sistema de computador embebido generalizado Control digital Registro de datos Visualización de datos Interfaz de operador Interfaz Sistema controlado Sistema de monitoreo remoto Reloj de tiempo real Base de datos Consola de operador Dispositivos de presentación Real-Time Computer
28
Informática IIIIng. Nora BletPág. 28 Características de los Sistemas en tiempo real Grandes y complejos La variedad de funciones aumenta la complejidad incluso en sistemas relativamente pequeños La adaptación a entornos cambiantes las aplicaciones deben evolucionar continuamente los STR deben ser extensibles
29
Informática IIIIng. Nora BletPág. 29 Características de los Sistemas en tiempo real Manipulación de números reales Ejemplo: Se debe tener un modelo matemático que relacione el calor aplicado y el incremento de temperatura del termo números en punto flotante
30
Informática IIIIng. Nora BletPág. 30 Características de los Sistemas en tiempo real Extremadamente fiables y seguros (dependability) Muchos ejemplos dramáticos ilustran que el hardware y el software de los computadores debe ser fiable y seguro El tamaño y complejidad de los STR exacerban el problema de la fiabilidad Mecanismos para recuperar fallos (esperados y no esperados)
31
Informática IIIIng. Nora BletPág. 31 Características de los Sistemas en tiempo real Simultaneidad de acciones (concurrencia) Los dispositivos físicos controlados funcionan al mismo tiempo Las tareas que los controlan actúan concurrentemente
32
Informática IIIIng. Nora BletPág. 32 Características de los Sistemas en tiempo real Determinismo temporal Acciones en intervalos de tiempo determinados Es fundamental que el comportamiento temporal de los STR sea determinista o, al menos, previsible No confundir con eficiencia El STR debe responder correctamente en todas las situaciones En los STR estrictos hay que prever el comportamiento en el peor caso posible
33
Informática IIIIng. Nora BletPág. 33 Características de los Sistemas en tiempo real Interacción con el hardware Los manejadores de dispositivos forman parte del software de aplicación Implementación eficiente Puesto que los STR son críticos respecto al tiempo, este requisito es más importante que en otro tipo de sistemas
34
Informática IIIIng. Nora BletPág. 34 Desarrollo de Sistemas en tiempo real
35
Informática IIIIng. Nora BletPág. 35 Desarrollo de Sistemas en tiempo real Los métodos, herramientas y tecnologías que se usan para construir otros tipos de sistemas no sirven para los STR No son lo suficientemente fiables Sólo contemplan tiempos de respuesta medio, no el peor No garantizan los requisitos temporales Las plataformas de desarrollo y ejecución suelen ser diferentes Es difícil hacer pruebas en la plataforma de ejecución Es difícil medir los tiempos con precisión
36
Informática IIIIng. Nora BletPág. 36 Desarrollo cruzado
37
Informática IIIIng. Nora BletPág. 37 Aspectos de un sistema Funcionalidad Relación entre entradas y salidas No se considera concurrencia, sincronización, tiempo real, fiabilidad, seguridad, etc. Arquitectura Componentes definidos por sus interfaces Concurrencia y tiempo real Hebras, sincronización Planificación y análisis temporal Implementación Código de aplicación Plataforma: RTOS, middleware
38
Informática IIIIng. Nora BletPág. 38 Diseño de Sistemas de tiempo real
39
Informática IIIIng. Nora BletPág. 39 Diseño de Sistemas de tiempo real
40
Informática IIIIng. Nora BletPág. 40 Diseño de Sistemas de tiempo real
41
Informática IIIIng. Nora BletPág. 41 Diseño de Sistemas en tiempo real
42
Informática IIIIng. Nora BletPág. 42 Diseño de Sistemas de tiempo real Las actividades de desarrollo de los STR incluyen las tradicionales de otros sistemas, aunque tienen requerimientos adicionales
43
Informática IIIIng. Nora BletPág. 43 Integración de métodos y herramientas
44
Informática IIIIng. Nora BletPág. 44 Integración de métodos y herramientas
45
Informática IIIIng. Nora BletPág. 45 Integración de métodos y herramientas
46
Informática IIIIng. Nora BletPág. 46 Integración de métodos y herramientas
47
Informática IIIIng. Nora BletPág. 47 Lenguajes de programación Hay varias clases de lenguajes de interés para los STR: Assembler Flexibles y eficientes pero costosos y poco fiables
48
Informática IIIIng. Nora BletPág. 48 Lenguajes de programación
49
Informática IIIIng. Nora BletPág. 49 Lenguajes de programación
50
Informática IIIIng. Nora BletPág. 50 Lenguajes de tiempo real
51
Informática IIIIng. Nora BletPág. 51 Lenguajes de tiempo real Requerimientos Robustez (Seguridad) Legibilidad Flexibilidad Simplicidad Portabilidad Eficiencia
52
Informática IIIIng. Nora BletPág. 52 Lenguajes de tiempo real Robustez Medida del grado en el que el compiladorpuede detectar automáticamente los errores de programación Requiere Que el lenguaje esté bien estructurado y sea legible, de modo que tales errores puedan ser localizados fácilmente Beneficios: La detección temprana de errores en el desarrollo del programa reducción general del coste Las comprobaciones de tiempo de compilación no sobrecargan la ejecución del proceso, y un programa se ejecuta más veces de las que se compila Inconveniente Puede llegar a complicar el lenguaje e incrementar tanto el tiempo de compilación como la complejidad del compilador
53
Informática IIIIng. Nora BletPág. 53 Lenguajes de tiempo real Legibilidad (Medida de la claridad de un programa) Minimiza la necesidad de comentarios y descripciones adicionales Requiere Palabras claves, nombres de tipos, nombres de variables y la capacidad del lenguaje para permitir la modularización del código Beneficios Menores costes de documentación Mayor robustez Mayor facilidad de mantenimiento Inconveniente Mayor longitud de los programas
54
Informática IIIIng. Nora BletPág. 54 Lenguajes de tiempo real Flexibilidad Permite al programador expresar todas las operaciones oportunas de una forma directa y coherente Menor necesidad de recurrir a funciones del sistema operativo o a fragmentos en código máquina para obtener el resultado deseado
55
Informática IIIIng. Nora BletPág. 55 Lenguajes de tiempo real Simplicidad – (Poder usarlo fácilmente) Minimiza el esfuerzo de producción de compiladores Reduce el costo asociado a la formación de programadores Disminuye los errores de programación como consecuencia de una mala interpretación de las características del lenguaje
56
Informática IIIIng. Nora BletPág. 56 Lenguajes de tiempo real Portabilidad Un programa deberá ser independiente, en la medida de lo posible, del hardware sobre el que se ejecuta En los STR una parte importante de cualquier programa estará involucrada en la manipulación de recursos hardware El lenguaje debe ser capaz de aislar la parte del programa que depende de la máquina de la parte independiente de la máquina
57
Informática IIIIng. Nora BletPág. 57 Lenguajes de tiempo real Eficiencia Deben producir sistemas con tiempos de ejecución predecibles evitar aquellos mecanismos que conduzcan a sobrecargas impredecibles del tiempo de ejecución
58
Informática IIIIng. Nora BletPág. 58 Lenguajes de tiempo real Por lo menos hasta ahora no existe ningún lenguaje que sobresalga en todos estos ítems En el diseño de cualquier lenguaje, general o de tiempo real, se deben analizar y sopesar ventajas y desventajas de cada decisión
Presentaciones similares
© 2024 SlidePlayer.es Inc.
All rights reserved.